一段代码,koa上传文件,上传文件到腾讯云

上传图片文件对于内容管理的项目来说是一段最基本的代码,对于使用Nodejs开发来说,这段代码在配置上来说就相对的简单了不少,先不管性能上与其他框架来说有什么差距,起码对于小的项目来说,Nodejs作为web服务是一个不错的选择。 

前端:form表单上传图片文件,KindEditor配置上传

服务端:Koa、koa-body 接收文件

上传到服务器目录 

这里使用koa-body对文件上传进行配置,配置如下:

var koaBody = require('koa-body')
app.use(koaBody({
    multipart: true,
    formidable: {
        maxFileSize: 2000 * 1024 * 1024    // 设置上传文件大小最大限制,默认2M
    }
}))

配置好koa-body之后,我们就可以在路由方法中进行上传文件的操作,读取上传文件并保存到我们需要保存的路径当中 

let file = ctx.request.files.file  // file就是前端传过来的文件名称
        let uppath = file.path  // 上传服务器的缓存路径
        
        // 创建可读流
        let reader = fs.createReadStream(uppath);

        //创建文件名
        let newFilename = new Date().getTime()+'.'+file.name.split('.')[1];
        
        // 文件保存路径
        let filePath = path.join(__dirname, 'public/upload/') + `${newFilename}`;
        
        // 创建可写流
        let upStream = fs.createWriteStream(filePath);
        
        // 可读流通过管道写入可写流
        reader.pipe(upStream);

        ctx.body = {
            error:0,
            url:`/upload/${file.name}`
        }

下面是前端页面,包括form表单上传文件,和KindEditor配置上传文件。

<!DOCTYPE html>
<html>
<head>
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1.0, user-scalable=0">
    <title>上传文件页面</title>
</head>
<body>

<form action="/upload" method="post"
      enctype="multipart/form-data">
    <!-- name是在服务端接收文件的名称 -->
    <input type="file" name="file"  />
    <input type="file" name="file2"   />
    <input type="submit" name="submit" value="Submit" />
</form>


<textarea id="editor_id" name="content" style="width:700px;height:300px;">
</textarea>
</body>
<script src="js/kindeditor/kindeditor-all-min.js"></script>
<script>
    KindEditor.ready(function (K) {
        window.editor = K.create('#editor_id', {
            uploadJson: '/upload',
            filePostName: 'file',  // 服务端接收文件的名称
            allowFileManager: true,
            allowFlashUpload: false,
        });
    });
</script>
</html>

 

上传到腾讯云存储

首先需要安装腾讯云提供的sdk

npm i cos-nodejs-sdk-v5

 安装好腾讯云提供的上传文件的sdk之后,就可以对文件进行上传,下面就是使用cos上传文件的一个简单方法。

var COS = require('cos-nodejs-sdk-v5');

const cosUtil = {
    cos: null,

    Bucket: 'img-2342423424',  // 存储桶名称
    Region: 'ap-shanghai',   // 存储桶区域
    Prefix: '',   // 路径前缀

    // 初始化配置
    init(config) {
        if(config){
            this.Bucket = config.Bucket || this.Bucket;
            this.Region = config.Region || this.Region;
            this.Prefix = config.Prefix || this.Prefix;
        }

        // 下面两个密钥,需要在腾讯云获取
        this.cos = new COS({
            SecretId: '***************',   // 密钥id
            SecretKey: '*******************'  // 密钥key
        });
    },

    putObject(param, callback) {
        return new Promise((resolve, reject) => {
            this.cos.putObject({
                Bucket: this.Bucket, /* 必须 */
                Region: this.Region,    /* 必须 */
                Key: param.key,              /* 必须 */
                Body: param.buffer, /* 必须 */
            }, function (err, data) {
                if (err) {
                    reject(err);
                    return;
                }
                resolve(data)
            });
        })
    }
}


module.exports = cosUtil

我们可以对上面的koa路由方法进行简单的修改,就可以将我们上传的文件再上传到腾讯云存储

// 首先引用上传的工具方法
const cosUtil = require('./cosUtil')


// 下面就是对koa路由方法进行的修改

let file = ctx.request.files.file
let uppath = file.path
// 创建可读流
let reader = fs.createReadStream(uppath);

let newFilename = new Date().getTime() + '.' + file.name.split('.')[1];

cosUtil.init()
        
let cosResult = await cosUtil.putObject({
    key: `upload/${newFilename}`,
    buffer: reader,
})

ctx.body = {
    error: 0,
    url: `https://${cosResult.Location}`
}

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是基于 TypeScript、Koakoa-body 实现的文件上传代码示例: ```typescript import Koa from 'koa'; import koaBody from 'koa-body'; const app = new Koa(); // 设置上传文件的保存路径 const uploadDir = './uploads'; // koa-body 中间件配置 const koaBodyConfig = { multipart: true, // 启用文件上传 formidable: { uploadDir, // 文件保存路径 keepExtensions: true, // 保留文件扩展名 }, }; // 注册 koa-body 中间件 app.use(koaBody(koaBodyConfig)); app.use(async (ctx) => { // 判断是否为文件上传请求 if (ctx.request.files && ctx.request.files.file) { const { file } = ctx.request.files; // 输出上传文件信息 console.log(`Received file: ${file.name}`); console.log(`File size: ${file.size}`); console.log(`File path: ${file.path}`); ctx.body = 'File uploaded successfully.'; } else { ctx.body = 'Hello World!'; } }); app.listen(3000, () => { console.log('Server is running on http://localhost:3000'); }); ``` 以上代码中,我们通过 `koa-body` 中间件启用了文件上传功能,并且设置了上传文件的保存路径。当接收到文件上传请求时,我们可以通过 `ctx.request.files.file` 获取上传的文件信息,然后对文件进行处理。如果不是文件上传请求,我们只是简单地返回了一个 "Hello World!" 字符串。 注意,我们在代码中没有对文件进行任何处理,只是输出了一些文件信息。在实际项目中,我们需要对上传的文件进行校验、存储和处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值