一、什么是Express?
Express是基于Node.js平台,快捷、开放、极简的Web开发框架,通俗的来讲,Express的作用和Node.js内置的http模块类似,是专门用来创建Web服务器的。
Express的本质:就是一个npm上的第三方包,提供了快速创建Web服务器的便捷方法。
Express的中文官网:http://www.expressjs.com.cn/
二、安装Express
在项目所处的目录中,运行以下终端命令,即可将Express安装到项目中使用:
npm i express@版本号
三、Express的基本使用
1.创建基本的Web服务器
// 导入express
const express = require('express')
// 创建web服务器
const app = express()
// 调用app.listen(端口号,启动成功后的回调函数),启动服务器
app.listen(80,()=>{
console.log('启动express')
})
2.监听GET请求
通过app.get()方法,可以监听客户端的GET请求
// 参数1:客户端请求的url地址
// 参数2:请求对应的处理函数
// req:请求对象(包含了与请求相关的属性和方法)
// res:响应对象(包含了与响应相关的属性和方法)
app.get('请求url',function(req,res){
console.log(req)
console.log(res)
})
3.监听POST请求
通过app.post()方法,可以监听客户端的POST请求
// 参数1:客户端请求的url地址
// 参数2:请求对应的处理函数
// req:请求对象(包含了与请求相关的属性和方法)
// res:响应对象(包含了与响应相关的属性和方法)
app.post('请求url',function(req,res){
console.log(req)
console.log(res)
})
4.把内容响应给客户端
通过res.send()方法,可以处理好的内容发送给客户端
app.get('/user',(req,res)=>{
res.send('get')
})
app.post('/user',(req,res)=>{
res.send('post')
})
5.获取URL中携带的查询参数
通过req.query对象,可以访问到客户端通过查询字符串的形式,发送到服务器的参数
app.get('/',(req,res)=>{
// req.query默认是一个空对象
// 客户端使用?name=zs&&age=20这种查询字符串形式发送到服务器的参数
// 可以通过req.query对象访问到,例如:
// req.query.name req.query.age
console.log(req.query )
})
6.获取URL中的动态参数
通过req.params对象,可以访问到URL中通过:匹配到的动态参数
// URL地址中,可以通过:参数名的形式匹配动态参数值
app.get('/user/:id',(req,res)=>{
// req.params默认是一个空对象
// 里面存放着通过:动态匹配到的参数值
console.log(req.params)
})
7.托管静态资源
express.static():通过此函数,我们可以非常方便的创建一个静态资源服务器,例如,通过以下代码就可以将public目录下的图片、css文件,js文件对外开放访问。如果需要托管多个静态资源目录,则多次调用次函数。
// 访问public目录下的index.html文件方法:
app.use(express.static('./public'))
// 访问路径例如:http://127.0.0.1/index.html
app.user('./abc',express.static('./public'))
// 访问路径例如:http://127.0.0.1/abc/index.html
8.模块化路由
步骤:
1.创建路由模块对应的js文件
2.调用express.Router()函数创建路由对象
3.向路由对象上挂载具体的路由
4.使用module.exports向外共享路由对象
5.使用app.use()函数注册路由模块
- app.use()的作用是用来注册全局的中间件
添加路由前缀:
// router为上文件暴露出来的/user/list
app.use(router)
// 访问路径为:http://127.0.0.1/user/list
app.use('api',router)
// 访问路径为:http://127.0.0.1/api/user/list