全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

node koa2实现上传图片并且同步上传到七牛云存储

因为升级到新的node版本,之前的通过很多上传图片的方式都已经不适用了,所以自己就写了一个对于 koa2上传图片的小demo,记录一下心得。

废话不多说,下面直接上代码,里面都有注释。

const Koa = require('koa');
const route = require('koa-route');
const serve = require('koa-static');
const inspect = require('util').inspect
const path = require('path')
const os = require('os')
const fs = require('fs')
const Busboy = require('busboy')
const qiniu = require('qiniu')
const qiniuConfig = require('./qiniuconfig')

 
const app = new Koa();

app.use(serve(__dirname + '/public/'));

 
// 写入目录
const mkdirsSync = (dirname) => {
 if (fs.existsSync(dirname)) {
  return true
 } else {
  if (mkdirsSync(path.dirname(dirname))) {
   fs.mkdirSync(dirname)
   return true
  }
 }
 return false
}

function getSuffix (fileName) {
 return fileName.split('.').pop()
}

// 重命名
function Rename (fileName) {
 return Math.random().toString(16).substr(2) + '.' + getSuffix(fileName)
}
// 删除文件
function removeTemImage (path) {
 fs.unlink(path, (err) => {
  if (err) {
   throw err
  }
 })
}
// 上传到七牛
function upToQiniu (filePath, key) {
 const accessKey = qiniuConfig.accessKey // 你的七牛的accessKey
 const secretKey = qiniuConfig.secretKey // 你的七牛的secretKey
 const mac = new qiniu.auth.digest.Mac(accessKey, secretKey)

 const options = {
  scope: qiniuConfig.scope // 你的七牛存储对象
 }
 const putPolicy = new qiniu.rs.PutPolicy(options)
 const uploadToken = putPolicy.uploadToken(mac)

 const config = new qiniu.conf.Config()
 // 空间对应的机房
 config.zone = qiniu.zone.Zone_z2
 const localFile = filePath
 const formUploader = new qiniu.form_up.FormUploader(config)
 const putExtra = new qiniu.form_up.PutExtra()
 // 文件上传
 return new Promise((resolved, reject) => {
  formUploader.putFile(uploadToken, key, localFile, putExtra, function (respErr, respBody, respInfo) {
   if (respErr) {
    reject(respErr)
   }
   if (respInfo.statusCode == 200) {
    resolved(respBody)
   } else {
    resolved(respBody)
   }
  })
 })

}

// 上传到本地服务器
function uploadFile (ctx, options) {
 const _emmiter = new Busboy({headers: ctx.req.headers})
 const fileType = options.fileType
 const filePath = path.join(options.path, fileType)
 const confirm = mkdirsSync(filePath)
 if (!confirm) {
  return
 }
 console.log('start uploading...')
 return new Promise((resolve, reject) => {
  _emmiter.on('file', function (fieldname, file, filename, encoding, mimetype) {
   const fileName = Rename(filename)
   const saveTo = path.join(path.join(filePath, fileName))
   file.pipe(fs.createWriteStream(saveTo))
   file.on('end', function () {
    resolve({
     imgPath: `/${fileType}/${fileName}`,
     imgKey: fileName
    })
   })
  })

  _emmiter.on('finish', function () {
   console.log('finished...')
  })

  _emmiter.on('error', function (err) {
   console.log('err...')
   reject(err)
  })

  ctx.req.pipe(_emmiter)
 })
}



app.use(route.post('/upload', async function(ctx, next) {

  const serverPath = path.join(__dirname, './uploads/')
 // 获取上存图片
 const result = await uploadFile(ctx, {
  fileType: 'album',
  path: serverPath
 })
 const imgPath = path.join(serverPath, result.imgPath)
 // 上传到七牛
 const qiniu = await upToQiniu(imgPath, result.imgKey)
 // 上存到七牛之后 删除原来的缓存图片
 removeTemImage(imgPath)
 ctx.body = {
  imgUrl: `http://xxxxx(你的外链或者解析后七牛的路径)/${qiniu.key}`
 }
}));
 
app.listen(3001);

console.log('listening on port 3001');

然后在同一级目录下,创建一个public文件夹,然后在下面新建一个 index.html,因为我们上面已经把这个文件夹设置为静态访问文件夹了, public/index.html 的代码为

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Document</title>
</head>
<body>
  <input id="btn1" type="file" name="file"/> 
 <input id="btn2" type="submit" value="提交"/>
</body>
<script>
  
  var btn1 = document.querySelector('#btn1')
  var btn2 = document.querySelector('#btn2')
  var file = null
  btn1.addEventListener('change', function(e){
    file = e.target.files[0]
  })

  btn2.onclick = function(){
  var _data = new FormData();
  _data.append('file', file);
  xhr(_data)
  }

  var xhr = function(formdata){
    var xmlHttp = new XMLHttpRequest(); 

    xmlHttp.open("post","http://127.0.0.1:3001/upload", true); 
     
    xmlHttp.send(formdata);

    xmlHttp.onreadystatechange = function(){ 
     if(xmlHttp.readyState==4){ 
       if(xmlHttp.status==200){ 
         var data = xmlHttp.responseText; 
         console.log(data); 
       } 
     }
    }
  }
</script>
</html>

选择好图片,然后点击提交,就可以上传到你的七牛空间啦!

源代码在 github: https://github.com/naihe138/koa-upload

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# nodejs  # koa  # 上传图片  # nodejs上传图片到七牛  # koa2实现上传图片  # nodejs之koa2请求示例(GET  # POST)  # node使用Koa2搭建web项目的方法  # node+koa2+mysql+bootstrap搭建一个前端论坛  # nodejs中Express与Koa2对比分析  # nodejs6下使用koa2框架实例  # 阿里大于短信验证码node koa2的实现代码(最新)  # Node.js环境下Koa2添加travis ci持续集成工具的方法  # Node.js Koa2使用JWT进行鉴权的方法示例  # node(koa2) web应用模块介绍详解  # Node.js中Koa2在控制台输出请求日志的方法示例  # 都有  # 用了  # 写了  # 就可  # 多说  # 设置为  # 创建一个  # 源代码  # 到新  # 大家多多  # 新建一个  # 重命名  # 文件上传  # 目录下  # accessKey  # key  # upToQiniu  # throw  # filePath 


相关文章: 沈阳个人网站制作公司,哪个网站能考到沈阳事业编招聘的信息?  建站主机服务器选型指南与性能优化方案解析  建站VPS推荐:2025年高性能服务器配置指南  GML (Geography Markup Language)是什么,它如何用XML来表示地理空间信息?  如何通过cPanel快速搭建网站?  如何在阿里云域名上完成建站全流程?  如何在IIS7上新建站点并设置安全权限?  存储型VPS适合搭建中小型网站吗?  如何在云指建站中生成FTP站点?  台州网站建设制作公司,浙江手机无犯罪记录证明怎么开?  如何选择香港主机高效搭建外贸独立站?  如何配置WinSCP新建站点的密钥验证步骤?  如何用西部建站助手快速创建专业网站?  电脑免费海报制作网站推荐,招聘海报哪个网站多?  c# Task.Yield 的作用是什么 它和Task.Delay(1)有区别吗  如何将凡科建站内容保存为本地文件?  东莞专业网站制作公司有哪些,东莞招聘网站哪个好?  建站之星如何实现网站加密操作?  无锡制作网站公司有哪些,无锡优八网络科技有限公司介绍?  建站主机服务器选购指南:轻量应用与VPS配置解析  网站制作员失业,怎样查看自己网站的注册者?  微信h5制作网站有哪些,免费微信H5页面制作工具?  如何在建站之星网店版论坛获取技术支持?  保定网站制作方案定制,保定招聘的渠道有哪些?找工作的人一般都去哪里看招聘信息?  建站之星后台密码遗忘?如何快速找回?  油猴 教程,油猴搜脚本为什么会网页无法显示?  移民网站制作流程,怎么看加拿大移民官网?  已有域名如何免费搭建网站?  建站之星安装需要哪些步骤及注意事项?  建站之星安装失败:服务器环境不兼容?  c# 服务器GC和工作站GC的区别和设置  如何确认建站备案号应放置的具体位置?  SAX解析器是什么,它与DOM在处理大型XML文件时有何不同?  安徽网站建设与外贸建站服务专业定制方案  如何打造高效商业网站?建站目的决定转化率  网站制作培训多少钱一个月,网站优化seo培训课程有哪些?  黑客如何利用漏洞与弱口令入侵网站服务器?    MySQL查询结果复制到新表的方法(更新、插入)  建站主机无法访问?如何排查域名与服务器问题  一键制作网站软件下载安装,一键自动采集网页文档制作步骤?  如何在IIS中新建站点并配置端口与物理路径?  网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?  儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?  C++中引用和指针有什么区别?(代码说明)  如何通过主机屋免费建站教程十分钟搭建网站?  建站VPS选购需注意哪些关键参数?  青岛网站建设如何选择本地服务器?  如何高效完成独享虚拟主机建站?  如何高效利用200m空间完成建站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。