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

上传成功,打印回显

腾讯云显示

相关推荐
北极糊的狐1 天前
4.1阿里云 OSS 的跨域访问 CORS 限制本地直接打开 HTML 无法正常播放 OSS 音频、视频
阿里云·云计算
观测云1 天前
观测云日志转发至 AWS S3 最佳实践
云计算·aws·观测云
TG_yunshuguoji1 天前
阿里云代理商:阿里云数字短信全面开放!触达新方案
阿里云·云计算·云服务器
牛奶咖啡131 天前
Docker容器实践——docker部署应用系统
docker·云计算·portainer·docker容器的使用流程·docker虚拟化云桌面·nginx可视化反向代理工具·构建服务器监控探针
PinTrust SSL证书1 天前
Geotrust企业型OV通配符SSL
网络协议·网络安全·小程序·https·云计算·ssl
翼龙云_cloud1 天前
亚马逊云代理商:CloudWatch vs CloudTrail 3 大核心区别与联动实战指南
云计算·aws·云服务器
johnny2331 天前
腾讯云COS分片上传完整实现
腾讯云
小白考证进阶中1 天前
阿里云ACA部分考试成绩分享(2月/3月/4月)
运维·阿里云·云计算·阿里云认证·阿里云aca认证·阿里云aca·阿里云aca大数据认证
翼龙云_cloud2 天前
亚马逊云代理商:CloudWatch Agent 全解析 5 步实现服务器监控
运维·服务器·云计算·aws·云服务器
TG_yunshuguoji2 天前
阿里云代理商:2026年云端与本地双轨部署OpenClaw 方案
服务器·阿里云·云计算·openclaw