因为升级到新的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
相关文章:
如何在服务器上三步完成建站并提升流量?
如何在IIS7中新建站点?详细步骤解析
子杰智能建站系统|零代码开发与AI生成SEO优化指南
如何快速生成凡客建站的专业级图册?
装修招标网站设计制作流程,装修招标流程?
上海制作企业网站有哪些,上海有哪些网站可以让企业免费发布招聘信息?
如何在Tomcat中配置并部署网站项目?
如何快速查询网站的真实建站时间?
利用JavaScript实现拖拽改变元素大小
网站设计制作企业有哪些,抖音官网主页怎么设置?
如何通过IIS搭建网站并配置访问权限?
网站制作知乎推荐,想做自己的网站用什么工具比较好?
西安专业网站制作公司有哪些,陕西省建行官方网站?
想学网站制作怎么学,建立一个网站要花费多少?
名字制作网站免费,所有小说网站的名字?
如何配置支付宝与微信支付功能?
免费ppt制作网站,有没有值得推荐的免费PPT网站?
建站之星安装路径如何正确选择及配置?
如何通过虚拟主机快速搭建个人网站?
建站之星如何保障用户数据免受黑客入侵?
如何快速选择适合个人网站的云服务器配置?
javascript中对象的定义、使用以及对象和原型链操作小结
如何确认建站备案号应放置的具体位置?
SQL查询语句优化的实用方法总结
定制建站模板如何实现SEO优化与智能系统配置?18字教程
如何选择适合PHP云建站的开源框架?
如何选择香港主机高效搭建外贸独立站?
如何在Windows 2008云服务器安全搭建网站?
北京的网站制作公司有哪些,哪个视频网站最好?
矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?
焦点电影公司作品,电影焦点结局是什么?
打鱼网站制作软件,波克捕鱼官方号怎么注册?
浅谈Javascript中的Label语句
小说建站VPS选用指南:性能对比、配置优化与建站方案解析
如何注册花生壳免费域名并搭建个人网站?
如何有效防御Web建站篡改攻击?
如何用虚拟主机快速搭建网站?详细步骤解析
如何选择服务器才能高效搭建专属网站?
免费网站制作模板下载,除了易企秀之外还有什么H5平台可以制作H5长页面,最好是免费的?
阿里云网站制作公司,阿里云快速搭建网站好用吗?
如何在云指建站中生成FTP站点?
湖北网站制作公司有哪些,湖北清能集团官网?
javascript基本数据类型及类型检测常用方法小结
建站三合一如何选?哪家性价比更高?
北京制作网站的公司排名,北京三快科技有限公司是做什么?北京三快科技?
在线教育网站制作平台,山西立德教育官网?
网站制作哪家好,cc、.co、.cm哪个域名更适合做网站?
如何在自有机房高效搭建专业网站?
香港服务器网站推广:SEO优化与外贸独立站搭建策略
小建面朝正北,A点实际方位是否存在偏差?
*请认真填写需求信息,我们会在24小时内与您取得联系。