nodejs 初步使用以及实现文件上传的功能

这个例子是引用了《nodejs入门》中的文件上传的例子,

相应的原理就不讲解了,可以查看上面所说的那本书,这里自会贴出相关的代码和注意点:


首先是server.js模块的代码:实现了基本的服务器的创建:

var http = require("http");
var url = require("url");
function start(route, handle) {
function onRequest(request, response) {
var pathname = url.parse(request.url).pathname;
console.log("Request for " + pathname + " received.");
route(handle, pathname, response, request);
}
http.createServer(onRequest).listen(8888);
console.log("Server has started.");
}
exports.start = start;


在者是有关这些服务器获取请求数据的处理模块:requestHandlers.js

var querystring = require("querystring"),
fs = require("fs"),
formidable = require("formidable");
function start(response) {
console.log("Request handler 'start' was called.");
	var body = '<html>'+
	'<head>'+
	'<meta http-equiv="Content-Type" content="text/html; '+
	'charset=UTF-8" />'+
	'</head>'+
	'<body>'+
	'<form action="/upload" enctype="multipart/form-data" '+
	'method="post">'+
	'<input type="file" name="upload" multiple="multiple">'+
	'<input type="submit" value="Upload file" />'+
	'</form>'+
	'</body>'+
	'</html>';
	response.writeHead(200, {"Content-Type": "text/html"});
	response.write(body);
	response.end();
}

function upload(response, request) {
	console.log("Request handler 'upload' was called.");
	var form      = new formidable.IncomingForm();
	console.log( form.uploadDir );
	form.uploadDir= "./";  //这一句话是很必要的,就是设置到当前的文件
	console.log("about to parse");
	form.parse(request, function(error, fields, files) {
		console.log("parsing done"+files.upload.path );
			fs.renameSync(files.upload.path,"./test.png");
<span style="white-space:pre">		</span>//很多资料中都是有/tmp/test.png 那是因为一般的都是在c盘,若是没有就会显示错误。我们这样就直接当前的目录存储。
		console.log(files.upload.path);
		response.writeHead(200, {"Content-Type": "text/html"});
		response.write("received image:<br/>");
		response.write("<img src='/show' />");
		response.end();
	});
}

function show(response) {
console.log("Request handler 'show' was called.");
try{
fs.readFile("./test.png", "binary", function(error, file) {//获取文件的路径要和上传存储文件的路径一样。
if(error) {
response.writeHead(500, {"Content-Type": "text/plain"});
response.write(error + "\n");
response.end();
} else {
response.writeHead(200, {"Content-Type": "image/png"});
response.write(file, "binary");
response.end();
}
});
}catch(e){
	console.log(e);
}
}
exports.start = start;
exports.upload = upload;
exports.show = show;
上面包括了请求的方法、上传的方法 和 展示的方法


下面是要给它们进行配置路由:就是实现服务器和数据处理模块之间的逻辑关系,代码如下:

function route(handle, pathname, response, request) {
console.log("About to route a request for " + pathname);
if (typeof handle[pathname] === 'function') {
handle[pathname](response, request);
} else {
console.log("No request handler found for " + pathname);
response.writeHead(404, {"Content-Type": "text/html"});
response.write("404 Not found");
response.end();
}
}
exports.route = route;
路由其实就是配置请求的过程路径,其实就是相当于Java EE中的Struts中的action配置文件,不同的请求配置不同的动作。



最后就是配置路劲是怎么样的,这个就是和router有对应的关系从而出发不同的动作。

var server = require("./server");
var router = require("./router");
var requestHandlers = require("./requestHandlers");
var handle = {}
handle["/"] = requestHandlers.start;
handle["/start"] = requestHandlers.start;
handle["/upload"] = requestHandlers.upload;
handle["/show"] = requestHandlers.show;
server.start(router.route, handle)


这些代码执行的时候需要相应的框架:formidable

在dos中(安装了npm的环境的情况下)执行命令:npm install formidable 在工程文件下安装这个框架。

像以前那样执行就可以了。











  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
Node.js是一个基于Chrome V8引擎的JavaScript运行环境,它可以使JavaScript在服务器端运行。要实现文件和下载,可以使用Node.js的一些模块和框架来简化开发过程。 对于文件,可以使用Multer作为中间件进行数据处理。Multer是一个流行的Node.js中间件,用于处理表单数据,特别是文件。以下是一个简单的示例代码: ```javascript const express = require('express'); const multer = require('multer'); const app = express(); const upload = multer({ dest: 'uploads/' }); app.post('/upload', upload.single('file'), (req, res) => { // 处理上文件 console.log(req.file); res.send('文件成功!'); }); app.listen(8080, () => { console.log('服务器已启动,监听端口8080'); }); ``` 上述代码创建了一个基本的Express应用程序,并使用Multer中间件来处理文件。`upload.single('file')`表示只接受名为`file`的单个文件。在回调函数中可以进行文件处理的操作。 对于文件下载,可以使用Node.js的内置模块`fs`和`http`来实现。以下是一个简单的示例代码: ```javascript const http = require('http'); const fs = require('fs'); http.createServer((req, res) => { if (req.method === 'GET' && req.url === '/download') { const file = fs.createReadStream('path/to/file.txt'); res.setHeader('Content-disposition', 'attachment; filename=file.txt'); file.pipe(res); } }).listen(8080, () => { console.log('服务器已启动,监听端口8080'); }); ``` 上述代码创建了一个简单的HTTP服务器,当GET请求路径为`/download`时,会将文件作为附件下载。可以通过设置`Content-disposition`头来指定下载文件的名称。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值