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测试上传图片

上传成功,打印回显

腾讯云显示

相关推荐
鱼是一只鱼啊3 小时前
ASP.NET Core 集成腾讯云 COS 实现文件上传下载完整指南
云计算·asp.net·腾讯云·文件上传·cos
testpassportcn4 小时前
AWS DVA-C02 考試完整介紹 |AWS Certified Developer Associate 最新考試內容
云计算·aws
sun03224 小时前
【AWS】【secret】Java从AWS Secrets Manager获取指定secret中特定key的值
云计算·aws
予枫的编程笔记4 小时前
【Docker基础篇】从0到1写Dockerfile:FROM/COPY/CMD/ENTRYPOINT指令详解+Hello World实战
人工智能·docker·云计算·dockerfile·容器技术·docker入门·docker实战
henry1010105 小时前
Debian/Ubuntu EC2实例上一键部署WireGuard
ubuntu·云计算·debian·aws
人间打气筒(Ada)5 小时前
k8s:认证、授权、准入控制
云原生·容器·kubernetes·云计算·k8s认证·k8s授权·k8s准入控制
主机哥哥14 小时前
还不会部署OpenClaw?阿里云推出五种OpenClaw快速部署方案
阿里云·云计算
Re.不晚17 小时前
可视化大数据——淘宝母婴购物数据【含详细代码】
大数据·阿里云·云计算
zhougl99621 小时前
云计算超详细介绍
云计算