NodeJS基础(三)

一、Express框架

Express框架是后台的Node框架,所以和jQuery、zepto、yui、bootstrap都不一个东西。

Express在后台的受欢迎的程度,和jQuery一样,就是企业的事实上的标准。

● 原生Node开发,会发现有很多问题。比如:

■ 呈递静态页面很不方便,需要处理每个HTTP请求,还要考虑304问题

■ 路由处理代码不直观清晰,需要写很多正则表达式和字符串函数

■ 不能集中精力写业务,要考虑很多其他的东西

我们自己可以把第一天的作业,就是那个静态文件服务给封装成为模块。封装的越多,就自己做出了类似Express的东西。

● EXPRESS的哲学是在你的想法和服务器之间充当薄薄的一层。这并不意味着他不够健壮,或者没有足够的有用特性,而是尽量少干预你,让你充分表达自己的思想,同时提供一些有用的东西。

英语官网:http://expressjs.com/

中文官网:http://www.expressjs.com.cn/

整体感知,Express框架。

安装Express框架,就是使用npm的命令。

1 npm install --save express

--save参数,表示自动修改package.json文件,自动添加依赖项。

路由能力:

1 var express = require("express");

2

3 var app = express();

4

5 app.get("/",function(req,res){

6 res.send("你好");

7 });

8

9 app.get("/haha",function(req,res){

10 res.send("这是haha页面,哈哈哈哈哈哈");

11 });

12

13 app.get(/^\/student\/([\d]{10})$/,function(req,res){

14 res.send("学生信息,学号" + req.params[0]);

15 });

16

17 app.get("/teacher/:gonghao",function(req,res){

18 res.send("老师信息,工号" + req.params.gonghao);

19 });

20

21 app.listen(3000);

静态文件伺服能力:

1 app.use(express.static("./public"));

模板引擎:

1 var express = require("express");

2

3 var app = express();

4

5 app.set("view engine","ejs");

6

7 app.get("/",function(req,res){

8 res.render("haha",{

9 "news" : ["我是小新闻啊","我也是啊","哈哈哈哈"]

10 });

11 });

12

13 app.listen(3000);

Express4.X,和Express3.X差别非常大。

二、路由

当用get请求访问一个网址的时候,做什么事情:

1 app.get("网址",function(req,res){

2

3 });

当用post访问一个网址的时候,做什么事情:

1 app.post("网址",function(req,res){

2

3 });

如果想处理这个网址的任何method的请求,那么写all

1 app.all("/",function(){

2

3 });

这里的网址,不分大小写,也就是说,你路由是

1 app.get("/AAb",function(req,res){

2 res.send("你好");

3 });

实际上小写的访问也行。

所有的GET参数,? 后面的都已经被忽略。 锚点#也被忽略

你路由到/a , 实际/a?id=2&sex=nan 也能被处理。

正则表达式可以被使用。正则表达式中,未知部分用圆括号分组,然后可以用req.params[0]、[1]得到。

req.params类数组对象。

1 app.get(/^\/student\/([\d]{10})$/,function(req,res){

2 res.send("学生信息,学号" + req.params[0]);

3 });

冒号是更推荐的写法。

1 app.get("/student/:id",function(req,res){

2 var id = req.params["id"];

3 var reg= /^[\d]{6}$/; //正则验证

4 if(reg.test(id)){

5 res.send(id);

6 }else{

7 res.send("请检查格式");

8 }

9 });

表单可以自己提交到自己上。

1 app.get("/",function(req,res){

2 res.render("form");

3 });

4

5 app.post("/",function(req,res){

6 //将数据添加进入数据库

7 res.send("成功");

8 });

适合进行 RESTful路由设计。简单说,就是一个路径,但是http method不同,对这个页面的使用也不同。

/student/345345

get 读取学生信息

add 添加学生信息

delete 删除学生新

三、中间件

如果我的的get、post回调函数中,没有next参数,那么就匹配上第一个路由,就不会往下匹配了。

如果想往下匹配的话,那么需要写next()

1 app.get("/",function(req,res,next){

2 console.log("1");

3 next();

4 });

5

6 app.get("/",function(req,res){

7 console.log("2");

8 });

下面两个路由,感觉没有关系:

1 app.get("/:username/:id",function(req,res){

2 console.log("1");

3 res.send("用户信息" + req.params.username);

4 });

5

6 app.get("/admin/login",function(req,res){

7 console.log("2");

8 res.send("管理员登录");

9 });

但是实际上冲突了,因为admin可以当做用户名 login可以当做id。

解决方法1:交换位置。 也就是说,express中所有的路由(中间件)的顺序至关重要。

匹配上第一个,就不会往下匹配了。 具体的往上写,抽象的往下写。

1 app.get("/admin/login",function(req,res){

2 console.log("2");

3 res.send("管理员登录");

4 });

5

6 app.get("/:username/:id",function(req,res){

7 console.log("1");

8 res.send("用户信息" + req.params.username);

9 });

解决方法2:

1 app.get("/:username/:id",function(req,res,next){

2 var username = req.params.username;

3 //检索数据库,如果username不存在,那么next()

4 if(检索数据库){

5 console.log("1");

6 res.send("用户信息");

7 }else{

8 next();

9 }

10 });

11

12 app.get("/admin/login",function(req,res){

13 console.log("2");

14 res.send("管理员登录");

15 });

路由get、post这些东西,就是中间件,中间件讲究顺序,匹配上第一个之后,就不会往后匹配了。next函数才能够继续往后匹配。

app.use()也是一个中间件。与get、post不同的是,他的网址不是精确匹配的。而是能够有小文件夹拓展的。

比如网址: http://127.0.0.1:3000/admin/aa/bb/cc/dd

1 app.use("/admin",function(req,res){

2 res.write(req.originalUrl + "\n"); // /admin/aa/bb/cc/dd

3 res.write(req.baseUrl + "\n"); // /admin

4 res.write(req.path + "\n"); // /aa/bb/cc/dd

5 res.end("你好");

6 });

如果写一个/

1 //当你不写路径的时候,实际上就相当于"/",就是所有网址

2 app.use(function(req,res,next){

3 console.log(new Date());

4 next();

5 });

app.use()就给了我们增加一些特定功能的便利场所。

实际上app.use()的东西,基本上都从第三方能得到。

● 大多数情况下,渲染内容用res.render(),将会根据views中的模板文件进行渲染。如果不想使用views文件夹,想自己设置文件夹名字,那么app.set("views","aaaa");

● 如果想写一个快速测试页,当然可以使用res.send()。这个函数将根据内容,自动帮我们设置了Content-Type头部和200状态码。send()只能用一次,和end一样。和end不一样在哪里?能够自动设置MIME类型。

● 如果想使用不同的状态码,可以:

res.status(404).send(‘Sorry, we cannot find that!‘);

● 如果想使用不同的Content-Type,可以:

res.set(‘Content-Type‘, ‘text/html‘);


四、GET请求和POST请求的参数

● GET请求的参数在URL中,在原生Node中,需要使用url模块来识别参数字符串。在Express中,不需要使用url模块了。可以直接使用req.query对象。

● POST请求在express中不能直接获得,必须使用body-parser模块。使用后,将可以用req.body得到参数。但是如果表单中含有文件上传,那么还是需要使用formidable模块。

Node中全是回调函数,所以我们自己封装的函数,里面如果有异步的方法,比如I/O,那么就要用回调函数的方法封装。

错误:

1 res.reder("index",{

2 "name" : student.getDetailById(234234).name

3 });

4

5

正确:

6

7 student.getDetailByXueHao(234234,function(detail){

8 res.render("index",{

9 "name" : detail.name

10 })

11 });

12

1

时间: 2025-01-14 22:03:27

NodeJS基础(三)的相关文章

Node.js学习笔记【3】NodeJS基础、代码的组织和部署、文件操作、网络操作、进程管理、异步编程

一.表 学生表 CREATE TABLE `t_student` ( `stuNum` int(11) NOT NULL auto_increment, `stuName` varchar(20) default NULL, `birthday` date default NULL, PRIMARY KEY  (`stuNum`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 学生分数表 CREATE TABLE `t_stu_score` ( `id` int(11

Python全栈开发【基础三】

Python全栈开发[基础三]  本节内容: 函数(全局与局部变量) 递归 函数 一.定义和使用 函数最重要的是减少代码的重用性和增强代码可读性 1 def 函数名(参数): 2 3 ... 4 函数体 5 ... 6 返回值 函数的定义主要有如下要点: def:表示函数的关键字 函数名:函数的名称,日后根据函数名调用函数 函数体:函数中进行一系列的逻辑计算 参数:为函数体提供数据 返回值:当函数执行完毕后,可以给调用者返回数据. 总结使用函数的好处: 1.减少代码重用 2.保持一致性,易维护

[转]Nodejs基础中间件Connect

Nodejs基础中间件Connect 从零开始nodejs系列文章,将介绍如何利Javascript做为服务端脚本,通过Nodejs框架web开发.Nodejs框架是基于V8的引擎,是目前速度最快的Javascript引擎.chrome浏览器就基于V8,同时打开20-30个网页都很流畅.Nodejs标准的web开发框架Express,可以帮助我们迅速建立web站点,比起PHP的开发效率更高,而且学习曲线更低.非常适合小型网站,个性化网站,我们自己的Geek网站!! 关于作者 张丹(Conan),

nodejs学习三 process对象

rocess对象,我说的是对象.这个对象包含的方法和属性非常的多,它向我们打开了一个通往Node.js的大门,让我们队Node.js有更多的了解. 你知道安装的Node.js的版本吗? 你知道你的Node安装在上面平台下吗? 你知道你的Node可执行文件的绝对路径吗? 你想得到你env环境变量内容吗? 上面输入的信息你可以更具体点,比如console.log(process.env.OS) 你想得到命令行上的参数吗? 好了,下面我们来写一个js.命名process.js 在命令行上运行它: 我们

JS基础三

1.delete删除对对象的属性和方法的定义.强制解除对它的引用,将其设置为 undefined delete 运算符不能删除开发者未定义的属性和方法. 2.void 运算符对任何值返回 undefined.该运算符通常用于避免输出不应该输出的值,没有返回值的函数真正返回的都是 undefined. 3.前增量运算符,就是数值上加 1,形式是在变量前放两个加号(++): var iNum = 10; ++iNum; 第二行代码把 iNum 增加到了 11,它实质上等价于: var iNum =

Nodejs基础中间件

Nodejs基础中间件Connect http://www.tuicool.com/articles/emeuie 关于作者 张丹(Conan), 程序员Java,R,PHP,Javascript weibo:@Conan_Z blog: http://blog.fens.me email: [email protected] 转载请注明出处: http://blog.fens.me/nodejs-connect/ 前言 "中间件"在软件领域是一个非常广的概念,除操作系统的软件都可以称

学习NodeJS第三天:打造Nodejs的调试环境(中)

2012-12-07 因追加<学习 NodeJS 第三天:打造 Nodejs 的调试环境(下)>的缘故,特此将原来的<下>篇改为<中>篇,如标题所示. 上一期我们为大家介绍了安装 Eclipse 调试插件的情况,这对于还不熟悉 Eclipse 开发平台的用户是至关重要的,希望可以通过一步步的图片加文字说明,把 Nodejs 困难的地方变简单和清晰.友好和轻松. 现在正式进入要调试程序肯定要有调试代码.下面就是我们第一个测试的代码,很小的行数: var sys = req

SQL基础三(例子)

-------------------对分组统计的结果进一步筛选(having子句使用)------------------------------ select * from student2010 --1.查询qypt08class表中各院系的人数,只显示人数多于400的记录 select yx,sum(rs) from qypt08class group by yx having sum(rs)>400 --2.统计stucou表中各门课程的选修人数,只显示人数少于30的记录(显示coun

Object Pascal 语法之语言基础(三)

1.6 Object Pascal 的运算符 运算符是程序代码中对各种类型的数据进行计算的符号,通常分为算数运算符.逻辑运算符.比较运算符和按位运算符. 1.算术运算符Object Pascal 语言的算术运算符,如表1-9 所示.表1-9 Object Pascal 语言算术运算符 操作符 操作 操作数据类型 结果类型 + 加 整型.实型 整型.实型 - 减 整型.实型 整型.实型 * 乘 整型.实型 整型.实型 / 除 整型.实型 整型.实型 mod 取余 整型 整型 div 整除 整型 整

色彩及图像基础(三)

色彩及图像基础(三) 学习时间:2014.04.30 学到了-- 1. 图像压缩的基础在于: ①原始图像信息存在着很大的冗余度: ②人眼对图像的亮度信息敏感.对颜色分辨率弱. 2. 数据压缩的两类基本方法: ①无损压缩:将相同的或相似的数据或数据特征归类,使用较少的数据量描述原始数据,达到减少数据量的目的. ②有损压缩:利用人眼的视觉特性有针对性地简化不重要的数据,以减少总的数据量. 3. 图像的编码方法:行程编码.增量调制编码和霍夫曼编码. 行程编码: 1. RLE(Run-Length En