Node.js路由知识

Node.js路由知识

什么是路由?

用大白话说,当用户访问http://example.com是一个页面,但是例如http://example.com/123,那么服务器应该调用什么函数才给用户返回这个123的页面信息呢?这个就是路由的事情了,如果没有路由,不关你的页面是什么样子的,都会返回同样的信息;但是有了路由我们就可以根据不同路径和方法来执行不同的逻辑了;

Node.js路由基础

在现实世界中,我们大多数都会用express来实现我们的路由,因为会更加简单,更加清晰,这里我们仅仅演示原生Node.js的路由,后续会一起学习express的路由

  • 回忆一下之前的代码
vue 复制代码
const http = require('http');
const server = http.createServer((request,response) => {
    response.writeHead(200,{'Content-type':'text/html;charset=utf-8'})
    response.end('Hello!,这是我的第一个Node.js服务器')
})

server.listen(8000,'127.0.0.1',()=>{
    console.log('服务器正在运行,访问地址:http://127.0.0.1:8000');
})
  • 这里首先我们将引入url,我们看这个会返回什么
vue 复制代码
const http = require('http');
const url = require('url')
const server = http.createServer((request,response) => {
    console.log(request.url)
......

这里直接返回了我们的路径

  • 所以我们就可以使用if/else手写一个路由表
vue 复制代码
const server = http.createServer((request,response) => {
    console.log(request.url)
    const pathName = request.url;
    const chatset = {'Content-type':'text/html;charset=utf-8'}
    if(pathName === '/' || pathName === '/overview'){
        response.writeHead(200,chatset);
        response.end('这个是主页');
    }

这个响应大家都能看懂,很坚韧,status.Code就是http的状态码

  • 所以我们也可以加入产品页啥的
javascript 复制代码
    const pathName = request.url;
    const chatset = {'Content-type':'text/html;charset=utf-8'}
    if(pathName === '/' || pathName === '/overview'){
        response.writeHead(200,chatset);
        response.end('这个是主页');
    } else if(pathName === '/product'){
        response.writeHead(200,chatset);
        response.end('这个是产品页');
    }
  • 但是还有一个问题,例如我们输入一个并不再我们规则里面的,他会一直转圈等待,这时候,一般情况下都是由一个特殊的404页面,只要是找不到页面的都会规则到这个页面
vue 复制代码
const server = http.createServer((request,response) => {
    console.log(request.url)
    const pathName = request.url;
    const chatset = {'Content-type':'text/html;charset=utf-8'}
    if(pathName === '/' || pathName === '/overview'){
        response.writeHead(200,chatset);
        response.end('这个是主页');
    } else if(pathName === '/product'){
        response.writeHead(200,chatset);
        response.end('这个是产品页');
    } else {
        response.writeHead(404,chatset);
        response.end('页面不存在!')
    }
})

缺点 :手动解析URL、参数、方法,代码很快变得臃肿。对于动态路径(如/users/123)需要正则或字符串分割,不适合生产环境。

相关推荐
KevinCyao2 小时前
node.js彩信接口如何集成?使用Node.js异步流模式发送多图片彩信
node.js
__zRainy__2 小时前
patch-package 打补丁方案详解
npm·node.js
hashiqimiya2 小时前
npm查看依赖
前端·npm·node.js
San302 小时前
从浏览器到 Node.js,这一次彻底搞懂 Event Loop 与异步模型
面试·node.js·浏览器
Bacon2 小时前
CDP、Puppeteer 与无头浏览器:它们到底什么关系?
前端·javascript·node.js
像我这样帅的人丶你还3 小时前
🔥🔥🔥Next + Tiptap + Yjs + Hocuspocus实现文档协同
前端·node.js
__zRainy__4 小时前
Node.js 日志选型指南:Winston vs Log4js 全方位对比与实战
node.js·log4j·winston
木木爱研究18 小时前
elpis 全栈里程碑一总结
node.js
夏暖冬凉19 小时前
npm发布流程(记录遇到的问题)
前端·npm·node.js