当前位置: 首页 > wzjs >正文

做房产应看的网站谷歌浏览器手机版官网下载

做房产应看的网站,谷歌浏览器手机版官网下载,网页设计模板图片家乡,格力网站建设首页说明:在使用cool-admin这个低代码平台时,发现官方的cos上传插件有问题,总是报错 substring,故自己找解决方案,修改本地的upload方法改为云端上传。 解决方案: 安装腾讯云cos的nodeJS SDK pnpm i cos-node…

说明:在使用cool-admin这个低代码平台时,发现官方的cos上传插件有问题,总是报错 substring,故自己找解决方案,修改本地的upload方法改为云端上传。


解决方案:

  1. 安装腾讯云cos的nodeJS SDK
pnpm i cos-nodejs-sdk-v5
  1. admin-midway/src/modules/plugin/hooks/upload 目录下新建工具文件upload_cos.ts 内容如下:
const COS: any = require('cos-nodejs-sdk-v5');
import fs = require('fs');// 定义配置接口
interface CosConfig {Bucket?: string;Region?: string;Prefix?: string;
}// 定义上传参数接口
interface PutObjectParam {key: string;buffer: fs.ReadStream | Buffer;
}class CosUtil {private cos;private Bucket: string;private Region: string;private Prefix: string;// 构造函数,初始化配置constructor(config?: CosConfig) {this.Bucket = config?.Bucket || 'mybucket-xxxxxx'; // 存储桶名称this.Region = config?.Region || 'ap-guangzhou'; // 存储桶区域this.Prefix = config?.Prefix || ''; // 路径前缀// 初始化 COS 实例this.cos = new COS({SecretId: 'xxxxxx', // 密钥idSecretKey: 'xxxxxx', // 密钥key});}// 上传文件方法public putObject(param: PutObjectParam): Promise<any> {return new Promise((resolve, reject) => {this.cos.putObject({Bucket: this.Bucket, // 必须Region: this.Region, // 必须Key: param.key, // 必须Body: param.buffer, // 必须},(err: Error, data: any) => {if (err) {reject(err);return;}resolve(data);});});}// 提取图片链接中的图片名称public getName(imageUrl: string): string {// 解析 URLconst parsedUrl = new URL(imageUrl);// 获取路径部分const pathname = parsedUrl.pathname;// 提取文件名const imageName = pathname.split('/').pop() || '';return imageName;}
}export default CosUtil;
  1. 修改上述目录下的index.ts文件:
// ... existing code ...
import CosUtil from './upload_cos';
// ... existing code ...// 修改之前的上传文件代码/*** 上传文件* @param ctx* @param key 文件路径*/async upload(ctx: any) {const { domain } = this.pluginInfo.config;const uploadUtil = new CosUtil();try {const { key } = ctx.fields;if (key &&(key.includes('..') ||key.includes('./') ||key.includes('\\') ||key.includes('//'))) {throw new CoolCommException('非法的key值');}if (_.isEmpty(ctx.files)) {throw new CoolCommException('上传文件为空');}const basePath = pUploadPath();const file = ctx.files[0];const extension = file.filename.split('.').pop();const name =moment().format('YYYYMMDD') + '/' + (key || `${uuid()}.${extension}`);const target = path.join(basePath, name);const dirPath = path.join(basePath, moment().format('YYYYMMDD'));if (!fs.existsSync(dirPath)) {fs.mkdirSync(dirPath);}const data = fs.readFileSync(file.data);fs.writeFileSync(target, data);// 主要变动在这里,key:上传图片的名称(带后缀),buffer:图片的bufferconst cosResult = await uploadUtil.putObject({key: name,buffer: data,});return `https://${cosResult.Location}`;} catch (err) {console.error(err);throw new CoolCommException('上传失败' + err.message);}}

通过以上修改,原来的upload方法及前端组建调用上传方法会得到返回的腾讯云cos存储桶中图片的访问地址,add接口也会把该地址存储到数据库中。

此时admin-node/src/modules/plugin/config.tsdomain参数将会失效

// 基础插件配置hooks: {// 文件上传upload: {// 地址前缀domain: ``,},},

由于是非正式项目,存储桶访问权限设置的是公有读写,不需要做身份验证。如有需要可查看官方文档:设置存储桶访问权限

http://www.dtcms.com/wzjs/50596.html

相关文章:

  • 邯郸哪儿做网站便宜营销页面
  • 专业仿站网站建设网站检测中心
  • 网络广告推广方法seo学习网站
  • 查看网站开发商什么是百度竞价
  • 车佣做汽车网站怎么样广东东莞疫情最新消息今天又封了
  • 国安中建建设集团网站游戏网站交换友情链接
  • 企业网站找私人做什安卓嗅探app视频真实地址
  • 域名注册商网站宁波seo如何做推广平台
  • 地方门户网站运营百度排名查询
  • 怎样用dw做 网站首页英文网站推广
  • 江都建设局网站李局北京seo顾问推推蛙
  • 做网站卖产品在线h5免费制作网站
  • 重庆互联网公司排行榜简述优化搜索引擎的方法
  • 淘宝客网站程序购米百度爱采购优化排名软件
  • 经典企业网站天津seo标准
  • 国内建站 wordpress定向推广
  • 石家庄网站建设接单怎么推广app让人去下载
  • 对日软件开发流程seo教学网seo
  • 品牌网站建设服务商看网站时的关键词
  • 省级门户网站建设洛阳市网站建设
  • 生鲜网站建设规划书范文广州的百度推广公司
  • 如何自己做网站 开直播百度seo霸屏软件
  • 网站动画广告条怎么做的企业培训课程有哪些内容
  • 信阳企业网站建设深圳百度推广联系方式
  • 南通网站建设要多少钱免费发布信息网平台
  • 购物商城网站建设公司百度关键词屏蔽
  • 青岛网站设计建立公司指数运算公式大全
  • 国内人做韩国网站一般都卖什么手续代写文章兼职
  • 哪些网站的做的好看的排名轻松seo 网站
  • 武汉网站建设报价明细表google官网