node学习笔记9——cookie,session相关操作
下面讲的都是基Express及相关的包。所以在实践本篇文章之前,通过npm安装好Express, cookie-parser, cookie-session这三个安装包。
先简单说一下,如何用Express搭建一个服务器环境。如下:
const express=require("express");//引用express var server=express();//创建服务器
server.listen(8090);//监听服务器
就是这么简单三句即可。
在说cookie, session 之前,先了解一下这2个东西的基本特性:
cookie:
1.保存在浏览器端,每次请求都会带过来;
2.不安全、大小有限(4K)。
session:
1.保存在服务器端;
2.安全、理论上是无限的;
3.基于cookie实现的。
对于这2个东西的操作,无非就是发送,读取,写入,删除这几种操作。
先讲一下cookie:
1.发送:
const express=require("express"); var server=express();
server.listen(8090); //发送cookie
server.use('/www/test.html',function(req,res){
res.cookie('user','test',{path:'/www',maxAge:30*24*3600*1000}); res.send('ok');
})
运行这个js,可以看到浏览器里面的cookie如下图:
2.读取cookie,如果需要用到签名功能,需要引用cookie-parser模块:
const express = require("express");
const cookieParser = require("cookie-parser"); var server = express();
server.use(cookieParser("adtq563fgkj452ag")); //先写入,再读取,secret表示cookie签名,可以防止别人篡改你的cookie
server.use('/', function (req, res) {
req.secret = 'adtq563fgkj452ag'; //如果上面在cookieParser传入了签名,这句话可以不写
res.cookie('user', 'sese', {
signed: true //表示该cookie需要签名
});
console.log('签名的cookie:', req.signedCookies); //读取签名的cookie
console.log('无签名的cookie:', req.cookies); //读取没签名的cookie res.send('ok');
}); server.listen(8090);
执行该JS,结果如下图:
服务器端返回的结果:
3.删除cookie,语句为clearCookie():
const express = require("express");
const cookieParser = require("cookie-parser"); var server = express(); //删除cookie
server.use('/', function (req, res) {
res.clearCookie('user');
res.send('ok');
}); server.listen(8090);
-------------------------我是存在感十足的分割线-------------------------
现在讲一下sessoion。
1.写入session,需要引用cookie-session模块 :
const express = require("express");
const cookieParser = require("cookie-parser");
const cookieSession = require("cookie-session"); var server = express(); //生成session的密钥数组
var arr=[];
for(var i=0;i<10000;i++){
arr.push('sig_'+Math.random());
}
server.use(cookieParser());
server.use(cookieSession({
name:'sess',
keys:arr // 密钥
})); server.use('/', function (req, res) {
res.send('ok');
}); server.listen(8090);
执行上面代码,显示结果如下 :
2.删除session,语句为delete req.session[name],即为:
server.use('/', function (req, res) {
delete req.session['sess'];
res.send('ok');
});
大家可以亲自测试上面的例子~
node学习笔记9——cookie,session相关操作的更多相关文章
- Python Web学习笔记之Cookie,Session,Token区别
一.Cookie,Session,Token简介 # 这三者都解决了HTTP协议无状态的问题 session ID or session token is a piece of data that i ...
- CentOS学习笔记--基本命令--目录的相关操作
Linux基本命令--目录的相关操作 常见的处理目录的命令吧: cd:变换目录 pwd:显示目前的目录 mkdir:创建一个新的目录 rmdir:删除一个空的目录 cd (变换目录) cd是Chang ...
- Javaweb学习笔记5—Cookie&Session
今天来讲javaweb的第五阶段学习. Cookie和Session同样是web开发常用到的地方. 老规矩,首先先用一张思维导图来展现今天的博客内容. ps:我的思维是用的xMind画的,如果你对我的 ...
- ElasticSearch学习笔记-02集群相关操作_cat参数
_cat参数允许你查看集群的一些相关信息,如集群是否健康,有哪些节点,以及索引的情况等的. 检测集群是否健康 curl localhost:9200/_cat/health?v 说明: curl 是一 ...
- Django学习笔记之Django ORM相关操作
一般操作 详细请参考官方文档 必知必会13条 <> all(): 查询所有结果 <> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 <> ...
- X-Cart 学习笔记(四)常见操作
目录 X-Cart 学习笔记(一)了解和安装X-Cart X-Cart 学习笔记(二)X-Cart框架1 X-Cart 学习笔记(三)X-Cart框架2 X-Cart 学习笔记(四)常见操作 五.常见 ...
- openresty 学习笔记六:使用session库
openresty 学习笔记六:使用session库 lua-resty-session 是一个面向 OpenResty 的安全和灵活的 session 库,它实现了 Secure Cookie Pr ...
- golang学习笔记16 beego orm 数据库操作
golang学习笔记16 beego orm 数据库操作 beego ORM 是一个强大的 Go 语言 ORM 框架.她的灵感主要来自 Django ORM 和 SQLAlchemy. 目前该框架仍处 ...
- amazeui学习笔记--css(布局相关1)--网格Grid
amazeui学习笔记--css(布局相关1)--网格Grid 一.总结 基本使用 1.div+class布局:amaze里面采取的就是div+class的布局方式 <div class=&q ...
随机推荐
- xctool + oclint 安装使用
使用brew 安装Xctool 先跟新brew : sudo brew update brew install xctool --HEAD OK. 使用请参照 文档 如: xctool -works ...
- Bash - 趣味Shell
好消息:本人博客已开通.很多其它博客请进 http://swplzj.github.io 今天抽闲玩了一下Shell.发现几个比較有意思的.记录一下. 终端彩虹字:lolcat 图形化文字:figle ...
- Android Eclipse Libs 的 jar 源码查看 (或者新版本ADT无法查看jar的源码)
问题背景:在使用比较新的ADT的时候,无法导入Jar中的源码包查看源码.只好自己打开压缩包,实在恼火.在半年前,只好这样. 问题解决方案:我就以 " android-support-v4.j ...
- Atitit Loading 动画效果
Atitit Loading 动画效果 使用才场景,加载数据,以及显示警告灯.. 要有手动关闭按钮 <div class="spinner loading_part" sty ...
- spring boot下JedisCluster方式连接Redis集群的配置
最近在使用springboot做项目,使用redis做缓存.在外网开发的时候redis服务器没有使用集群配置,所有就是用了RedisTemplate的方式进行连接redis服务器.但是项目代码挪到内网 ...
- mydqldump 备份数单库 然后还原数据的时候报:ERROR 1881 (HY000) at line 52: Operation not allowed when innodb_forced_recovery > 0.
修改my.cnf innodb_force_recovery = 1 修改为: innodb_force_recovery = 0
- 高级数据库及一步一步搭建versant数据库
总的来说,高级数据库课程分为分布式数据库和面向对象数据库两块.分布式数据库介绍了分布式数据库的方方面面,包括数据库系统的设计.查询处理优化.事务管理和恢复.并发控制.可靠性.安全性与目录管理等.面向对 ...
- Android 微信支付资料收集
老板要求支持微信支付,收集了些资料做后期参考 http://www.360doc.com/content/15/0214/10/7044580_448519997.shtml http://www.t ...
- 【驱动】Flash设备驱动基础·NOR·NAND
Flash存储器 ——>Flash存储器是近几年来发展最快的存储设备,通常也称作闪存.Flash属于EEPROM(电可擦除可编程只读存储器),是一类存取速度很高的存储器. ——>它既有RO ...
- 【ARM】2410裸机系列-按键查询式控制led
开发环境 硬件平台:FS2410 主机:Ubuntu 12.04 LTS LED灯原理图 按键原理图 按键的接线资源 KSCAN0 -> GPE11 KSCAN1 -> GPG6 ...