首页 > 代码库 > nodejs(三)上之express
nodejs(三)上之express
- express
- 简介
- Express 是一个简洁而灵活的 node.js Web应用框架, 提供了一系列强大特性帮助你创建各种 Web 应用,和丰富的 HTTP 工具。
- 使用 Express 可以快速地搭建一个完整功能的网站
- 安装并运行
- sudo npm install express
- var express = require(“express”);
var app = express();//初始化 - 核心功能
- 路由
- get方法 — 根据请求路径来处理客户端发出的GET请求
- app.get(path,cb);
* path:为请求的路径
* cb :第二个参数为处理函数的回调,有两个参数request和response,代表请求信息和响应信息 - 前端页面代码
- <!DOCTYPE html>
<html lang=“en”>
<head>
<meta charset=“UTF-8”>
<title>Title</title>
</head>
<body>
<form action=“/list” method=“post”>
用户名:<input type=“text” name=“user”><br>
密码: <input type=“password”><br>
<input type=“submit” value=http://www.mamicode.com/“发送”>
</form>
</body>
</html> - 服务端
- //处理get方式发送的请求
app.get(“/“, function (req,res) {
//返回一个静态文件
res.sendFile(__dirname+”/post.html”);
});
app.get(“/list”, function (req,res) {
//返回一个字符串
res.send(“get”+req.url);
});
app.post(“/list”, function (req,res) {
res.send(“post”+req.url);
});
//all就是处理不管是任何方式发送的请求,*为任意路径
app.all(“*”, function (req,res) {
res.send(“Welcome to Express”);
});
//设置端口号
app.listen(8080); - 获取请求的参数
- 获取请求参数
* req.host:返回请求头里取的主机名(不含端口号)
* req.path:返回请求的url的路径名
* req.query:是一个可获取客户端get请求路径参数的对象属性,包含着被解析过的请求参数对象,默认为{}
* req.params:获取路由的parameters - 获取返回的参数
- 4.返回参数
* res.send();返回数据,默认会转为字符串,编码为utf8
* res.sendFile();返回文件
* res.sendStatus();返回状态码 - 例子
- //http://localhost:8080/query?user=tangcaiye
app.get(“/query”, function (req,res) {
res.send(req.query);
});
//http://localhost:8080/article/2/tangcaiye
app.get(“/article/:id/:name”, function (req,res) {
res.send(req.params);
});
app.all(‘/*’, function(req,res){
console.log(req.path);
console.log(req.host);
res.send(“没找到页面”);
});
app.listen(8080); - 中间件
- 概念
- 中间件就是处理HTTP请求的函数,用来完成各种特定的任务,比如检测用户是否登录,分析数据,以及其他在需要最终将数据发送给用户之前完成的任务
* 特点:
* 1.每个中间件都可以控制流程是否继续执行
* 2.每个中间件的req res都是用的同一个对象
* 3.如果出错了,转交错误处理中间件进行处理
* 4.最大的特点是,一个中间件处理完,可以把相应数据再传递给下一个中间件
* 5.如果调用回调函数的next参数表示将请求数据传递给下一个中间件 - 例子:
- //中央发了100快钱
app.use(function (req,res,next) {
req.money = 100;
next();
});
//市政府
app.use(function (req,res,next) {
req.money -= 20;
//如果next传了一个不为null的参数,说明有错,会中止其他中间件并执行错误处理中间件
next(“钱丢了”);
});
//村
app.use(function (req,res,next) {
req.money -= 50;
next();
});
//错误处理中间件
app.use(function (err,req,res,next) {
console.error(err);
res.end(err);
});
app.all(‘/*’, function(req,res){
res.send(“”+req.money);
});
app.listen(8080); - 模板引擎
- 模板引擎-首先需要先安装才能用
* nam install ejs
* 1.指定渲染模板引擎
* app.set(“view engine”,”ejs”);
* 2.设置放模板文件的目录
* add.set(“views”,path.join(__dirname,”/“));
* 3.rander函数,对网页模板进行渲染,在渲染模板时locals可谓其模板传入变量值,在模板中就可以条用所传变量了
* res.rander(view,[local],callback); - 前端代码
- <!DOCTYPE html>
<html lang=“en”>
<head>
<meta charset=“UTF-8”>
<title>Title</title>
</head>
<body>
姓名:<%=name%><br>
年龄:<%=age%>
哪谁的年龄也是:<%=age%>岁
</body>
</html> - 服务器端代码
- app.set(“view engine”,”ejs”);
app.set(“views”,__dirname);//放在当前目录下
app.get(“/“, function (req,res) {
//默认模板文件后缀格式是pjs
res.render(“muban”,{
name:”tangcaiye”,
age:18
});
}); - cookie
- 安装cookie-parser模块
- npm install cookie-parser
- 代码
- var express = require(“express”);
var cookieParser = require(“cookie-parser”);
var app = express();
app.use(cookieParser());
app.get(“/“, function (req,res) {
//如果请求中cookie存在visited,则输出cookie
//否则,设置cookie字段visited,并设置过期时间
if (req.cookies.visited){
res.send(“已访问过”);
}else {
res.cookie(“visited”,”1”,{maxAge: 10*60*1000});
res.send(“第一次访问”);
}
});
app.listen(8080); - 参数说明
- expires:cookie的过期时间,GMT格式。如果没有指定或者设置为0,则产生新的cookie。
- maxAge:是设置过去时间的方便选项,其为过期时间到当前时间的毫秒值。
- api网址:
- https://www.zybuluo.com/XiangZhou/note/208532
nodejs(三)上之express
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。