Node.js 学习笔记 express框架

express

  • express 使用
    • express下载
    • express 初体验
  • express 路由
    • 什么是路由
    • 1路由的使用
      • 验证的方法
    • 2获取请求报文参数
    • 3获取路由参数
    • 4响应设置
      • 响应报文
  • express 中间件
    • 5中间件
      • 全局中间件
      • 路由中间件
    • 6静态资源中间件
      • 注意事项
      • 案例
    • 7请求体数据
    • 8防盗链
      • 实现防盗链
    • 9路由模块化
      • router
  • EJS 模板引擎
    • 初体验
    • EJS 常用语法
  • express-generator

尚硅谷node-express视频学习笔记

express 使用

express 是一个基于 Node.js 平台的极简、灵活的 WEB 应用开发框架,官方网址:https://www.expressjs.
com.cn/
简单来说,express 是一个封装好的工具包,封装了很多功能,便于我们开发 WEB 应用(HTTP 服务)

express下载

express 本身是一个 npm 包,所以可以通过 npm 安装

npm init
npm i express

express 初体验

  1. 创建 JS 文件,键入如下代码
//1. 导入 express
const express = require('express');//2. 创建应用对象
const app = express();//3. 创建路由规则
app.get('/home', (req, res) => {
res.end('hello express server');
});//4. 监听端口 启动服务
app.listen(3000, () =>{
console.log('服务已经启动, 端口监听为 3000...');
});
  1. 命令行下执行该脚本
node <文件名>
# 或者
nodemon <文件名>
  1. 然后在浏览器就可以访问 http://127.0.0.1:3000/home

express 路由

什么是路由

官方定义: 路由确定了应用程序如何响应客户端对特定端点的请求

1路由的使用

一个路由的组成有 请求方法 , 路径 和 回调函数 组成

express 中提供了一系列方法,可以很方便的使用路由,使用格式如下:

app.<method>(path,callback)
  • 代码示例
//导入 express
const express = require('express');//创建应用对象
const app = express();//创建 get 路由
app.get('/home', (req, res) => {
res.send('网站首页');
});//首页路由
app.get('/', (req,res) => {
res.send('我才是真正的首页');
});//创建 post 路由
app.post('/login', (req, res) => {
res.send('登录成功');
});//匹配所有的请求方法 不管是get还是post及其他
app.all('/search', (req, res) => {
res.send('1 秒钟为您找到相关结果约 100,000,000 个');
});//自定义 404 路由
app.all("*", (req, res) => {
res.send('<h1>404 Not Found</h1>')
});app.listen(3000,()=>{console.log('服务已经启动, 端口监听为 3000...');
})

验证的方法

① 浏览器输入 http://localhost:3000/home

可以验证get请求

② form表单

可以验证post请求
在这里插入图片描述

这里不涉及跨域问题,因为form没有使用ajax请求

2获取请求报文参数

express 框架封装了一些 API 来方便获取请求报文中的数据,并且兼容原生 HTTP 模块的获取方式

原生的HTTP模块的方法 method、url、httpVersion、headers

Express独有的方法path、query、ip、get

//导入 express
const express = require('express');//创建应用对象
const app = express();//获取请求的路由规则
app.get('/request', (req, res) => {//1. 获取报文的方式与原生 HTTP 获取方式是兼容的
console.log(req.method); //请求方法
console.log(req.url);//如果请求是http://localhost:3000/home 打印/home
console.log(req.httpVersion);
console.log(req.headers); //请求头//2. express 独有的获取报文的方式
console.log(req.path);//如果请求是http://localhost:3000/home 打印/home
console.log(req.query); //获取查询字符串 『相对重要』
console.log(req.ip);客户端ip
console.log(req.get('host')); // 获取指定的请求头
res.send('请求报文的获取');
});
//启动服务
app.listen(3000, () => {
console.log('启动成功....')
})

3获取路由参数

req.params.XXXXX

路由参数指的是 URL 路径中的参数(数据)

在这里插入图片描述

0240514111354211.png&pos_id=img-jDlrJAey-1715677072203)

服务端会根据路径中的数字返回不同的商品

  • 示例
//路由参数
app.get('/10003.html',(req,res)=>{res.setHeader('content-type', 'text/html;charset=utf-8') //不乱码res.end('商品详情')
})
  • 问题是商品不止一个,通过/:id.html通配符一起配置
//路由参数
app.get('/:id.html',(req,res)=>{console.log(req.params.id) //这个id和上面id保持一致res.setHeader('content-type', 'text/html;charset=utf-8') //不乱码res.end('商品详情')
})

4响应设置

express 框架封装了一些 API 来方便给客户端响应数据,并且兼容原生 HTTP 模块的获取方式

//获取请求的路由规则
app.get("/response", (req, res) => {//1. express 中设置响应的方式兼容 HTTP 模块的方式res.statusCode = 404;res.statusMessage = 'xxx';res.setHeader('abc','xyz');res.write('响应体');res.end('xxx');//2. express 的响应方法res.status(500); //设置响应状态码res.set('xxx','yyy');//设置响应头res.send('中文响应不乱码');//设置响应体//连贯操作res.status(404).set('xxx','yyy').send('你好朋友')//3. 其他响应res.redirect('http://atguigu.com') // 跳转响应 重定向res.download(__dirname+'./package.json');//下载响应res.json();//响应 JSONres.sendFile(__dirname + '/home.html') //响应文件内容});

响应报文

在这里插入图片描述

  • 相应报文的组成

server:BWS/1.1记录了服务器所属的技术;content-type 记录了与响应body相关的一些内容,声明响应体的内容的格式与字符集。content-length记录了响应体内容的长度,单位是字节。

express 中间件

5中间件

什么是中间件

中间件(Middleware)本质是一个回调函数

中间件函数 可以像路由回调一样访问 请求对象(request) , 响应对象(response)

中间件的作用

中间件的作用 就是 使用函数封装公共操作,简化代码

中间件的类型

全局中间件

路由中间件

全局中间件

每一个请求 到达服务端之后 都会执行全局中间件函数。区别路由中间件,只有匹配到某一个路由才会访问路由中间件。

//中间件函数
let recordMiddleware = function(req,res,next){//实现功能代码let {url, ip} = req fs.appendFileSync(path.resolve(__dirname, './access.log'), `${url}, ${ip}\r\n`)//执行next函数(当如果希望执行完中间件函数之后,仍然继续执行路由中的回调函数,必须调用next)next();
}//使用中间件
app.use(recordMiddleware)

路由中间件

如果 只需要对某一些路由进行功能封装 ,则就需要路由中间件

在这里插入图片描述

6静态资源中间件

静态资源:内容长时间不发生改变的资源 CSS JS 图片

静态资源目录/也是网站根目录:浏览器把请求发送到服务端之后,服务端到哪个目录下找文件,哪个目录就是网站根目录。

const express = require('express')const app = express()//静态资源中间件设置
app.use(express.static(__dirname+'/public'))app.get('/home',(req,res)=>{// console.log(req.url);res.end('home')
})app.listen(3000,()=>{console.log('服务已经启动, 端口监听为 3000...');
})

在网址中输入http://localhost:3000/10_test.html

在这里插入图片描述

注意事项

  1. index.html 文件为默认打开的资源。

    http://localhost:3000/index.html简写为http://localhost:3000

  2. 如果静态资源与路由规则同时匹配,谁先匹配谁就响应

    路由规则的意思是app.get(‘/’,(req,res)=>{…})

    看这一句话和app.use的上下位置

  3. 路由响应动态资源,静态资源中间件响应静态资源

案例

7请求体数据

第一步:安装 npm i body-parser

第二步:导入 body-parser 包const bodyParser = require('body-parser');

第三步:获取中间件函数

请求体有两种格式。

//处理 querystring 格式的请求体
let urlParser = bodyParser.urlencoded({extended:false}));//处理 JSON 格式的请求体
let jsonParser = bodyParser.json();

第四步:设置路由中间件,然后使用 request.body 来获取请求体数据

app.post('/login', urlParser, (request,response)=>{
//获取请求体数据
//console.log(request.body);
//用户名
console.log(request.body.username);
//密码
console.log(request.body.userpass);
response.send('获取请求体数据');
});

获取到的请求体数据:

[Object: null prototype] { username: 'admin', userpass: '123456' }

  • 代码

用form表单发送post请求

  <form action="http://127.0.0.1:3000/login" method="post">用户名 <input type="text" name="username"><br>密码 <input type="password" name="password"> <br><button>登录</button></form>

node.js

const express = require('express')
const app = express()
//引入中间件
const bodyParser = require('body-parser')
let urlParser = bodyParser.urlencoded({extended:false})//客户端请求login界面的时候,把写好的11_form.html发给它
app.get('/login',(req,res)=>{res.sendFile(__dirname+'/11_form.html')
})//客户端在login界面提交表单的时候,服务端接收
//利用中间件,body-parser,路由中间件处理之后,req身上会多出一个body参数
app.post('/login',urlParser,(req,res)=>{console.log('123');console.log(req.body);res.send('获取用户数据')
})app.listen(3000,()=>{console.log('服务已经启动, 端口监听为 3000...');
})

8防盗链

禁止该域名之外的其他网站请求资源

网站通过报文请求头中的referer判断,如果不是相同域名,就会拒绝访问

实现防盗链

利用中间件

//导入 express
const express = require('express');//创建应用对象
const app = express();//声明中间件
app.use((req, res, next) => {//检测请求头中的 referer 是否为 127.0.0.1//获取 refererlet referer = req.get('referer');if(referer){//referer是完整的网站,这一不是为了提取出中间不同的部分let url = new URL(referer);//实例化let hostname = url.hostname;//获取 hostname//判断if(hostname !== '127.0.0.1'){//响应 404 res.status(404).send('<h1>404 Not Found</h1>');return;}}next();
});//静态资源中间件设置
app.use(express.static(__dirname + '/public'));//监听端口, 启动服务
app.listen(3000, () => {console.log('服务已经启动, 端口 3000 正在监听中....')
})

注意这里静态资源目录(根目录)

在这里插入图片描述

图片的src是有网址的

9路由模块化

上面是前台路由(展示数据),下面是后台路由(管理员查看)

在这里插入图片描述

router

借助到router

router: express 中的 Router 是一个完整的中间件和路由系统,可以看做是一个小型的 app 对象。

  • 拆分出前台路由:

在这里插入图片描述

EJS 模板引擎

模板引擎】:模板引擎是分离 用户界面和业务数据 的一种技术。

简单理解就是分离HTML和JS的,JS指的是服务端的JS

【EJS】:EJS 是一个高效的 Javascript 的模板引擎

官网: https://ejs.co/ 中文站:https://ejs.bootcss.com/

初体验

  • 下载安装EJS

npm i ejs --save

补充知识:npm下载的时候会向外寻找,所以只要是在同一个大文件中,不管在哪个小路径,npm i统一下载到一个地方。

  • 代码示例
//1.引入ejs
const ejs = require('ejs');
//2.定义数据
let person = ['张三','李四','王二麻子'];
//3.ejs解析模板返回结构
//<%= %> 是ejs解析内容的标记,作用是输出当前表达式的执行结构
let res = ejs.render(<%= person.join(",") %>, {person:person});
//4.输出结果
console.log(res);//案例2
let china = '中国'
let res2 = ejs.render('我爱你 <%= china %>', {china:china})
  • 具体项目中使用

找到 <%= %>标识符,把后面的输入填入

在这里插入图片描述

EJS 常用语法

执行JS代码 <% code %>

输出转义的数据到模板上 <%= code %>

输出非转义的数据到模板上 <%- code %>

express-generator

  • npm i -g express-generator
  • express -e 15_generator: -e:添加EJS支持,目标文件夹

在这里插入图片描述

  • npm i 安装依赖

  • npm start 运行项目

其实入口文件是 bin/www

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/12080.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java——类和对象第二节——封装

1.什么是封装 封装是面向对象程序的三大特性之一&#xff0c;面向对象程序的三大特性分别是封装&#xff0c;继承&#xff0c;多态 而封装简单来说就是套壳隐藏细节 打个比方&#xff1a; 在一些电脑厂商生产电脑时&#xff0c;仅对用户提供开关机键&#xff0c;键盘输入&a…

瑞友科技质量改进服务事业部总经理张力受邀为第十三届中国PMO大会演讲嘉宾

全国PMO专业人士年度盛会 北京瑞友科技股份有限公司质量改进服务事业部总经理张力先生受邀为PMO评论主办的2024第十三届中国PMO大会演讲嘉宾&#xff0c;演讲议题为“PMO如何对接战略成为企业IT投资成功的有效保障”。大会将于6月29-30日在北京举办&#xff0c;敬请关注&#x…

一个不知名的开源项目可以带来多少收入

起源 2020 年新冠疫情开始蔓延&#xff0c;当时我在同时经营 3 个不同的公司。除了其中的体育赛事平台因为疫情关门大吉之外&#xff0c;另外两个公司并没有受影响&#xff0c;营收和利润反而都持续增加。但是连续几个月不能出远门&#xff0c;也不能随便见朋友和客户&#xff…

软件测试到了35岁,真的就干不动了吗?

摘要&#xff1a;随着年龄的增长&#xff0c;很多人担心软件测试岗位是否存在技术瓶颈。本文将从零到一&#xff0c;详细且规范地探讨软件测试岗位在35岁后的发展前景&#xff0c;并提供一些建议以应对可能的挑战。 引言&#xff1a;软件测试作为软件开发生命周期中至关重要的…

基于PySpark进行去哪儿网数据分析

基于PySpark进行去哪儿网数据分析 本文介绍了如何使用PySpark对去哪儿网的数据进行分析&#xff0c;从而洞察用户偏好、热门目的地以及销售趋势。 1.数据加载 我们需要确保已经准备好了PySpark的开发环境&#xff0c;并且准备好了去哪儿网的数据集。可以通过创建SparkSessio…

SpringCloudAlibaba:5.1Sentinel的基本使用

概述 简介 Sentinel是阿里开源的项目&#xff0c;提供了流量控制、熔断降级、系统负载保护等多个维度来保障服务之间的稳定性。 官网 https://sentinelguard.io/zh-cn/ Sentinel的历史 2012 年&#xff0c;Sentinel 诞生&#xff0c;主要功能为入口流量控制。 2013-2017 年…

中北机械有限公司将参加2024长三角快递物流供应链与技术装备展览会

参展企业介绍 浙江中北机械有限公司总部位于浙江杭州&#xff0c;生产基地位于浙江桐乡。是一家有着十几年金属制品及仓储物流设施设备生产经验&#xff0c;专业设计、生产、制造各类物流钢制托盘&#xff0c;物流手推车&#xff0c;仓储货架及门店展架&#xff0c;宣传展架等物…

Pytorch读取自己的数据集

数据集 流程图 导包设置tfs创建datasets.ImageFolder创建torch.utils.data.DataLoader() import time import os from tqdm import tqdm import pandas as pd import numpy as np import torch import torchvision import torch.nn as nn import torch.nn.functional as F im…

7天精通Web APIs——正则阶段案例(理论+实战)(第六天)

正则表达式的定义和使用 定义&#xff1a;是一种匹配模式&#xff0c;用于匹配字符串中字符组合 作用&#xff1a;表单验证&#xff08;匹配&#xff09;、过滤敏感词&#xff08;替换&#xff09;、字符串中提取我们想要的部分&#xff08;提取&#xff09; 使用分为两步&…

KP85321 650V栅极驱动器兼容代替IR2110 中高压高低边驱动解决方案

KP85321是一款中高压半桥 / 高低边驱动芯片系列&#xff0c;以高可靠性、低温漂、大驱动电流 为主要特性&#xff0c;输出开关节点 dv/dt 可达 100V/nS。高低侧通道相互独立&#xff0c;允许同时导通。 关于 中高压半桥 / 高低边驱动芯片&#xff1a; 中高压半桥/高低边驱动芯…

mybatis 跨库查询 mysql

跨库&#xff0c;表关联的查询&#xff0c;实现起来很简单&#xff1a; select a.uid from ucenter.user a , database user_profile b where a.uid b.uid;只要在表的前边加上库名即可。 这个是我项目中xml 中的一个例子&#xff0c;项目采用的是springmvc,持久层框架就是my…

MySQL:MySQL索引结构为什么选用B+树?

一、前言 当我们发现SQL执行很慢的时候&#xff0c;自然而然想到的就是加索引。在MySQL中&#xff0c;无论是Innodb还是MyIsam&#xff0c;都使用了B树作索引结构。我们知道树的分类有很多&#xff0c;MySQL中使用了B树作索引结构&#xff0c;这是为什么呢&#xff1f; 本文将从…

如何用易查分制作扫码签到,支持在线签名,一键导出名单!

学校在开展培训讲座、研讨会等活动会议时&#xff0c;通常都需要参会人在纸质名单上签字表示到场。负责人不仅要耗费大量人力引导签到&#xff0c;如果人数众多&#xff0c;场面混乱&#xff0c;签到效率会十分低下。 易查分能够制作安全、高效的二维码签到系统&#xff0c;参会…

游泳带什么防水耳机好?甄选四大顶尖游泳耳机推荐,最值入手!

在享受游泳的同时&#xff0c;搭配一款优秀的防水耳机&#xff0c;能够让您的游泳体验更加完美。然而&#xff0c;市面上琳琅满目的防水耳机品牌&#xff0c;让人难以选择。作为一名游泳爱好者&#xff0c;我深知选购一款合适的防水耳机的重要性。因此&#xff0c;我自费购买了…

MHD093C-058-PG1-AA具备哪些特点?

MHD093C-058-PG1-AA是一种高性能的伺服电机控制器。 该产品具备以下特点&#xff1a; 高精度与高性能&#xff1a;MHD093C-058-PG1-AA设计用于提供精确的运动控制和定位&#xff0c;适用于需要高精度定位和控制的场合。快速响应&#xff1a;采用先进的控制技术&#xff0c;确…

高血压患者可以吃什么?不可以吃什么?

点击文末领取揿针的视频教程跟直播讲解 随着生活水平的提高&#xff0c;越来越多的人得上了“新四高”——高血压、高血脂、高血糖、高尿酸。 一旦惹上这些慢性病&#xff0c;那就得「管住嘴」了~但究竟什么能吃、什么不能吃&#xff0c;还是有很多人不清楚 高血压患者应该遵…

2024/5/14 英语每日一段

“It is important as it suggests that possibly several populations in the world already started to include substantial amount of plants in their diet” in the period before agriculture was developed, a view contradictory to the popular one, added archeo-ge…

【C#】 SortedDictionary,查找字典中是否存在给定的关键字

欢迎来到《小5讲堂》 这是《C#》系列文章&#xff0c;每篇文章将以博主理解的角度展开讲解。 温馨提示&#xff1a;博主能力有限&#xff0c;理解水平有限&#xff0c;若有不对之处望指正&#xff01; 目录 背景场景说明红黑树原理判断代码Dictionary知识点相关文章 背景 最近…

ICode国际青少年编程竞赛- Python-5级训练场-多参数函数

ICode国际青少年编程竞赛- Python-5级训练场-多参数函数 1、 def go(a, b):Spaceship.step(2)Dev.step(a)Spaceship.step(b)Dev.turnRight()Dev.step(b)Dev.turnLeft()Dev.step(-a) Dev.turnLeft() Dev.step(3) Dev.step(-3) go(3, 2) go(6, 1) go(5, 2) go(4, 3)2、 def go(…