node作为服务器更多的是web服务器

1.http模块

首先:http是一个协议。里面有通信机制,状态码一大堆乱七八糟的东西。自己写猴年马月都写不出来,node通过这个http这个对象帮我们集成。直接用

服务器对象: http.createSever()【快速搭建一个服务器,集成好】

let http = require('http')

http.createServer(() => {
content
}).listen(8088)
//当访问localhost:8088 content就会输出到服务器
let http = require('http')
let fs = require('fs')
http.createServer((request, response) => {
console.log(request.url)
fs.readFile(`./${request.url}`, (err, data) => {
if (err) { } else {
response.end(data)
}
})
}).listen(8088)
//当访问localhost:8088 content就会输出到服务器
let http = require('http')
let fs = require('fs')
http.createServer((request, response) => {
console.log(request.url)
fs.readFile(`./${request.url}`, (err, data) => {
if (err) {
response.writeHead(404)
response.end('data')
} else {
response.writeHead(200) //这行可不写,默认
response.end(data)
}
})
}).listen(8088)
//当访问localhost:8088 content就会输出到服务器

2.Node中的数据交互

头部:信息 不能大于32k (url 浏览器版本 内核)

身体:数据 不能大于2g(超过只能用插件)

get请求方法

1.主要用于获取数据

2.数据是放在url里进行传输的

let http = require('http')
let fs = require('fs')
http.createServer((request, response) => {
console.log(request.url)
let [path, query] = request.url.split('?')
console.log(path, query)
}).listen(8088)
//当访问localhost:8088 content就会输出到服务器 //html文件
<form action="http://localhost:8088/1.html" method="get"> action数据提交的地址
用户名<br><input type="text" name="username">
密码<br><input type="text" name="password">
<br><input type="submit">
</form> //使用新模块
let http = require('http')
let fs = require('fs')
let url = require('url')
http.createServer((request, response) => {
console.log(url.parse(request.url, true))
}).listen(8088)
//当访问localhost:8088 content就会输出到服务器

GET请求

参数放在url中 放在头部

数据比较小(一次就传输了)

POST请求

数据放在body里面传输

数据比较大(一段一段传输,一般传输的是二进制 buffer)

也可以放在url中

let http = require('http')
let fs = require('fs')
let url = require('url')
http.createServer((request, response) => {
let result = []
request.on('data',(buffer) => {
result.push(buffer)
}) //data事件,每发送一段data数据,就执行一次data事件。on比较像绑定
request.on('end', () => {
var data = Buffer.concat(result)
console.log(data, result) // 因为我们需要的是一个buffer数据格式
})
}).listen(8088)
//引入字符串切片工具
let http = require('http')
let fs = require('fs')
let querystring = require('querystring')
let url = require('url')
http.createServer((request, response) => {
let result = []
request.on('data',(buffer) => {
result.push(buffer)
}) //data事件,每发送一段data数据,就执行一次data事件。on比较像绑定
request.on('end', () => {
var data = Buffer.concat(result).toString()
console.log(querystring.parse(data)) // 因为我们需要的是一个buffer数据格式
})
}).listen(8088)

上面例子只阐述字符串的转译

总结(数据通信)

1.get 特性

  • url中 ?后面
  • < 32k(http协议规定的)
  • url模块(帮我们处理url)  url.parse(req.url  true) true帮我们转化json

2.post特性

  • 放在body里面
  • 数据大 2G
  • querystring模块  (处理数据)
    querystring.parse(data)

案例

什么是接口:不同功能层之间的通信规则称为接口

参数:

返回值

接口设计

‘/login’ 接口地址(登陆接口)

username,password(前端提供)

get

/reg

post

返回值

{
err:1
mas:''" //错误信息
}//前端希望看到的返回值json

接口文档:接口如何使用

node核心 http模块的更多相关文章

  1. Node核心模块

    在Node中,模块主要分两大类:核心模块和文件模块.核心模块部分在 Node 源代码的编译过程中,编译进了二进制执行文件.在 Node 进启动时,部分核心模块就被直接加载进内存中,所以这部分核心模块引 ...

  2. node.js 核心http模块,起一个服务器,返回一个页面

    let http=require("http"); //引入核心http模块 let fs=require("fs"); let mime={ '.js':'a ...

  3. Node.js面试题:侧重后端应用与对Node核心的理解

    Node是搞后端的,不应该被被归为前端,更不应该用前端的观点去理解,去面试node开发人员.所以这份面试题大全,更侧重后端应用与对Node核心的理解. node开发技能图解 node 事件循环机制 起 ...

  4. 《Node.js高级编程》之Node 核心API基础

    Node 核心API基础 第三章 加载模块 第四章 应用缓冲区 第五章 事件发射器模式简化事件绑定 第六章 使用定时器制定函数执行计划 第三章 加载模块 本章提要 加载模块 创建模块 使用node_m ...

  5. node.js面试题大全-侧重后端应用与对Node核心的理解

    Node是搞后端的,不应该被被归为前端,更不应该用前端的观点去理解,去面试node开发人员.所以这份面试题大全,更侧重后端应用与对Node核心的理解. github地址: https://github ...

  6. Node入门教程(12)第十章:Node的HTTP模块

    Ryan Dahl开发node的初衷就是:把Nginx非阻塞IO功能和一个高度封装的WEB服务器结合在一起的东东.所以Node初衷就是为了高性能的Web服务器去的,所以:Node的HTTP模块也是核心 ...

  7. Node学习HTTP模块(HTTP 服务器与客户端)

    Node学习HTTP模块(HTTP 服务器与客户端) Node.js 标准库提供了 http 模块,其中封装了一个高效的 HTTP 服务器和一个简易的HTTP 客户端.http.Server 是一个基 ...

  8. Node.js之模块机制

    > 文章原创于公众号:程序猿周先森.本平台不定时更新,喜欢我的文章,欢迎关注我的微信公众号. ![file](https://img2018.cnblogs.com/blog/830272/20 ...

  9. Node解析之----模块机制篇

    开篇前,我们先来看张图, 看node与W3C组织.CommonJS组织.ECMAScript之间的关系. Node借鉴来CommonJS的Modules规范实现了一套非常易用的模块系统,NPM对Pac ...

随机推荐

  1. CentOS7编译安装httpd-2.4.41

    安装参考环境: CentOS Linux release 7.5.1804 (Core) 一.安装依赖包 httpd安装的依赖包 # yum -y install pcre-devel # yum - ...

  2. [原]JointJS流程图

    最近项目上需要用流程图来做问题定界分析,之前有同事用jsPlumb做过,但是阅读代码后觉得比较麻烦,所以自己又找了一圈,找到一个叫Dagre-D3的开源类库,画出来的效果如下图,Dagre-D3最大的 ...

  3. 阿里云服务器ubantu创建新用户登录显示问题

    在root用户下输入:vi /etc/passwd,找到添加的用户,在后面加上/bin/bash 重新登录即回复正常

  4. Docker 基础入门

    Docker是一个开放的平台,将应用和基础设施分隔开来, 方便快速的交付软件.利用docker的提供的方法可以快速的测试和部署代码,显著的减少写代码和部署直接的延迟. Docker 平台(The Do ...

  5. js 动画提示数据有变化

    let groupZiArray = $.....; for (let i = 1; i < groupZiArray.length; i++) { let $groupZi = $(group ...

  6. 灵光一闪来个科普贴:Linux文件系统

    在计算机系统中,各种需要保存的信息都是以文件的形式存在的.文件管理是对系统信息资源的管理,是操作系统的一项重要功能. 1.文件与文件系统: 1.1文件: 文件是具有名字的一组相关信息的有序集合,存放在 ...

  7. rally问题合集

    rally 执行过程中涉及到keystone的用例,需要调用adminurl,在-/rally/lib/python2.7/site-packages/rally/osclients.py(主机文件的 ...

  8. JS弹出层制作,以及移动端禁止弹出层下内容滚动,overflow:hidden移动端失效问题

    HTML <div class="layer"> <div class="menu-list"> <span>社会</ ...

  9. tomcat#结构

    下面是一个tomcat的配置文件,通过分析tomcat配置文件的结构,和相关注释,可以大致了解tomcat的结构 <?xml version="1.0" encoding=& ...

  10. 【android官方文档】与其他App交互

    发送用户到另外一个App YOU SHOULD ALSO READ 内容分享 One of Android's most important features is an app's ability ...