node处理表单请求,需要用到formidable包。安装formidable包的命令如下:

npm install formidable

安装package的路径分为两种,一种是本地目录,一种是全局目录。

npm install xxx -g 命令将模块下载安装到全局目录中。

全局目录可以通过 npm config set prefix "目录路径" 来设置。

通过 npm config get prefix 来获取当前设置的目录。

npm install xxx ,则是将模块下载到当前命令行所在目录。

关于package安装路径的说明网上是像上面那样说的,但我不执行全局安装的时候,formidable被安装在了用户主目录/home/用户名/node_modules下面,而不是安装在命令行所在目录,我用的ubuntu版本是14.04,原因不太清楚。安装在本里目录和全局目录到底哪个好,我认为各有优势。这里就不赘述了。

安装完formidable之后,一个标准的node project,应该有一个index.js文件,用于定义怎么处理来自浏览器的request,index.js代码如下:

var http = require("http");//获取http对象
var url = require("url");//获取url对象
//http、url都是系统自带的模块,而下面的requestHandlers是我们手动编写的模块,对应当前目录下的requestHandlers.js文件
var requestHandlers = require("./requestHandlers"); //onRequest函数,用于处理http请求,不同的url请求交由不同的函数进行处理
function onRequest(request, response){
var pathname = url.parse(request.url).pathname;//获取请求的URL //requestHandlers的handle属性又是一个对象,该对象包含多组属性:属性值,属性名对应uri,属性值对应处理函数,详见requestHandlers.js
if(typeof requestHandlers.handle[pathname] === "function")
requestHandlers.handle[pathname](request, response);
else {
console.log("No request handler found for " + pathname);
response.writeHead(404, {"Content-Type": "text/html;charset=utf-8"});
response.write("您访问的页面不存在!访问<a href='/'>首页</a>");
response.end();
}
} var server = http.createServer(onRequest);//函数onRequest作为createServer的参数,这样浏览器每发送一次请求,服务器中该函数都会被调用一次
server.listen(8888);
//上面两句可以合写成http.createServer(onRequest).listen(8888);

上面这段代码几乎可以成为大部分node项目的index的模板,有改动也不会很大,如果给应用增加功能,只需要更改后面的requestHandlers.js文件。以前上学时老师讲的一个基本node应用分为index.js、server.js、router.js和requestHandlers.js四个部分,而server.js和router.js的代码从来都是不需要改变的,可以应用到任何一个项目,后来我发现其实前三个部分可以整合到一起,于是自己琢磨了一下写出了上面那个index.js,后来发现整合之后其实还好理解一点。

下面贴出requestHandlers.js的代码:

var handle = {};
var formidable = require("formidable"); handle["/"] = start;
handle["/start"] = start;
handle["/upload"] = upload; function start(request, response) {
var body = '<html>'+
'<head>'+
'<meta http-equiv="Content-Type" content="text/html; '+
'charset=UTF-8" />'+
'</head>'+
'<body>'+
'<form action="/upload" method="post">'+
'学号:<input type="text" name="id" /><br /><br />'+
'姓名:<input type="text" name="name" /><br /><br />'+
'<input type="submit" value="提交" />'+
'</form>'+
'</body>'+
'</html>';
response.writeHead(200, {"Content-Type": "text/html"});
response.write(body);
response.end();
} function upload(request, response) {
var form = new formidable.IncomingForm();
form.parse(request, function(error, fields, files) {
console.log("id:" + fields.id);
console.log("name:" + fields.name);
response.writeHead(200, {"Content-Type": "text/html;charset=utf-8"});
response.write("id:" + fields.id + "<br>");
response.write("name:" + fields.name);
response.end();
});
} exports.handle = handle;
exports.start = start;
exports.upload = upload;

上面演示了一个form表单提交后,从form表单中提取信息的例子。其中handle是一个对象,包含多组属性和属性值,属性名对应url,属性值对应处理函数,即请求的url与函数是一一对应的,浏览器每发送一个请求,服务器分析出请求的url,并用handle中名为该url的属性的值所对应的函数来处理该请求。比如,浏览器发送了一个请求,uri为/upload,服务器查找到handler中,handler["/upload"] = upload,就会调用upload函数来处理该请求。模块中所有可能会被外部文件调用属性、函数都需要使用exports命令导出,如requestHandlers.js的结尾部分。所以,如果增加功能时,页面上增加了一个链接或表单之类的请求/xxx,则通常需要在requestHandlers.js文件中作出修改,分三步:

一、增加 handler["/xxx"] = xxx;

二、增加 function xxx(request, response){...};

三、增加 exports.xxx = xxx;

node.js表单——formidable的更多相关文章

  1. node.js表单——formidable/////z

    node.js表单--formidable   node处理表单请求,需要用到formidable包.安装formidable包的命令如下: npm install formidable 安装pack ...

  2. JS表单验证-12个常用的JS表单验证

    JS表单验证-12个常用的JS表单验证 最近有个项目用到了表单验证,小编在项目完结后的这段时间把常用的JS表单验证demo整理了一下,和大家一起分享~~~ 1. 长度限制 <p>1. 长度 ...

  3. js 表单验证控制代码大全

    js表单验证控制代码大全 关键字:js验证表单大全,用JS控制表单提交 ,javascript提交表单:目录:1:js 字符串长度限制.判断字符长度 .js限制输入.限制不能输入.textarea 长 ...

  4. js表单提交,面向对象

    一.js表单验证之后再提交 1.普通按钮onclick函数调用表单的submit()函数 <input type=button name="submit1" value=&q ...

  5. jquery.validation.js 表单验证

    jquery.validation.js 表单验证   官网地址:http://bassistance.de/jquery-plugins/jquery-plugin-validation jQuer ...

  6. Jquery.validate.js表单验证插件的使用

    作为一个网站web开发人员,以前居然不知道还有表单验证这样好呀的插件,还在一行行写表单验证,真是后悔没能早点知道他们的存在. 最近公司不忙,自己学习一些东西的时候,发现了validation的一个实例 ...

  7. angular js 表单验证

    <!doctype html> <html ng-app="myapp"> <head> <meta charset="UTF- ...

  8. JS表单验证类HTML代码实例

    以前用的比较多的一个JS表单验证类,对于个人来说已经够用了,有兴趣的可以在此基础上扩展成ajax版本.本表单验证类囊括了密码验证.英文4~10个 字符验证. 中文非空验证.大于10小于100的数字.浮 ...

  9. js表单提交,判断文本框,用户名密码是否为空,JS表单检测!

    当表单提交时先触发验证的js代码,当验证表单的方法返回true时才会提交表单返回false则不提交数据<script type="text/javascript">fu ...

随机推荐

  1. excel查看VBA代码快捷键

    公司现在的很多自动化代码生成使用excel VBA,本来这事跟自己一点关系打不着,不过计划年底切换中间件,这得导致部分代码结构调整,自己还得去调整测试,老忘掉这快捷键,特记录下,Alt + F11

  2. Spring MVC处理异常的4种方式

    http://blog.csdn.net/ufo2910628/article/details/40399539 http://my.oschina.net/CandyDesire/blog/3333 ...

  3. git node(&npm)安装

    1.git 下载地址:https://git-scm.com/download/win 2.node 下载地址:https://nodejs.org/en/download/ 安装node会自带npm ...

  4. scroll事件实现监控滚动条并分页显示示例(zepto.js)

    scroll事件实现监控滚动条并分页显示示例(zepto.js  ) 需求:在APP落地页上的底部位置显示此前其他用户的购买记录,要求此div盒子只显示3条半,但一页有10条,div内的滑动条滑到一页 ...

  5. jQuery构造函数init参数分析(三)

    分析完了字符串情况剩下的就不多了. 5.参数selector是函数 这个就是很容易想到了,首先说一下dom加载.我们通常在head里面写脚本的时候需要等待文档加载在进行处理,js是这么写的 windo ...

  6. 茎叶图(stem)

    介绍 茎叶图(Stem-and-Leaf display)又称“枝叶图”,由统计学家约翰托奇( Arthur Bowley)设计,它的思路是将数组中的数按位数进行比较,将数的大小基本不变或变化不大的位 ...

  7. SharePoint 开启网站匿名访问图文详解

    SharePoint 开启网站匿名,需要先开启web application的匿名访问,然后开启site的匿名访问.特别的,site可以选择整个网站开启或者列表和库开启匿名,如果选择列表和库开启匿名, ...

  8. 编译安装mysql(Ubuntu10 64位)

    选用较好的编译器和较好的编译器选项,这样应用可提高性能10-30%,这个对大多数程序都非常重要 Mysql的编译,不同的版本具体的配置方式是有差别的 旧版的配置形式参考 这个形式主要是使用config ...

  9. AS下NDK开发(一)

    捣鼓了一天的NDK,总结下. Eclipse下开发ndk好像挺麻烦的样子,看书上要下载Cygwin,eclipse还要下载插件CDT..而在AS上就方便多啦.下载android ndk.安装,配置环境 ...

  10. iOS远程推送原理及实现过程

    ➠更多技术干货请戳:听云博客 推送通知,是现在的应用必不可少的功能.那么在 iOS 中,我们是如何实现远程推送的呢?iOS 的远程推送原理又是什么呢?在做 iOS 远程推送时,我们会遇到各种各样的问题 ...