原生nodejs如何上传图片

var http=require('http')
var fs=require('fs')
// formidable是nodejs中用来上传图片的模块
var formidable=require('formidable')
// path是路径模块
var path=require('path')

http.createServer(function(req,res){
	// 如果请求的方法为post (在form中的method='post')
if(req.method.toLowerCase()=='post'){
	var form=formidable.IncomingForm();
	// 设置上传之后图片的地址 这个文件夹要提前创好,否则报错
	form.uploadDir='./uploadImg'
	form.parse(req,function(err,fields,files){
		// 图片的所有信息都在这个 files 中,console.log可以查看
		// console.log(files)
		if(err){
			throw err
		}
			// 原名字
			// __dirname 是node的一个全局变量,获得当前文件所在目录的完整目录名
		var oldpath= __dirname+"/"+files.pic.path   
		// 时间戳
		var time= +new Date()
	  // 随机数
		var random=parseInt(Math.random()*10000)
		// 图片拓展名 .JPG .png
		var extname=path.extname(files.pic.name)
			// 新的文件名=__dirname+存放上传图片的文件夹地址+时间戳+随机数+后缀名
		var newpath=__dirname + '/uploadImg/'+	time + random +extname
console.log(newpath)
		fs.rename(oldpath,newpath,function(err){
			if(err){
				throw Error("false")

			}
			res.end("success")
		})

	})
}


}).listen(3000,'127.0.0.1')
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Node.js中实现图片功能可以使用koa-body和koa-static这两个插件。首先,需要安装koa-body插件并在app.js配置中引入它。通过设置app.use(bodyParser.json({limit: '50mb'}))和app.use(bodyParser.urlencoded({limit: '50mb', extended: true}))来限制post文件的大小。然后,设置视图引擎和模板配置,可以使用art-template插件来处理视图。最后,通过app.use('/', routes)将路由设置为根路径。\[1\] 具体实现图片功能的流程如下: 1. 前端通过接口将图片到后端。 2. 后端接收并验证图片。 3. 后端将图片存储在文件服务器上,并生成图片路径和唯一ID。 4. 后端将图片路径和唯一ID返回给前端。 5. 前端将图片路径和唯一ID发送到相应的接口中。 6. 接口保存图片信息以便后续使用。 这样,前端就可以通过图片路径和唯一ID来使用上图片了。\[3\] 总结起来,Node.js实现图片功能需要使用koa-body和koa-static插件,并按照上述流程进行处理。\[2\] #### 引用[.reference_title] - *1* [nodejs图片](https://blog.csdn.net/chunyouhai5703/article/details/100978631)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [《NodeJS》Koa实现图片功能](https://blog.csdn.net/zy21131437/article/details/130440198)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值