uniapp 上传图片到华为云obs

本文档记录了使用uniapp通过后端获取签名的方式直接上传图片到华为云OBS的过程,避免因公司带宽限制导致的上传速度慢问题。在尝试前端直接获取签名失败后,选择将文件名和类型发送给后端,由后端生成必要的签名信息,包括key、AccessKeyId、Policy等,然后前端使用这些信息通过uniapp的uploadFile接口上传图片。最后,图片的地址为设置的baseURL加上从后端获取的key。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

记录一下用uniapp上传图片到华为云obs,之前是先把文件传到我们自己的服务器,然后后端的同事再上传到obs,但是我们公司的带宽太低了,传的太太太太慢了,于是考虑直接让用户上传到obs,不经过我们自己的服务器,这样能稍微快一点。
那么现在问题来了,obs的文档,前端(小程序)获取签名直传,都需要引入BrowserJS,但是不知道为什么,我用uniapp死活引入不成功,不是文件报错,就是无法创建ObsClient对象,一整个无语住了,生成工单问华为云工程师,得到的回复也只是uniapp还没适配,简直了。。。。。。而且前端获取签名ak这些还是比较有风险的在这里插入图片描述
所以最后采用后端生成签名,前端上传的方法。
首先选择、压缩好图片(根据需求选择压缩)之后,把文件名和文件类型传给后端,后端同事需要根据这两个参数,获取签名,生成’key’、‘AccessKeyId’、‘Policy’、‘x-obs-acl’、‘content-type’、‘Signature’;
之后前端根据这几个参数,访问自己的obs上传地址,就可以上传图片啦。

// 从相册选择图
					uni.chooseImage({
   
						count: count,
						sizeType: ['compressed'],
						success: function(res) {
   
							uni.showLoading({
   
							    title: '上传中'
							});
							that.picList.push(res.tempFiles[0])
							var num=res.tempFilePaths[0].split('/').length
							console.log(res.tempFilePaths[0].
要实现vue3分段上传视频到华为云obs,你可以按照以下步骤操作: 1. 在vue3项目中引入obs-sdk-js库,用于连接华为云obs服务。 2. 创建一个上传对象,设置上传参数,如上传的文件名、文件大小等。 3. 将上传文件分段,每个分段大小为1MB-5MB,使用obs-sdk-js库的putObject接口上传每个分段。 4. 当所有分段上传完成后,使用obs-sdk-js库的completeMultipartUpload接口合并所有分段。 以下是一个简单的代码示例: ``` import OBS from 'obs-sdk-js' const obs = new OBS({ access_key_id: 'your_access_key_id', secret_access_key: 'your_secret_access_key', server: 'obs.cn-north-1.myhuaweicloud.com' }) async function uploadVideo(file) { const objectName = file.name const fileSize = file.size const partSize = 5 * 1024 * 1024 // 5MB const parts = Math.ceil(fileSize / partSize) // Step 1: Initiate multipart upload const { uploadId } = await obs.initiateMultipartUpload({ Bucket: 'your_bucket_name', Key: objectName }) // Step 2: Upload all parts const partPromises = [] for (let i = 0; i < parts; i++) { const start = i * partSize const end = Math.min(start + partSize, fileSize) const partNumber = i + 1 const partData = file.slice(start, end) const partPromise = obs.uploadPart({ Bucket: 'your_bucket_name', Key: objectName, PartNumber: partNumber, UploadId: uploadId, Body: partData }) partPromises.push(partPromise) } await Promise.all(partPromises) // Step 3: Complete multipart upload await obs.completeMultipartUpload({ Bucket: 'your_bucket_name', Key: objectName, UploadId: uploadId }) console.log('Video uploaded successfully!') } ``` 在上面的代码中,我们首先初始化了一个OBS对象,然后在uploadVideo函数中,我们使用initiateMultipartUpload接口创建一个分段上传的任务,并获取到任务的uploadId。然后,我们将上传文件分成多个大小相同的分段,使用uploadPart接口上传每个分段。最后,当所有分段上传完成后,我们使用completeMultipartUpload接口合并所有分段。 注意,上面的代码示例仅供参考,具体实现可能需要根据你的项目需求进行调整。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值