资讯专栏INFORMATION COLUMN

TP5整合阿里云OSS上传文件第二节,异步上传头像(下)

Dongjie_Liu / 2632人阅读

摘要:找到头像下面的添加一个的样式类将内容改变成上传成功并且显示上传成功文件上传失败,同样是添加找到头像下面的添加一个的样式类将内容改变成上传失败并且显示上传失败完成上传完了,成功或者失败,先删除进度条。

是这个功能的最后一步了,
新增插件:
layer.js 弹窗层组件
jquery.form 异步表单提交插件

新增CSS:
layer扩展文件 修改layer弹窗的皮肤,默认的不喜欢!
基本代码和之前第二节的差不多,修改了upload.js里面的一点点东西

先看看演示吧!

简单的数据表:

-- 图片表
DROP TABLE IF EXISTS images;
CREATE TABLE IF NOT EXISTS images(
  id INT(11) UNSIGNED PRIMARY KEY AUTO_INCREMENT COMMENT "id",
  img_url VARCHAR(255) NOT NULL DEFAULT "" COMMENT "图片名称",
  create_time INT NOT NULL DEFAULT 0 COMMENT "创建时间",
  update_time INT NOT NULL DEFAULT 0 COMMENT "更新时间"
)ENGINE innodb CHARSET utf8 COMMENT "图片表";
-- 用户表
DROP TABLE if EXISTS user;
CREATE TABLE IF NOT EXISTS user(
  id INT(11) UNSIGNED PRIMARY KEY AUTO_INCREMENT COMMENT "id",
  img_id int(11) UNSIGNED NOT NULL DEFAULT 0 COMMENT "图片ID",
  create_time INT NOT NULL DEFAULT 0 COMMENT "创建时间",
  update_time INT NOT NULL DEFAULT 0 COMMENT "更新时间"
)ENGINE innodb CHARSET utf8 COMMENT "用户表";

之后再aliyunOss配置文件中增加一个配置,就是访问的域名;

//阿里云OSS配置
return [
    "KeyId"      => "***",  //您的Access Key ID
    "KeySecret"  => "***",  //您的Access Key Secret
    "Endpoint"   => "****",  //阿里云oss 外网地址endpoint
    "Bucket"     => "****",  //Bucket名称
    "OssDomain" => "http://thinkpjax.cn/",  // 这个配置是新增的
];

创建基础模型类 (application/index/model/base.php)

hasOne("Images","id","img_id");
    }
}

创建用户模型(application/index/model/User.php) 继承基础模型类
创建图片模型(application/index/model/Images.php)


修改upload.js

$ImgId = $face.find($("input[name="imgId"]"));
if (!$ImgId.length) {
$ImgId = $face.append("");
}

$face.find($("input[name="imgId"]")).val(response.data.imgId);

完整代码:

/**
 * User: 李昊天
 * Date: 2018/5/18
 * Time: 1:15
 * Email: haotian0607@gmail.com
 */
$(function () {
    var $face = $("#face"), thumbnailWidth = 100, thumbnailHeight = 100;
    //创建uploader实例
    WebUploader.create({
        server: uploaderUrl, //服务器异步接受地址!
        pick: {
            id: "#changeFile", //指定选择文件的按钮容器
            multiple: false, //禁止多选
        },
        resize: false, //不压缩image
        auto: true, //选择之后自动上传
        swf: "../flash/Uploader.swf", //防止低版本浏览器 用到了flash
        // 只允许选择图片文件。
        accept: {
            title: "Images",
            extensions: "gif,jpg,jpeg,bmp,png",
            mimeTypes: "image/*"
        }
    }).on("fileQueued", function (file) {
        // 当有文件添加进来的时候
        var $img = $face.find("img"); //获取到头像的DOM
        // 创建缩略图
        this.makeThumb(file, function (error, src) {
            if (error) {
                $img.replaceWith("不能预览");
                return;
            }
            $img.attr("src", src);
        }, thumbnailWidth, thumbnailHeight);
    }).on("uploadProgress", function (file, percentage) {
        // 文件上传过程中创建进度条实时显示。
        $percent = $face.find(".progress .progress-bar");
        $ImgId = $face.find($("input[name="imgId"]"));
        if (!$ImgId.length) {
            $ImgId = $face.append("");
        }
        // 避免重复创建
        if (!$percent.length) {
            //构建进度条DOM
            $face.append("
"); //这个是提示框 $percent = $("
").appendTo($face).find("progress-bar"); } $percent.css({"width": 50 + "%"}); //让进度条动起来 }).on("uploadSuccess", function (file, response) { // 文件上传成功,给dialog添加class, 用样式标记上传成功。 //找到头像DIV下面的dialog 添加一个success的样式类将内容改变成上传成功并且显示! $face.find(".dialog").addClass("success").text("上传成功").show(); $face.find($("input[name="imgId"]")).val(response.data.imgId); }).on("uploadError", function (file) { // 文件上传失败,同样是添加Class //找到头像DIV下面的dialog 添加一个error的样式类将内容改变成上传失败并且显示! $face.find(".dialog").addClass("error").text("上传失败").show(); }).on("uploadComplete", function (file) { // 完成上传完了,成功或者失败,先删除进度条。 $face.find(".progress").remove(); }); });

修改up.html里面的代码:
主要是加入表单,加入提交按钮,加入form.js和layer.js
主要部分代码:

选择文件

加入操作的js

后端代码也有更改:

public function uploadFile()
    {
//        sleep(3);
        $file = request()->file("file");  //获取到上传的文件
        $resResult = Image::open($file);
        try {
            $config = Config::pull("aliyun_oss"); //获取Oss的配置
            //实例化对象 将配置传入
            $ossClient = new OssClient($config["KeyId"], $config["KeySecret"], $config["Endpoint"]);
            //这里是有sha1加密 生成文件名 之后连接上后缀
            $fileName = sha1(date("YmdHis", time()) . uniqid()) . "." . $resResult->type();
            //执行阿里云上传
            $result = $ossClient->uploadFile($config["Bucket"], $fileName, $file->getInfo()["tmp_name"]);
            if ($result && $result["info"]["http_code"] == 200) {
                try {
                    $Images = new Images(); //实例化图片模型
                    $Images->allowField("img_url")->save([
                        "img_url" => $fileName   //写入上传的文件名
                    ]);
                    return ajaxReturn(parent::SUCCESS, "success", [
                        "imgId" => $Images->id,
                    ]);
                } catch (Exception $e) {
                    return ajaxReturn(parent::FAIL, "error");
                }
            } else {
                return ajaxReturn(parent::FAIL, "error");
            }
        } catch (OssException $e) {
            return $e->getMessage();
        }
    }

最好是在修改的时候判断表单传递的imgId与数据库里面的ID,如果一致就不允许修改!
修改逻辑代码:

 public function modify()
    {
        if (request()->isPost()) {
            $userData = (new UserModel())->find(parent::$uid);
            if (null === $userData) {
                return ajaxReturn(parent::FAIL, "获取用户信息失败,请重新登录!");
            }
            $imgId = input("post.imgId", "");
            $result = $userData->allowField("img_id")->save(["img_id" => $imgId]);
            if ($result) {
                return ajaxReturn(parent::SUCCESS, "修改成功!");
            } else {
                return ajaxReturn(parent::FAIL, "操作失败!");
            }
        }
    }

up控制器:

public function up()
    {
       /**
         * 使用动态关联预载入
         */
        $userData = (new UserModel())->with("img")->find(parent::$uid);
        return $this->fetch("up", [
            "data" => $userData,
        ]);
    }

基础模型类:

           
               
                                           
                       
                 

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/52384.html

相关文章

  • TP5整合阿里OSS上传文件二节,异步上传头像()

    摘要:找到头像下面的添加一个的样式类将内容改变成上传成功并且显示上传成功文件上传失败,同样是添加找到头像下面的添加一个的样式类将内容改变成上传失败并且显示上传失败完成上传完了,成功或者失败,先删除进度条。 是这个功能的最后一步了,新增插件:layer.js 弹窗层组件jquery.form 异步表单提交插件 新增CSS:layer扩展文件 修改layer弹窗的皮肤,默认的不喜欢!基本代码和之...

    qiangdada 评论0 收藏0
  • TP5整合阿里OSS上传文件二节,异步上传头像()

    摘要:找到头像下面的添加一个的样式类将内容改变成上传成功并且显示上传成功文件上传失败,同样是添加找到头像下面的添加一个的样式类将内容改变成上传失败并且显示上传失败完成上传完了,成功或者失败,先删除进度条。 是这个功能的最后一步了,新增插件:layer.js 弹窗层组件jquery.form 异步表单提交插件 新增CSS:layer扩展文件 修改layer弹窗的皮肤,默认的不喜欢!基本代码和之...

    dmlllll 评论0 收藏0
  • TP5整合阿里OSS上传文件二节,异步上传头像()

    摘要:找到头像下面的添加一个的样式类将内容改变成上传成功并且显示上传成功文件上传失败,同样是添加找到头像下面的添加一个的样式类将内容改变成上传失败并且显示上传失败完成上传完了,成功或者失败,先删除进度条。 是这个功能的最后一步了,新增插件:layer.js 弹窗层组件jquery.form 异步表单提交插件 新增CSS:layer扩展文件 修改layer弹窗的皮肤,默认的不喜欢!基本代码和之...

    draveness 评论0 收藏0
  • TP5整合阿里OSS上传文件二节,异步上传头像实现,

    摘要:版本也是我最喜欢的方式这个代码有点黏在一起了凑合看把李昊天创建实例服务器异步接受地址指定选择文件的按钮容器禁止多选不压缩选择之后自动上传防止低版本浏览器用到了只允许选择图片文件。 TP5整合阿里云OSS上传文件第二节,上传头像实现首先先看一个效果图上传失败效果图:showImg(https://segmentfault.com/img/bVbaJLZ?w=983&h=561);上传成功...

    douzifly 评论0 收藏0
  • TP5整合阿里OSS上传文件二节,异步上传头像实现,

    摘要:版本也是我最喜欢的方式这个代码有点黏在一起了凑合看把李昊天创建实例服务器异步接受地址指定选择文件的按钮容器禁止多选不压缩选择之后自动上传防止低版本浏览器用到了只允许选择图片文件。 TP5整合阿里云OSS上传文件第二节,上传头像实现首先先看一个效果图上传失败效果图:showImg(https://segmentfault.com/img/bVbaJLZ?w=983&h=561);上传成功...

    dayday_up 评论0 收藏0

发表评论

0条评论

Dongjie_Liu

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<