Node 搭建服务器
- 概述 :
Node 搭建服务器:开启一个本地服务器需要 Node.js 中 http 核心模块。
- 基础用法 :
// 1,http 模块提供了搭建本地服务器的 API,首先在项目中引入
let http = require('http')
// 2,利用 http.createServer() 方法得到一个服务器实例
let server = http.createServer()
// 3,给服务器实例绑定 request 的事件处理函数
server.on('request',(req,res) => {
// 当服务器被请求时,会触发请求事件,并传入请求对象和响应对象
res.end('hello world')
})
// 4,绑定监听端口号,开启服务器
server.listen(3000,()=>{
console.log('服务器开启成功,可通过 http://127.0.0.1:3000/ 来获取数据')
})
- 基础语法简单实例 :
let http = require('http')
let server = http.createServer()
server.on('request',(req,res) => {
// 设置请求头,解决中文乱码问题
res.setHeader('Content-Type','text/html; charset=UTF-8')
if(req.url == '/'){
res.end('首页')
}else if(req.url == '/gnxw'){
res.end('国内新闻')
}else if(req.url == '/ylxw'){
res.end('娱乐新闻')
}else{
res.end('404')
}
})
server.listen(3000,()=>{
console.log('服务器开启成功,可通过 http://127.0.0.1:3000 访问')
})
- 服务器基础封装:
封装目标:
- 构造函数能够实例化 app 对象 。
- app.on(url,(req,res)=>{}),可以添加路由的事件(根据请求的路径去执行不同的内容)。
- app.run(port,callback),让服务器运行起来 。
let http = require('http')
let path = require('url')
class App {
constructor(){
this.server = http.createServer()
this.reqEvent = {}
this.server.on('request',(req,res) => {
// 解析路径
let pathObj = path.parse(req.url)
if(pathObj.path in this.reqEvent){
this.reqEvent[pathObj.path](req,res)
}else{
res.setHeader('content-type','text/html;charset=utf-8')
res.end('<h4>404页面找不到</h4>')
}
})
}
on(url,fn){
this.reqEvent[url] = fn
}
run(port,callback){
this.server.listen(port,callback)
}
}
module.exports = App
- 封装的服务器使用实例:
let App = require('./index')
let app = new App()
app.on('/',(req,res) => {
res.setHeader('content-type','text/html;charset=utf-8')
res.end('<h4>---这是首页内容---</h4>')
})
app.on('/gnxw',(req,res) => {
res.setHeader('content-type','text/html;charset=utf-8')
res.end('<h4>===这是国内新闻内容===</h4>')
})
app.on('/usa',(req,res) => {
res.setHeader('content-type','text/html;charset=utf-8')
res.end('<h4>,,,这是美国新闻内容,,,</h4>')
})
app.run(80,() => {
console.log('服务器启动成功,可通过 http://127.0.0.1 进行访问')
})
总结: 这里对于服务器的封装只是自己简单实现基础,有很多封装好的各种框架如 Express,koa.js 等,可以去学习了解在项目中使用。