微信小程序使用七牛云对象存储保存图片和文件

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(filePath, fileName, success, fail, options) {

if (null == filePath) {

console.error(‘qiniu uploader need filePath to upload’);

return;

}

if (options) {

init(options);

}

if (config.qiniuUploadToken) {

doUpload(filePath, fileName,success, fail, options);

} else if (config.qiniuUploadTokenURL) {

getQiniuToken(function () {

doUpload(filePath, fileName, 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, fileName, success, fail, options) {

var url = uploadURLFromRegionCode(config.qiniuRegion);

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;

}

})();

3、创建一个config.js文件,用于保存七牛云配置信息,代码如下:

module.exports = {

/*

  • 由于签名计算放在前端会暴露 AccessKey 和 SecretKey

  • 我们把签名计算过程放在后端实现,前端通过 ajax 向后端获取签名结果,

  • 正式部署时请在后端加一层自己网站本身的权限检验。

*/

uptokenURL: ‘https://后端域名/getUptoken.html’,//后端获取签名

domain: ‘http://xxx.bkt.clouddn.com/’,//空间域名(融合CDN域名)

Region: ‘SCN’, //所属地域(华南)

};

七牛云的存储对象的地区对应表

存储区域区域代码客户端上传地址
华东ECN

https://up.qbox.me

华北NCN

https://up-z1.qbox.me

华南SCN

https://up-z2.qbox.me

北美NA

https://up-na0.qbox.me

五、index.wxml代码:

六、index.wxss代码:

.container{

padding: 20rpx;

}

.images-item{

width: -webkit-calc(50% - 10px);

width: -moz-calc(50% - 10px);

width: calc(50% - 10px);

float: left;

border-radius: 7px;

margin: 5px;

background: #fff;

}

.img-box {

display: flex;

justify-content: center;

}

七、index.js代码:

//获取应用实例

const app = getApp()

const qiniuUploader = require(‘./libs/qiniuUploader’)

const config = require(‘./libs/config’);

// 初始化七牛相关参数

function initQiniu() {

var options = {

region: config.Region, // 所属地址

uptokenURL: config.uptokenURL, //后端获取token

domain: config.domain, //空间域名(融合CDN域名)

};

qiniuUploader.init(options);

}

Page({

/**

  • 页面的初始数据

*/

data: {

fileList: [],

date: ‘’

},

/**

  • 生命周期函数–监听页面加载

*/

onLoad: function(options) {

//获取时间,作为图片文件夹名,如20191207

this.setData({

date: app.globalData.util.dateFormat(new Date(), “YMD”)

});

//清除缓存

//wx.removeStorageSync(‘fileList’);

//获取缓存中的地址

this.updateData();

},

afterRead(event) {

var that = this;

// 当设置 mutiple 为 true 时, file 为数组格式,否则为对象格式

/* 单个上传 */

/*

const { file } = event.detail;

var filePath = file.path;

var filename = new Date().getTime() + ‘.’+ filePath.substr(filePath.lastIndexOf(‘.’) + 1);

//文件相对路径名

var relativePath = ‘upload/’ + that.data.date + ‘/’ + filename;

//上传图片到对象存储中

//添加到预览中

var img = {

id: i,

url: app.globalData.cosUrl + relativePath,

name: filename

}

//读取缓存

let list = wx.getStorageSync(‘fileList’);

if (list) {

list.push(img);

} else {

list = [img];

}

//存入缓存

wx.setStorageSync(‘fileList’, list);

//延迟更新数据

setTimeout(function () {

that.updateData();

}, 5000);

*/

/* 批量上传 */

var files = event.detail.file; //数组

for (var i = 0; i < files.length; i++) {

var filePath = files[i].path;

var name = new Date().getTime() + ‘.’ + filePath.substr(filePath.lastIndexOf(‘.’) + 1);

//文件名(文件名里添加路径,加以区分)

var fileName = ‘upload/’ + that.data.date + ‘/’ + name;

wx.showLoading({

title: ‘上传中…’,

})

//上传图片到对象存储中

initQiniu();

qiniuUploader.upload(filePath, fileName, (res) => {

var key = res.key;

var imageURL = res.imageURL;

//添加到预览中

var img = {

id: i,

url: imageURL,

key: key

}

//读取缓存

let list = wx.getStorageSync(‘fileList’);

if (list) {

list.push(img);

} else {

list = [img];

}

//存入缓存

wx.setStorageSync(‘fileList’, list);

//更新数据

that.updateData();

wx.hideLoading();

wx.showToast({

title: ‘上传成功’,

icon: ‘success’,

duration: 3000

});

}, (error) => {

wx.hideLoading();

wx.showModal({

title: ‘Error’,

content: ‘请求失败,状态码:’ + JSON.stringify(error),

showCancel: false

});

});

}

},

delFile(event) {

var that = this;

wx.showModal({

title: ‘提示’,

content: ‘确定要删除这张图片吗?’,

success(res) {

if (res.confirm) {

var index = event.detail.index;

//读取缓存

let list = wx.getStorageSync(‘fileList’);

var filename = list[index].key;

//更新fileList中的数据

for (let i = 0; i < list.length; i++) {

//如果item是选中的话,就删除它。

if (filename == list[i].key) {

// 删除对应的索引

list.splice(i, 1);

break;

}

}

//更新缓存

wx.setStorageSync(‘fileList’, list);

//更新数据

that.updateData();

//删除对象存储中的图片

that.delQiniuFile(filename);

} else if (res.cancel) {

//console.log(‘用户点击取消’)

}

}

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

总结

最后对于程序员来说,要学习的知识内容、技术有太多太多,要想不被环境淘汰就只有不断提升自己,从来都是我们去适应环境,而不是环境来适应我们!

这里附上上述的技术体系图相关的几十套腾讯、头条、阿里、美团等公司20年的面试题,把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分。

相信它会给大家带来很多收获:

当程序员容易,当一个优秀的程序员是需要不断学习的,从初级程序员到高级程序员,从初级架构师到资深架构师,或者走向管理,从技术经理到技术总监,每个阶段都需要掌握不同的能力。早早确定自己的职业方向,才能在工作和能力提升中甩开同龄人。

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

解视频,并且会持续更新!**

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

总结

最后对于程序员来说,要学习的知识内容、技术有太多太多,要想不被环境淘汰就只有不断提升自己,从来都是我们去适应环境,而不是环境来适应我们!

这里附上上述的技术体系图相关的几十套腾讯、头条、阿里、美团等公司20年的面试题,把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分。

相信它会给大家带来很多收获:
[外链图片转存中…(img-bvwOXgLY-1713607985674)]

[外链图片转存中…(img-vSFHEvqr-1713607985676)]

当程序员容易,当一个优秀的程序员是需要不断学习的,从初级程序员到高级程序员,从初级架构师到资深架构师,或者走向管理,从技术经理到技术总监,每个阶段都需要掌握不同的能力。早早确定自己的职业方向,才能在工作和能力提升中甩开同龄人。

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
微信小程序调用uploadFile接口可以向七牛云存储上传图片。首先,我们需要获取到七牛云的上传凭证(token),然后使用微信小程序的uploadFile接口将图片上传至七牛云。 具体步骤如下: 1. 在小程序后台或自己的服务器上请求七牛云的上传凭证。可以使用七牛云的SDK或者API进行请求。 2. 在小程序中调用wx.uploadFile接口,设置url为七牛云的上传接口,formData中设置为 {key: '上传的文件七牛云的保存路径', token: '七牛云的上传凭证'}。 3. 小程序通过wx.chooseImage接口选择要上传的图片,并将选择的图片临时路径传给wx.uploadFile的filePath参数。 4. 小程序调用wx.uploadFile接口进行图片上传,上传成功后会返回七牛云图片的保存路径。 需要注意的是,在上传图片之前,我们可能需要对图片进行压缩、裁剪或者添加水印等处理,以满足七牛云保存图片的要求。 同时,七牛云对于图片上传还提供了许多其他的功能,如图片样式处理、图片持久化等,我们可以根据需要进行设置。 使用七牛云存储可以方便地进行图片上传与管理,并且具有高可靠性和高性能。为了保证数据的安全性,我们还可以设置七牛云的访问控制,限制只有授权用户才能访问上传的图片。 总之,通过微信小程序调用uploadFile接口向七牛云存储上传图片,可以实现图片的高效、安全地存储和管理。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值