http模块

1.创建最基本的服务器

①导入http模块
②创建web服务器实例
③为服务器实例绑定request事件,监听客户端的请求
④启动服务器

//1.导入http模块
const http=require('http')
//2.创建web服务器实例
const server=http.createServer()
//3.为服务器实例绑定request事件,监听客户端的请求
server.on('request',function(req,res){
    //req是请求对象,它包含了与客户端相关的数据和属性,例如:
    //req.url是客户端请求的URL地址
    //req.method是客户端的method请求类型
    const str='Your request url is ${req.url},and request method is ${req.method}'
    console.log(str)

    //调用res.end()方法,向客户端响应一些内容
    //res.end(str)

    //当调用res.end()方法,向客户端发送中文内容的时候,会出现乱码问题,需要手动设置内容的编码格式
    //为了防止中文显示乱码问题,需设置响应头Content-Type的值为text/html;charset=utf-8
    res.setHeader('Content-Type','text/html;charset=utf-8')
    res.end(str)

    console.log('Someone visit our web server')
})
//4.启动服务器
server.listen(8080,function(){
    console.log('serve running at http://127.0.0.1:8080')
})

2.根据不同的url响应不同的html内容

①获取请求的url地址
②设置默认的响应内容为404 Not Found
③判断用户的请求是否为/或/index.html首页
④判断用户的请求是否为/about.html关于页面
⑤设置Content-Type响应头,防止中文乱码
⑥使用res.end()把内容响应给客户端

const http=require('http')
const server=http.createServer()

server.on('request',function(req,res){
    //1.获取请求的url地址
    const url=req.url
    //2.设置默认的内容为404 Not found
    let content='<h1>404 Not found!</h1>'
    if(url==='/'||url==='/index.html'){
        content='<h1>首页</h1>'//3.用户请求的是首页
    }else if(url==='/about.html'){
        content='<h1>关于页面</h1>'//4.用户请求的是关于页面
    }
    res.setHeader('Content-Type','text/html;charset=utf-8')//5.设置Content-Type响应头,防止中文乱码
    res.end(content)//6.把请求发送到客户端
})

server.listen(8080,function(){
    console.log('serve running at http://127.0.0.1:8080')
})

3.实现clock时钟的web服务器

①导入需要的模块
②创建基本的web服务器
③将资源的请求url地址映射为文件的存放路径
④读取文件内容并响应给客户端
⑤优化资源的请求路径

//1.导入需要的模块
const http=require('http')
const fs=require('fs')
const path=require('path')

//2.1创建web服务器
const server=http.createServer()
//2.2监听web服务器的request事件
server.on('request',function(req,res){
   //3.1获取到客户端请求的url地址
      ///clock/index.html
   const url=req.url
   //3.2把请求的url地址,映射为本地文件的存放路径,预定义空白的文件存放路径
   let fpath=''
   if(url==='/'){
       //5.2如果请求的路径是否为/,则手动指定文件的存放路径
       fpath=path.join(__dirname,'./clock/index.html')
   }else{
       //5.3如果请求的路径不为/,则动态拼接文件的存放路径
       fpath=path.join(__dirname,'./clock',url)
   }

   //4.1根据“映射”过来的文件路径读取文件的内容
   fs.readFile(fpath,'utf-8',(err,dataStr)=>{
       //4.2读取失败,向客户端响应固定的“错误消息”
       if(err) return res.end('404 Not found')
       //4.3读取成功,将读取成功的内容,响应给客户端
       res.end(dataStr)
   })
})
//2.3启动web服务器
server.listen(80,function(){
    console.log('server listen at http://127.0.0.1')
})

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值