node怎么根据url读取对应文件

我们需要根据不同的url请求相同页面这时我们可以试试下面方式:

第一我们要引入需要的模块

// 引入服务器模块
const http = require('http')
    // 引入fs模块
const fs = require('fs')
    // 引入path模块
const path = require('path')

之后根据文件的实际存放路径,作为每个资源的请求url地址具体代码如下:

// 创建服务器
const server = http.createServer()
    // 监听服务器事件
server.on('request', (req, res) => {
    // 获取请求的url地址
    const url = req.url
    console.log('当前的url是 ' + url);

    // 把请求的url地址映射为具体的文件存放路径 但是这样太“死板”我们需要优化一下
    // const fpath = path.join(__dirname, url)
    // 代码优化
    let fpath = ''
    if (url == '/') {
        // 由于刚进入或者用户输入'/'一般也是主页 所以我们要拼接一下
        fpath = path.join(__dirname, './code/index.html')
    } else {
        fpath = path.join(__dirname, './code', url)
    }

    // 读取文件 把获得的url地址作为读取文件的实时路径
    fs.readFile(fpath, 'utf-8', (err, dataStr) => {
        //    错误返回404
        if (err) {
            return res.end('404 Not found!')
        }
        // 成功返回数据
        res.end(dataStr)
        console.log(dataStr);
    })
})
server.listen(80, () => {
    console.log('地址为 http://127.0.0.1');
})

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值