1、express处理post请求

借助body-parse中间件,其实最终我们也不会使用这个

对于get请求,无需中间件,用req.query即可返回相应的数据

但是post我们尝试借助中间件处理

const express = require('express')
const es = require('express-static')
const bp = require("body-parser") let server = express() server.use(bp.urlencoded({
extended: false,//是否启用扩展模式
limit: 2 * 1024 * 1024//限制接收post数据的大小,100k默认 })) //中间处理,共有2个参数 server.use('/', function (req, res) {
console.log(req.body)
}) server.listen(8080, () => console.log('server is running')) <!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<script src="./ajax.js"></script> <body>
<form action="http://localhost:8080" method="post">
用户名:<input type="text" name="user" id="user"><br />
密码:<input type="passsword" name="pwd" id="pwd">
<input type="submit" value="登录" id="login">
</form> </body>
<script>
window.onload = function () { } </script> </html>
const express = require('express')
const es = require('express-static')
const bp = require("body-parser") let server = express() server.use(bp.urlencoded({
extended: false,//是否启用扩展模式
limit: 2 * 1024 * 1024//限制接收post数据的大小,100k默认 })) //中间处理,共有2个参数 server.use('/', function (req, res, next) {//use的第一个参数缺省,将响应所有的路径 console.log(req.body)
req.a = 12
//next适用来表明需要进行下一步的链式操作的,否则直接结束响应
//进行链式操作的use的url务必一致,本函数体内数据在下一个相应的use内仍有效
next()
}) server.use('/',function(){
console.log(req.a)
}) server.listen(8080, () => console.log('server is running'))

2、尝试编写中间件

const express = require('express')
const es = require('express-static')
const bp = require("body-parser")
const qs = require("querystring") let server = express() //自己编写的处理post请求的中间件
server.use(function (req, res, next) {
let str = ''
req.on('data', function (data) {
str += data
})
req.on('end', function () {
req.body = qs.parse(str)
next()
})
}) server.use('/', function (req, res) {
console.log(req.body)
console.log('finished')
}) server.listen(8080, () => console.log('server is running'))

2)进行封装

const qs = require("querystring")

module.exports=function (req, res, next) {
let str = ''
req.on('data', function (data) {
str += data
})
req.on('end', function () {
req.body = qs.parse(str)
next()
})
}

3)总结

const qs = require("querystring")

module.exports=function (req, res, next) {
let str = ''
req.on('data', function (data) {
str += data
})
req.on('end', function () {
req.body = qs.parse(str)
next()
})
}

4、cookie/session

session存储在服务端,比较安全,seession是基于cookie存在的

const qs = require("querystring")

module.exports=function (req, res, next) {
let str = ''
req.on('data', function (data) {
str += data
})
req.on('end', function () {
req.body = qs.parse(str)
next()
})
}

操作这两个存储需要使用到的中间件是cookie-parser cookie-session

简单地使用cookie

const express = require('express')

let server = express()

server.use('/', function (req, res) {
res.cookie('user', 'cc', {
path: '/',//哪个目录下可以读取这个cookie
maxAge: 30 * 24 * 3600 * 1000//一个月有效时间
})//共三个参数:键、值、设置其他cookie参数的对象 res.send('ok啦')
}) server.listen(8080, function () {
console.log('server is running')
})

使用签名的cookie

const express = require('express')
const cp = require('cookie-parser') let server = express() server.use(cp('esfwegethg'))//密钥,必须和下面的secret对应,可省略 //cookie是可以向上访问的
server.use('/', function (req, res) {
req.secret='esfwegethg'
//进行签名,可以防止用户端篡改
res.cookie('user', 'blue', { signed: true })//s开头,进行了签名 console.log(req.cookies)//这里打印的是没有进行签名的cookie
console.log(req.signedCookies)//这里打印的是进行签名的cookie
res.send('ok啦')
}) server.listen(8080, function () {
console.log('server is running')
})

res.clearCookie('键’)//删除cookie

使用cookie-encrypter中间件能更好地为cookie进行加密解密

但cookie一般不加密,session是强制我们进行加密的

2)使用session

const express = require('express')
const cp = require('cookie-parser')
const cs = require('cookie-session') let server = express() server.use(cp())
server.use(cs({
  name:"cc"//自定义sesion id 键名
//必须,强制加密以保证session数据安全
keys: ['aaa', 'bbb', 'ccc'],
   maxAge:24*3600*1000//设置session有效期
})) //cookie是可以向上访问的
server.use('/', function (req, res) {
if (!req.session["count"]) {
//记录访问次数
req.session["count"] = 1
} else {
req.session["count"]++
} console.log(req.session['count'])
res.send('ok啦')
}) server.listen(8080, function () {
console.log('server is running')
})

使用后cookie中会存有两个cookie,一个session,即session id,一个session.sig,是一个签名,

删除session:

delete req.session

node03的更多相关文章

  1. 网站日志流量分析采集(LuaJIT系统环境部署-node03,相关jar包自己手动上传)

    注:/usr/local/src 是源码包路径,可以自己更改 服务器中安装依赖 yum -y install gcc perl pcre-devel openssl openssl-devel 上传 ...

  2. Keepalived 配置实例

    Keepalived 是一款轻量级HA集群应用,它的设计初衷是为了做LVS集群的HA,即探测LVS健康情况,从而进行主备切换,不仅如此,还能够探测LVS代理的后端主机的健康状况,动态修改LVS转发规则 ...

  3. Puppet3在CentOS6.5集群下的安装

    环境:3台主机, IP分别为10.211.55.11.12.13 puppet master安装在10.211.55.11 puppet agent安装在10.211.55.11.12.13 1.安装 ...

  4. 解决zabbix图中出现中文乱码问题 图中的中文会变成方块

    [root@node03 src]# wget http://down1.chinaunix.net/distfiles/ttf-arphic-uming_0.0.20050501-1.tar.gz ...

  5. 分布式架构高可用架构篇_02_activemq高可用集群(zookeeper+leveldb)安装、配置、高可用测试

    参考: 龙果学院http://www.roncoo.com/share.html?hamc=hLPG8QsaaWVOl2Z76wpJHp3JBbZZF%2Bywm5vEfPp9LbLkAjAnB%2B ...

  6. 分布式架构高可用架构篇_01_zookeeper集群的安装、配置、高可用测试

    参考: 龙果学院http://www.roncoo.com/share.html?hamc=hLPG8QsaaWVOl2Z76wpJHp3JBbZZF%2Bywm5vEfPp9LbLkAjAnB%2B ...

  7. 【转载】图解:二叉搜索树算法(BST)

    原文:图解:二叉搜索树算法(BST) 摘要: 原创出处:www.bysocket.com 泥瓦匠BYSocket 希望转载,保留摘要,谢谢!“岁月极美,在于它必然的流逝”“春花 秋月 夏日 冬雪”— ...

  8. 在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针。 例如,链表1->2->3->3->4->4->5 处理后为 1->2->5

    // test20.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include<iostream> #include< ...

  9. Advanced Awk for Sysadmins

    转:http://www.linuxforu.com/2011/06/advanced-awk-for-sysadmins/ By Vishal Bhatia on June 1, 2011 in H ...

随机推荐

  1. Pytorch划分数据集的方法

    之前用过sklearn提供的划分数据集的函数,觉得超级方便.但是在使用TensorFlow和Pytorch的时候一直找不到类似的功能,之前搜索的关键字都是"pytorch split dat ...

  2. 【Android手机测试】linux内存管理 -- 一个进程占多少内存?四种计算方法:VSS/RSS/PSS/USS

    在Linux里面,一个进程占用的内存有不同种说法,可以是VSS/RSS/PSS/USS四种形式,这四种形式首字母分别是Virtual/Resident/Proportional/Unique的意思. ...

  3. MVC或WebAPI发布后报错404问题的总结

    在MVC项目或者webAPI项目发布之后有时会发生404错误.针对这种错误的解决办法: 解决办法1(不推荐):在webconfig中 <system.webServer> 节点下 添加 & ...

  4. 禁用 urllib3 的安全请求警告

    报错情况: 禁用该警告: import urllib3 urllib3.disable_warnings()

  5. Android Wear 2.0 AlarmManager 后台定时任务

    以前在Android 4.0时,alarmManager 没什么问题.后来android为了优化系统耗电情况,引入了doze模式,参见此页 https://developer.android.com/ ...

  6. PHP提取页面第一张图为缩略图的代码

    <?php $p = '/<img.*?src=[\'|\"](.+?)[\'|\"].*?>/i'; preg_match_all($p,$str,$match ...

  7. 如何配置adb环境变量

    如何配置adb环境变量? 1.我的电脑---控制面板---高级系统设置 2.点击[高级系统设置],弹出系统属性的弹框, 3.点击[环境变量],弹出环境变量弹框,新建一个系统变量,命名为Android ...

  8. RROR: [XSIM 43-3238] Failed to link the design.

    仿真时遇到上述错误,在tcl下运行 set_property -name {xsim.elaborate.xelab.more_options} -value {-cc clang} -objects ...

  9. python2使用eval 让除法可以保留小数

    使用的Python版本2.7, 我在使用eval('1/3')发现一个问题,结果都是去掉小数,保留了整数.但是我需要保留小数,各种查资料,最后在一大神指点下,成功解决这个问题,解决办法是: 加载模块: ...

  10. SpringBoot的Profiles根据开发环境和测试环境载入不同的配置文件

    参考:https://www.cnblogs.com/bjlhx/p/8325374.html 1.需要有一个默认的配置文件,然后一个正式的配置文件,一个测试的配置文件.激活配置项,默认的配置文件ap ...