express浅入浅出

01express基本使用

// 创建一个express实例
require("./hehe");
const express = require("express")
const app = express();//创建一个express应用
// app实际上是一个函数,用于处理函数请求
// 配置一个请求映射,如果请求方法和请求路径均匹配满足,交给处理函数进行处理
// app.请求方法(“请求路径”,处理函数)
app.get("/abc",(req,res) => {
    //req和res是被express封装过后的对象
    console.log(req.header["host"])
    
    // 响应
// res.send("<h1>你好啊</h1>")
// res.status(302).header("location","https://www.baidu.com").end()
res.status(302).location("https://duyi.ke.qq.com").end();
// 直接重定向
res.redirect(302,"https://duyi.ke.qq.com")
})

//匹配任何get请求
app.get("*",(req,res) => {
    console.log('abc')
})

const port = 9527;
// const server = http.createServer(app)
app.listen(9527, ()=>{
    console.log(`object listen on ${port}`)
})

//逻辑没有分开

4-02nodemon

安装:npm i -D nodemon
在package.json中修改:

 "start": "nodemon -x npm run server",
   "server":"node index"

运行:npm start
配置nodemon.son

{
    "env":{
        "NODE_ENV":"development"

    },
    "watch":["*.js","*.json"],
    "ignore":["package*.json","nodemon.json","node_modules"]
}

03express中间件

中间件:就是一个个处理函数,当匹配到了请求后,交给第一个处理函数处理;函数中需要手动处理的交给后续中间件处理。
中间件处理的细节:如果后续没有中间件,express发现如果响应没有结束,express会响应404,如果中间件发生了错误,不会停止服务器,相当于调用了next(错误对象)会寻找后续的错误处理中间件,如果没有后续处理的则响应(500,/服务器内部错误)

/ 处理错误的中间件
module.exports = (err,req,res,next) => {
    // 发生了错误
    if(err){
        const errObj = {
            code:500,
            msg:err instanceof Error ? err.message : err,
        }
        // 发生了错误
        res.status(500).send(errObj)
}else{
    next();

}}
const express = require("express");
const app = express();
app.get(
    (req,res,next) => {
        console.log("handler1");
        // res.status(200);
        // res.end();
        // next();
        next(new Error("abc"))
    },
   
    (err,req,res,next) => {
        console.log("handler2");
        // res.status(200);
        res.send("服务器发生了错误");
        next();
    },
    require("./err")

);
app.get("/news",(req,res,next) => {
    console.log("handler3");
    next();
})
app.use("/news",require("./err"))

const port = 5009;
app.listen(port,() => {
    console.log(`server listen on ${port}`);
});

04express常用中间件

访问静态资源
①express.static

const express = require("express")
const app = express();

const path = require("path")
const staticPoot = path.resolve(__dirname,"../public")
//当请求时,会根据请求的路径从指定的目录中寻找是否存在该文件如果存在,直接影响文件内容。不交给后面的中间件,如果不存在,移交给后面的中间件。
//默认情况下,如果映射的结果是一个目录则会自动找index.html是否存在
app.use(express.static(staticPoot))
// app.use(require("./err"));

const port = 5000;
app.listen(port,() => {
    console.log(`server listen on ${port}`)
})

//当你消息请求的类型是application。。。 会以流的形式
app.use(express.urlencoded({
    extended:true
}))

app.use(express.json())

app.post("api/student",(req,res) => {
    console.log(req.body)
})

05 express路由

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值