微信中七牛云上传的upload文件 (--sdk 二次改动过)

我自己修改了一些地方,对应我写的 七牛云上传

// created by gpake
(function() {

	var config = {
	    qiniuRegion: '',
	    qiniuImageURLPrefix: '',
	    qiniuUploadToken: '',
	    qiniuUploadTokenURL: '',
	    qiniuUploadTokenFunction: null
	}
	
	module.exports = {
	    init: init,
	    upload: upload,
	}
	
	// 在整个程序生命周期中,只需要 init 一次即可
	// 如果需要变更参数,再调用 init 即可
	function init(options) {
	    config = {
	        qiniuRegion: '',
	        qiniuImageURLPrefix: '',
	        qiniuUploadToken: '',
	        qiniuUploadTokenURL: '',
	        qiniuUploadTokenFunction: null
	    };
	    updateConfigWithOptions(options);
	}
	
	function updateConfigWithOptions(options) {
	    if (options.region) {
	        config.qiniuRegion = options.region;
	    } else {
	        console.error('qiniu uploader need your bucket region');
	    }
	    if (options.uptoken) {
	        config.qiniuUploadToken = options.uptoken;
	    } else if (options.uptokenURL) {
	        config.qiniuUploadTokenURL = options.uptokenURL;
	    } else if(options.uptokenFunc) {
	        config.qiniuUploadTokenFunction = options.uptokenFunc;
	    }
	    if (options.domain) {
	        config.qiniuImageURLPrefix = options.domain;
	    }
	}
	
	function upload(params) {
	  //filePath, success, fail, options
	  let filePath = params.filePath
	  let success = params.success
	  let fail = params.fail
	  let options = params.options
	    if (null == filePath) {
	        console.error('qiniu uploader need filePath to upload');
	        return;
	    }
	    if (options) {
	        init(options);
	    }
	    if (config.qiniuUploadToken) {
	        doUpload(filePath, success, fail, options);
	    } else if (config.qiniuUploadTokenURL) {
	        getQiniuToken(function() {
	            doUpload(filePath, success, fail, options);
	        });
	    } else if (config.qiniuUploadTokenFunction) {
	        config.qiniuUploadToken = config.qiniuUploadTokenFunction();
	    } else {
	        console.error('qiniu uploader need one of [uptoken, uptokenURL, uptokenFunc]');
	        return;
	    }
	}
	
	function doUpload(filePath, success, fail, options) {
	    var url = uploadURLFromRegionCode(config.qiniuRegion);
	    var fileName = filePath.split('/')[1];
	    if (options && options.key) {
	        fileName = options.key;
	    }
	    var formData = {
	        'token': config.qiniuUploadToken,
	        'key': fileName
	    };
	    wx.uploadFile({
	        url: url,
	        filePath: filePath,
	        name: 'file',
	        formData: formData,
	        success: function (res) {
	            var dataString = res.data
	            var dataObject = JSON.parse(dataString);
	            //do something
	            var imageUrl = config.qiniuImageURLPrefix + dataObject.key;
	            dataObject.imageURL = imageUrl;
	            console.log(dataObject);
	            if (success) {
	                success(dataObject);
	            }
	        },
	        fail: function (error) {
	            console.log(error);
	            if (fail) {
	                fail(error);
	            }
	        }
	    })
	}
	
	function getQiniuToken(callback) {
	  wx.request({
	    url: config.qiniuUploadTokenURL,
	    success: function (res) {
	      var token = res.data.uptoken;
	      config.qiniuUploadToken = token;
	      if (callback) {
	          callback();
	      }
	    },
	    fail: function (error) {
	      console.log(error);
	    }
	  })
	}
	
	function uploadURLFromRegionCode(code) {
	    var uploadURL = null;
	    switch(code) {
	        case 'ECN': uploadURL = 'https://up.qbox.me'; break;
	        case 'NCN': uploadURL = 'https://up-z1.qbox.me'; break;
	        case 'SCN': uploadURL = 'https://up-z2.qbox.me'; break;
	        case 'NA': uploadURL = 'https://up-na0.qbox.me'; break;
	        default: console.error('please make the region is with one of [ECN, SCN, NCN, NA]');
	    }
	    return uploadURL;
	}
})();
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
el-upload是一个用于上传图片的组件,而七牛云是一种云存储服务。你可以通过将这两者结合使用,实现将图片上传七牛云的功能。 具体的步骤如下: 1. 首先,你需要从后台获取七牛云的token,这个token将用于上传图片到七牛云。你可以通过调用后端提供的接口,传入AccessKey、SecretKey和Bucket等信息来获取token。 2. 在el-upload组件,你需要配置action属性为https://upload.qiniup.com,这是七牛云存储区域的上传地址。不同的七牛云存储区域可能会有不同的地址,请根据自己使用的七牛云服务器存储区域来确定具体的地址。 3. 配置el-upload组件的其他参数,如class、list-type、file-list等。这些参数可以根据自己的需求进行设置。 4. 在el-upload组件,你可以监听onChange事件,以便在图片上传完成后执行相应的操作。比如,你可以在该事件获取返回的图片路径,并将其放入el-upload组件进行显示。 5. 当图片上传成功后,你可以在el-upload组件使用on-success事件来回显上传的图片。你需要将回显地址配置为你在七牛云上配置的回显地址,具体地址可以参考七牛云的官方文档。 6. 最后,你可以根据需要配置其他的el-upload组件参数,如before-upload、on-remove等。 总结起来,通过el-upload组件和七牛云的配合,你可以实现在前端上传图片到七牛云,并在上传成功后进行回显操作。详情可以参考提供的引用内容的代码和注意点。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [vueel-upload上传图片到七牛的示例代码](https://download.csdn.net/download/weixin_38675465/13977470)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [elementUI el-upload组件直接上传七牛云(亲测可用)](https://blog.csdn.net/DLGDark/article/details/126763197)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [el-upload上传文件七牛云](https://blog.csdn.net/qq_42157868/article/details/107286616)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值