如何利用unicloud阿里云云函数实现文件包括图片或文件上传,unicloud云函数写法一览

这里以一个单文件上传为例子,多图多文件同理,循环单图处理逻辑即可。

背景

前端vue上传图片文件(base64格式)到服务器,并获取返回的服务器资源存储路径

传入参数

{

"queryStringParameters":{

"file":"单图文件临时src的base64编码内容"

}

}

**注意:**请求体问题!

在云函数中,请求体(body)有时会出现在`queryStringParameters`中,而不是在`body`中,可能是因为请求的 Content-Type 类型不被云函数所支持,或者在请求的时候没有正确地设置请求头。

在云函数中,一般情况下,如果请求是一个 HTTP POST 请求且 Content-Type 是 application/json,那么请求体应该出现在`body`中。但如果请求的 Content-Type 不是 application/json,云函数可能会将请求体解析为字符串并放在`queryStringParameters`中,而不是解析为 JSON 对象并放在`body`中。

完整js代码

javascript 复制代码
'use strict';
exports.main = async (event, context) => {
	   console.log(event)
	   const db = uniCloud.database();
	    try {
	               const file = event.queryStringParameters.file; // 从前端传来的图片文件对象
	
	           // 上传图片到云存储
	           const res = await uniCloud.uploadFile({
	               cloudPath: `images/${Date.now()}_${Math.floor(Math.random() * 10000)}.png`, // 上传到云存储的路径,可以自定义
	               fileContent: Buffer.from(file.split(',')[1], 'base64') // 将 base64 格式的图片内容转换为 Buffer 对象
	           });
			   
	           // 将图片地址返回给前端
	           return {
				    event:event,
	               fileUrl: res.fileID // 返回上传成功后的文件地址
	           };
	       } catch (error) {
	           return {
				   event:event,
	               code: 500,
	               message: '上传失败:' + error.message
	           };
	       }
};

**注意:**uniCloud.uploadFile

uniCloud.uploadFile 是 uniCloud 提供的用于将文件上传到云存储的一个方法。uniCloud 是 DCloud 提供的云开发平台,主要面向前端开发者。通过 uniCloud,开发者可以在云端处理数据库、文件存储等操作,而不需要自己搭建和维护服务器。

如果这篇文章对您有所帮助的话,点个小赞赞吧🌹🌹

相关推荐
万物得其道者成7 小时前
前端大整数精度丢失:一次踩坑后的实战解决方案(`json-bigint`)
前端·json
鹏北海8 小时前
移动端 H5 响应式字体适配方案完全指南
前端
姜太公钓鲸2339 小时前
ROM就是程序存储器,实际的存储介质是Flash闪存。上述描述中的程序存储器是什么意思?
开发语言·javascript·ecmascript
柳杉10 小时前
使用AI从零打造炫酷医疗数据可视化大屏,源码免费拿!
前端·javascript·数据可视化
凌云拓界10 小时前
前端开发的“平衡木”:在取舍之间找到最优解
前端·性能优化·架构·前端框架·代码规范·设计规范
iOS阿玮10 小时前
百款出海社交 App 一夜下架!2026,匿名社交的生死劫怎么破?
uni-app·app·apple
zhengfei61110 小时前
【XSS payload 】一个经典的XSS payload
前端·xss
简单Janeee10 小时前
[Vue 3 从零到上线]-第四篇:组件化思维——把网页像积木一样拆解
javascript·vue.js·ecmascript
全栈老石11 小时前
手写一个无限画布 #1:坐标系的谎言
前端·canvas
XW010599912 小时前
4-11判断素数
前端·python·算法·素数