图片上传阿里云

随着手机摄像头像素变大,很多图片都超过5兆,所以阿里云默认的nginx最大上传5兆,不够使用了。所以需要重新设置nginx上传图片最大值。修改文件nginx.conf(我们的是/usr/local/nginx/conf/nginx.conf 不同的系统版本文件位置不同)。

http {这里增加一行代码:client_max_body_size 50M; # 添加这一行具体多大自己控制。若要上传视频,需要设置的更大。我见到一个网站一个视频都要800多兆。

配置:

复制代码
const OSSURL = 'https://test.oss-cn-hangzhou.aliyuncs.com';
const OSS = require('ali-oss');
const ossHZ = new OSS({
    region: 'oss-cn-hangzhou',
    accessKeyId: FspConstant.ACCESS_KEY_ID,
    accessKeySecret: FspConstant.ACCESS_KEY_SECRET,
    bucket: 'bucket节点名',
});

核心上传代码很简单:

复制代码
await ossHZ.putStream(filename, readStream);

上传具体代码:

复制代码
ImageTool.uploadImage = async function(filename, fileExt, readStream, convertedPath, originalPath) {
    try {
        await ossHZ.putStream(filename, readStream);
        // 删除临时转换文件
        if(convertedPath && fs.existsSync(convertedPath)){
            fs.unlinkSync(convertedPath);
        }
        if(fs.existsSync(originalPath)){
            fs.unlinkSync(originalPath);
        }
        return {
            code: 200,
            data: {
                data: {
                    url: OSSURL + filename,
                    // src: urlPath,
                    originalFormat: fileExt
                }
            }
        };
    } catch (error) {
        // 删除临时转换文件
        if(convertedPath && fs.existsSync(convertedPath)){
            fs.unlinkSync(convertedPath);
        }
        if(originalPath && fs.existsSync(originalPath)){
            fs.unlinkSync(originalPath);
        }
        console.error('上传失败:', error);
        throw msgCode[39522]('上传');
    }
};

调用代码:

复制代码
    // 获取文件扩展名
    const fileExt = path.extname(ctx.req.file.originalname).toLowerCase();
    let convertedPath = null;    
            // 支持的格式,直接上传原文件
        const readStream = fs.createReadStream(ctx.req.file.path);
        let arr = ctx.req.file.path.split('/');
        let filename = '/img/' + arr[arr.length - 1];
        return ImageTool.uploadImage(filename, fileExt, readStream, null, ctx.req.file.path);
相关推荐
风止何安啊11 小时前
网课倍速痛点解决:一套前端代码实现自由控速播放器
前端·javascript·node.js
糖拌西瓜皮12 小时前
Node.js核心模块实战:文件、路径、HTTP与流处理
javascript·node.js
糖拌西瓜皮12 小时前
Node.js工程化实践:包管理、TypeScript配置与代码质量
typescript·node.js
糖拌西瓜皮12 小时前
NestJS入门指南:Java开发者的Spring Boot体验
javascript·node.js
糖拌西瓜皮12 小时前
Express框架快速上手:中间件、路由与错误处理
javascript·node.js
半个落月15 小时前
从 Tokenization 到 Embedding:用 Node.js 搞懂大模型为什么先“分词”再“向量化”
人工智能·node.js
叁两1 天前
前端转型AI Agent该如何学习?(前置篇)
前端·人工智能·node.js
糖拌西瓜皮2 天前
TypeScript 进阶:泛型、条件类型、类型守卫与装饰器
javascript·node.js
米丘5 天前
vite8 vite preview 命令做了什么?
node.js·vite
blanks20205 天前
生成 公钥私钥 笔记
node.js