9、ThinkPHP6实战开发高大上企业站(TP6)之图片上传

前言 在我们制作网站的过程中,图片上传功能是很常用的一个功能。例如:头像、文章缩略图等。今天给大家安排上。文章 […]

前言

在我们制作网站的过程中,图片上传功能是很常用的一个功能。例如:头像、文章缩略图等。今天给大家安排上。文章上传我是基于layui上传组件。后台代码应该是一致的。

 

前台

// html
<div class="layui-form-item h-form-item">
  <label class="layui-form-label">封面</label>
  <div class="layui-input-inline">
    <input name="cover" lay-verify="required" id="LAY_avatarSrc" placeholder="请输入封面图片" value=""
      class="layui-input">
  </div>
  <div class="layui-input-inline layui-btn-container" style="width: auto;">
    <button type="button" class="layui-btn layui-btn-primary" id="LAY_avatarUpload">
      <i class="layui-icon">&#xe67c;</i>上传图片
    </button>
    <!-- <button class="layui-btn layui-btn-primary" layadmin-event="avartatPreview">预览</button> -->
  </div>
</div>

 

// js
upload.render({
        elem: '#LAY_avatarUpload',
        url: '/admin/upload/', // 此处配置你自己的上传接口即可
        size: 10 * 1024, // 限制文件大小,单位 KB
        accept: 'images ',
        done: function (res) {
          // layer.msg('上传成功')
          console.log(res)
          if(res.code === 200) {
            form.val('form-val-filter', {
              cover: res.data
            });
          }
        }
      })

 

后台

新建一个Upload控制器,并在index中添加如下方法

// 获取上传的文件对象
        $file = Request()->file('file');

        $savename = thinkfacadeFilesystem::disk('public')->putFile('uploads', $file);

        if($savename) {
            return jsonSuccess('数据获取成功~', '/public/' . $savename);
        } else {
            return jsonError('上传失败:' . $file->getError());
        }

 

最终效果

 

版权声明
文章标题:9、ThinkPHP6实战开发高大上企业站(TP6)之图片上传
文章链接:https://blog.chiyuba.com/houduanjishu/php/505.html
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布,转载或引用请注明出处。
温馨提示:本文最后更新于 2025年7月9日,部分内容可能存在时效性,请注意甄别。

相关推荐

更多教程
phpstorm代码格式化快捷键是什么(phpstorm代码格式化快捷键) php phpstorm代码格式化快捷键是什么(phpstorm代码格式化快捷键)

前言 今天开始休假,打算折腾一下word...

2 浏览
零基础网站入门:网站相关关键词说明 php 零基础网站入门:网站相关关键词说明

前言 最近小伙伴想学习网站搭建,本来自己...

2 浏览
2、ThinkPHP6实战开发高大上企业站(TP6)之连接数据库 php 2、ThinkPHP6实战开发高大上企业站(TP6)之连接数据库

  前言 连接数据库之前,必须...

5 浏览

评论