cos文件存储

cos核心

腾讯云对象存储(COS)的使用,核心是创建存储桶 → 上传 / 下载 / 管理文件 → 配置权限与访问,支持控制台、工具、SDK/API 三种方式。下面是完整入门流程与常用操作指南。

注册使用

  1. 注册并登录 腾讯云账号https://console.cloud.tencent.com/cos,完成实名认证。
  2. 进入 对象存储 COS 控制台 。(同类于oss阿里云的对象存储)创建存储库和文件荚
  3. 在 访问管理 获取 SecretId / SecretKey,用于 API/SDK/ 工具调用。

上传图片

可通过vue直传,但会暴露信息

可通过node 后端上传的,安装multer @koa/multer依赖包,可上传图片,文件,视频,两者是相互依赖

  1. 包装依赖
javascript 复制代码
npm i -S @koa/multer multer //静态资源上传:img,video,
npm i -S cos-nodejs-sdk-v5  //腾讯云cos
  1. 创建cos的文件夹,创建cos.js文件
  2. 上传文件 使用cos的sdk上传
    cos.js文件
javascript 复制代码
const multer=require('@koa/multer')
const COS=require('cos-nodejs-sdk-v5')
var cos=new COS({
	SecretId:'改成自己的',
	SecretKey:'改成自己的',
	Protocol:'https:'
})
// 存储桶名称
let Bucket='改成自己的'
// 地域
let Region='ap-beijing'
// 文件夹名称
let Foldername='改成自己的/'
// 定义上传函数
let cosfun=function(filename,path){
	return new Promise((resolve,reject)=>{
		cos.uploadFile({
			Bucket,
			Region,
			Key:Foldername+filename,
			FilePath:path
		})
		.then(res=>{
			// console.log('success=',res)
			resolve(res.Location)
		})
		.catch(err=>{
			// console.log('err=',err)
			reject(err)
		})
	})
}
// 配置上传文件
// diskStorage磁盘存储引擎方法
const storage = multer.diskStorage({
	// 1.所在的目录
  destination:(req, file, cb)=>{
    cb(null, 'upload/image')
  },
	// 2.更改文件名
	filename: function (req, file, cb) {
    const uniqueSuffix = Date.now()
		const ori_name=file.originalname.split('.')
    cb(null, `wh-${uniqueSuffix}.${ori_name[ori_name.length-1]}`)
  }
})

const upload = multer({ storage: storage })

module.exports={upload,cosfun}

4.上传图片的接口

router/merchant-infor/infor.js

javascript 复制代码
const KoaRouter = require('koa-router');
const router = new KoaRouter();
// 统一给前端返回的body响应
const result=require('../../config/result.js')
// 操作数据库的接口
const {getToken,addUrl,searchUrl} = require('../../config/databaseapi.js')
// 校验
const {regCheck}=require('../../config/checking.js')
// 验证token合法性
const {Auth}=require('../../token/auth.js')
// 图片上传
const {upload,cosfun}=require('../../cos/cos.js')
// 图片上传接口upload.single('file')做为中间件
router.post('/uploadres',upload.single('file'),async ctx=>{
	// 接收前端上传的静态资源文件
	console.log('reback=',ctx.file)
	try {
		const res=await cosfun(ctx.file.filename,ctx.file.path)
		new result(ctx,'SUCCESS',200,'https://'+res).answer()
	} catch (error) {
		//TODO handle the exception
		new result(ctx,'上传失败,服务器发生错误',500).answer()
	}
	
})
// 商家信息上传
router.post('/uploadshop',new Auth().m, async ctx=>{
	const {id,name,address,logo}=ctx.request.body
	console.log(name)
})
module.exports=router.routes() 

5.在app.js中全局引入

javascript 复制代码
// 商家设置
const uploadres=require('./router/merchant-infor/infor.js')
// 配置路由登录
router.use('/api',uploadres)

6.利用Apipost测试上传图片

上传成功,打印回显

腾讯云显示

相关推荐
Ynchen. ~1 小时前
告别 OSS 强制下载!阿里云 OSS 绑定自定义域名实现文件在线预览全记录
阿里云·云计算·oss
Huy-C4 小时前
云计算案例排错(云上2)
云计算
bug总结6 小时前
小程序云函数 vs 传统前后端分离(阿里云)原理解析
阿里云·小程序·云计算
gaize121317 小时前
腾讯小龙虾使用指南
云计算·腾讯云·小龙虾
Echo-J1 天前
KVM-VMI项目编译安装全过程,包含所遇问题及解决措施
安全·网络安全·云计算·系统安全
新缸中之脑1 天前
AntSpace:Anthropic的秘密PaaS
云原生·云计算·paas
Yokon_D1 天前
腾讯云+Astrbot个人AI部署,接入QQ机器人
云计算·腾讯云
TG_yunshuguoji1 天前
腾讯云代理商:快速解锁飞书机器人文档操控术 免审核权限配置指南
云计算·飞书·腾讯云
xingyuzhisuan1 天前
租用GPU服务器后,快速搭建Stable Diffusion WebUI并实现公网访问全指南
服务器·人工智能·云计算·gpu算力
OpenAnolis小助手1 天前
玄铁 C950 发布!龙蜥社区加速 RISC-V 云计算落地
云计算·操作系统·龙蜥社区·risc-v