成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

TP5整合阿里云OSS上傳文件第二節(jié),異步上傳頭像(下)

dmlllll / 2455人閱讀

摘要:找到頭像下面的添加一個的樣式類將內(nèi)容改變成上傳成功并且顯示上傳成功文件上傳失敗,同樣是添加找到頭像下面的添加一個的樣式類將內(nèi)容改變成上傳失敗并且顯示上傳失敗完成上傳完了,成功或者失敗,先刪除進度條。

是這個功能的最后一步了,
新增插件:
layer.js 彈窗層組件
jquery.form 異步表單提交插件

新增CSS:
layer擴展文件 修改layer彈窗的皮膚,默認的不喜歡!
基本代碼和之前第二節(jié)的差不多,修改了upload.js里面的一點點東西

先看看演示吧!

簡單的數(shù)據(jù)表:

-- 圖片表
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 "創(chuàng)建時間",
  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 "創(chuàng)建時間",
  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 外網(wǎng)地址endpoint
    "Bucket"     => "****",  //Bucket名稱
    "OssDomain" => "http://thinkpjax.cn/",  // 這個配置是新增的
];

創(chuàng)建基礎(chǔ)模型類 (application/index/model/base.php)

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

創(chuàng)建用戶模型(application/index/model/User.php) 繼承基礎(chǔ)模型類
創(chuàng)建圖片模型(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: [email protected]
 */
$(function () {
    var $face = $("#face"), thumbnailWidth = 100, thumbnailHeight = 100;
    //創(chuàng)建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
        // 創(chuàng)建縮略圖
        this.makeThumb(file, function (error, src) {
            if (error) {
                $img.replaceWith("不能預覽");
                return;
            }
            $img.attr("src", src);
        }, thumbnailWidth, thumbnailHeight);
    }).on("uploadProgress", function (file, percentage) {
        // 文件上傳過程中創(chuàng)建進度條實時顯示。
        $percent = $face.find(".progress .progress-bar");
        $ImgId = $face.find($("input[name="imgId"]"));
        if (!$ImgId.length) {
            $ImgId = $face.append("");
        }
        // 避免重復創(chuàng)建
        if (!$percent.length) {
            //構(gòu)建進度條DOM
            $face.append("
"); //這個是提示框 $percent = $("
").appendTo($face).find("progress-bar"); } $percent.css({"width": 50 + "%"}); //讓進度條動起來 }).on("uploadSuccess", function (file, response) { // 文件上傳成功,給dialog添加class, 用樣式標記上傳成功。 //找到頭像DIV下面的dialog 添加一個success的樣式類將內(nèi)容改變成上傳成功并且顯示! $face.find(".dialog").addClass("success").text("上傳成功").show(); $face.find($("input[name="imgId"]")).val(response.data.imgId); }).on("uploadError", function (file) { // 文件上傳失敗,同樣是添加Class //找到頭像DIV下面的dialog 添加一個error的樣式類將內(nèi)容改變成上傳失敗并且顯示! $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();
            //執(zhí)行阿里云上傳
            $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與數(shù)據(jù)庫里面的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()
    {
       /**
         * 使用動態(tài)關(guān)聯(lián)預載入
         */
        $userData = (new UserModel())->with("img")->find(parent::$uid);
        return $this->fetch("up", [
            "data" => $userData,
        ]);
    }

基礎(chǔ)模型類:

           
               
                                           
                       
                 

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/30806.html

相關(guān)文章

  • TP5整合阿里OSS上傳文件二節(jié),異步上傳頭像()

    摘要:找到頭像下面的添加一個的樣式類將內(nèi)容改變成上傳成功并且顯示上傳成功文件上傳失敗,同樣是添加找到頭像下面的添加一個的樣式類將內(nèi)容改變成上傳失敗并且顯示上傳失敗完成上傳完了,成功或者失敗,先刪除進度條。 是這個功能的最后一步了,新增插件:layer.js 彈窗層組件jquery.form 異步表單提交插件 新增CSS:layer擴展文件 修改layer彈窗的皮膚,默認的不喜歡!基本代碼和之...

    qiangdada 評論0 收藏0
  • TP5整合阿里OSS上傳文件二節(jié),異步上傳頭像()

    摘要:找到頭像下面的添加一個的樣式類將內(nèi)容改變成上傳成功并且顯示上傳成功文件上傳失敗,同樣是添加找到頭像下面的添加一個的樣式類將內(nèi)容改變成上傳失敗并且顯示上傳失敗完成上傳完了,成功或者失敗,先刪除進度條。 是這個功能的最后一步了,新增插件:layer.js 彈窗層組件jquery.form 異步表單提交插件 新增CSS:layer擴展文件 修改layer彈窗的皮膚,默認的不喜歡!基本代碼和之...

    draveness 評論0 收藏0
  • TP5整合阿里OSS上傳文件二節(jié),異步上傳頭像()

    摘要:找到頭像下面的添加一個的樣式類將內(nèi)容改變成上傳成功并且顯示上傳成功文件上傳失敗,同樣是添加找到頭像下面的添加一個的樣式類將內(nèi)容改變成上傳失敗并且顯示上傳失敗完成上傳完了,成功或者失敗,先刪除進度條。 是這個功能的最后一步了,新增插件:layer.js 彈窗層組件jquery.form 異步表單提交插件 新增CSS:layer擴展文件 修改layer彈窗的皮膚,默認的不喜歡!基本代碼和之...

    Dongjie_Liu 評論0 收藏0
  • TP5整合阿里OSS上傳文件二節(jié),異步上傳頭像實現(xiàn),

    摘要:版本也是我最喜歡的方式這個代碼有點黏在一起了湊合看把李昊天創(chuàng)建實例服務器異步接受地址指定選擇文件的按鈕容器禁止多選不壓縮選擇之后自動上傳防止低版本瀏覽器用到了只允許選擇圖片文件。 TP5整合阿里云OSS上傳文件第二節(jié),上傳頭像實現(xiàn)首先先看一個效果圖上傳失敗效果圖:showImg(https://segmentfault.com/img/bVbaJLZ?w=983&h=561);上傳成功...

    douzifly 評論0 收藏0
  • TP5整合阿里OSS上傳文件二節(jié),異步上傳頭像實現(xiàn),

    摘要:版本也是我最喜歡的方式這個代碼有點黏在一起了湊合看把李昊天創(chuàng)建實例服務器異步接受地址指定選擇文件的按鈕容器禁止多選不壓縮選擇之后自動上傳防止低版本瀏覽器用到了只允許選擇圖片文件。 TP5整合阿里云OSS上傳文件第二節(jié),上傳頭像實現(xiàn)首先先看一個效果圖上傳失敗效果圖:showImg(https://segmentfault.com/img/bVbaJLZ?w=983&h=561);上傳成功...

    dayday_up 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<