从0到1学习node.js(http模块)

一、使用node.js构建后台服务
1、使用node.js创建一个HTTP服务
javascript 复制代码
// 1.导入 http模块
const http = require('http')

// 2.创建服务对象 两个参数,第一个请求体,第二个响应体
const server = http.createServer((request, response) => {
    response.end('Hello HTTP server') // 响应并结束
})

// 监听端口
server.listen(9000, () => {
    console.log('服务启动成功...')
})
2、服务中提取HTTP请求报文
含义 语法
请求方法 request.method
请求版本 request.httpVersion
请求路径 request.url
请求头 request.headers
请求体
javascript 复制代码
// 1.导入 http模块
const http = require('http')

// 2.创建服务对象 两个参数,第一个请求体,第二个相应体
const server = http.createServer((request, response) => {
    // 获取请求的方法
    console.log(request.method)
    // 获取请求的url
    console.log(request.url) // 只包含路径和字符串
    // 获取HTTP协议版本号
    console.log(request.httpVersion)
    // 获取请求头
    console.log(request.headers)
    response.end(request.method)
})

// 监听端口
server.listen(9000, () =>{
    console.log('服务启动成功..')
})
3、设置HTTP响应报文
javascript 复制代码
response.statusCode = 200 // 设置返回状态码
response.statusMessage = '123' // 设置返回消息体 几乎不用
response.setHeader('content-type','text/html;charset=utf-8')// 设置MIME类型
response.end() // 返回响应体,有切只有一个!必须有一个
4、一个小练习,返回一个html文件
javascript 复制代码
const http = require('http')
const fs = require('fs')

const server = http.createServer((request, response) => {
    response.setHeader('content-type', 'text/html;charset=utf-8')
    fs.readFile(__dirname + '/index.html', (err, data) => {
        if (err) {
            console.log('读取失败')
            return
        }
        response.end(data)
    })
})

server.listen(9000, () => {
    console.log('服务器启动完毕...')
})
5、设置响应资源的MIME类型
javascript 复制代码
常见的文件对应的mime类型
html:'text/html'
js:'text/javaScript'
css:'text/css'
png:'image/png'
jpg:'image/jpg'
gif:'image/gif'
mp4:'video/mp'
mp3:'audio/mpeg'
json:'application/json'
如果都不是,就返回application/octet-stream 类型
浏览器在遇到该类型的时候会对响应体内容进行独立存储,也就是我们常见的下载效果
6、绝对路径
路径 用法
http://www.baidu.com/aaa 完整路径
//www.baidu.com/aaa 省略协议
/aaa 全部省略就会默认自动的使用当前项目的路径
7、相对路径

相对路径在发送请求时,需要与当前页面的URL路径进行计算,得到完整URL后再发送请求, 例如当前的路径是https://www.baidu.com/sourse/index.html

形式 最终的URL
./css/app.css https://www.baidu.com/sourse/css/app.css 当前目录
js/app.js https://www.baidu.com/sourse/js/app.js 当前目录
.../img/logo.png https://www.baidu.com/img/logo.png 上一级目录
.../.../mp4/show.mp4 https://www.baidu.com/mp4/show.mp4 上一级目录的上一级,但是现在只有一层,所以就是上一级目录。
相关推荐
whoarethenext39 分钟前
C++ OpenCV 学习路线图
c++·opencv·学习
恰薯条的屑海鸥1 小时前
零基础在实践中学习网络安全-皮卡丘靶场(第十四期-XXE模块)
网络·学习·安全·web安全·渗透测试
Lester_11011 小时前
嵌入式学习笔记 - freeRTOS vTaskPlaceOnEventList()函数解析
笔记·学习
moxiaoran57533 小时前
uni-app学习笔记二十三--交互反馈showToast用法
笔记·学习·uni-app
恰薯条的屑海鸥10 小时前
零基础在实践中学习网络安全-皮卡丘靶场(第十六期-SSRF模块)
数据库·学习·安全·web安全·渗透测试·网络安全学习
喜欢吃燃面10 小时前
C++刷题:日期模拟(1)
c++·学习·算法
2301_7976042411 小时前
学习记录:DAY32
学习
玩转4G物联网12 小时前
零基础玩转物联网-串口转以太网模块如何快速实现与TCP服务器通信
服务器·网络·物联网·网络协议·tcp/ip·http·fs100p
蓝婷儿12 小时前
6个月Python学习计划 Day 16 - 面向对象编程(OOP)基础
开发语言·python·学习
叶子20242212 小时前
学习使用YOLO的predict函数使用
人工智能·学习·yolo