zoukankan      html  css  js  c++  java
  • nodejs(7)练习 http 和 express 创建简单的服务器

    http 

    const http = require('http')
    
    // 创建服务器
    const server = http.createServer()
    
    // 绑定事件,监听客户端的请求
    server.on('request', (req, res) => {
        // 写入响应头,防止中文乱码
        res.writeHeader(200, {
          'Content-Type': 'text/html; charset=utf-8'
        })
      res.end('你好 http 服务器!')
    })
    
    server.listen(3333, () => {
      console.log('http server running at http://127.0.0.1:3333')
    })

    express 

    const express = require('express')
    
    // 创建服务器
    const app = express()
    
    // 监听客户端的请求
    // 只有客户端的请求类型是 get,并且 请求地址是 / 根路径的时候,
    // 才会调用 后面指定的处理函数
    app.get('/', (req, res) => {
      // express 中,封装了更好用的 res.send 方法
      res.send('你好,express 服务器!')
    })
    
    // 监听客户端的post请求,并且请求的地址是 /adduser 的时候,
    // 才会调用后面指定的处理函数
    app.post('/adduser', (req, res) => {
      res.send('服务器处理成功!')
    })
    
    // 启动服务器
    app.listen(4444, () => {
      console.log('express server running at http://127.0.0.1:4444')
    })

    在express框架中获取客户端提交的表单数据

    const express = require('express')
    const qs = require('querystring')
    
    const app = express()
    
    // 监听客户端的 post 请求,且请求地址为 /adduser 的时候,会调用指定的处理函数
    app.post('/adduser', (req, res) => {
      // 注意:客户端提交到服务器的数据,都保存到了 req 请求对象中
      // 只要客户端向服务器通过post方式,提交了表单,那么 就会触发 req 的 data 事件
      // 只要安装一个 第三方的npm包,名字叫做 body-parser, 并进行简单配置,就能够直接使用 req.body获取到表单数据了
      let str = ''
      req.on('data', chunk => {
        // 把每次得到的分片数据,拼接到 str 字符串中
        // 如果 字符串 和 Buffer 数据进行拼接,得到结果,是字符串
        str += chunk
        // 思考:只要触发了 data,就证明有数据发送到服务器了,但是,什么时候,就证明数据已经发送和接收完毕了呢???
      })
    
      // 通过监听 req 的 end 事件,就能够直到数据已经发送完毕了,服务器也已经接收到了完整的数据!
      req.on('end', () => {
        // console.log(str)
        // 对数据进行 URL 解码操作
        // const strDecode = decodeURI(str)
        // console.log(strDecode)
        const result = qs.parse(str)
        // 使用 express 的 send 方法,向客户端发送 对象
        res.send(result)
      })
    
      // res.send('添加用户成功!')
    })
    
    app.listen(4444, () => {
      console.log('express server running at http://127.0.0.1:4444')
    })

     使用body-parser包解析表单数据

    安包:npm install body-parser -S

    const express = require('express')
    // 1. 导入 解析表单数据的包
    const bodyParser = require('body-parser')
    
    const app = express()
    // 2. 配置一下
    app.use(bodyParser.urlencoded({ extended: false }))
    
    app.post('/adduser', (req, res) => {
      console.log(req.body)
      res.send('ok')
    })
    
    app.listen(4444, () => {
      console.log('启动成功!')
    }) 
  • 相关阅读:
    「模板」 树套树
    [Luogu 3701] 「伪模板」主席树
    「模板」 可持久化平衡树
    「模板」 割点
    [Luogu 2596] ZJOI2006 书架
    省选有感。(不是游记)
    [Luogu 2604] ZJOI2010 网络扩容
    MySql聚簇索引与非聚簇索引的区别
    四层负载均衡和七层负载均衡的区别
    Redis利用Pipeline加速查询速度的方法
  • 原文地址:https://www.cnblogs.com/houfee/p/10287853.html
Copyright © 2011-2022 走看看