下面讲的都是基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相关操作的更多相关文章

  1. Python Web学习笔记之Cookie,Session,Token区别

    一.Cookie,Session,Token简介 # 这三者都解决了HTTP协议无状态的问题 session ID or session token is a piece of data that i ...

  2. CentOS学习笔记--基本命令--目录的相关操作

    Linux基本命令--目录的相关操作 常见的处理目录的命令吧: cd:变换目录 pwd:显示目前的目录 mkdir:创建一个新的目录 rmdir:删除一个空的目录 cd (变换目录) cd是Chang ...

  3. Javaweb学习笔记5—Cookie&Session

    今天来讲javaweb的第五阶段学习. Cookie和Session同样是web开发常用到的地方. 老规矩,首先先用一张思维导图来展现今天的博客内容. ps:我的思维是用的xMind画的,如果你对我的 ...

  4. ElasticSearch学习笔记-02集群相关操作_cat参数

    _cat参数允许你查看集群的一些相关信息,如集群是否健康,有哪些节点,以及索引的情况等的. 检测集群是否健康 curl localhost:9200/_cat/health?v 说明: curl 是一 ...

  5. Django学习笔记之Django ORM相关操作

    一般操作 详细请参考官方文档 必知必会13条 <> all(): 查询所有结果 <> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 <> ...

  6. X-Cart 学习笔记(四)常见操作

    目录 X-Cart 学习笔记(一)了解和安装X-Cart X-Cart 学习笔记(二)X-Cart框架1 X-Cart 学习笔记(三)X-Cart框架2 X-Cart 学习笔记(四)常见操作 五.常见 ...

  7. openresty 学习笔记六:使用session库

    openresty 学习笔记六:使用session库 lua-resty-session 是一个面向 OpenResty 的安全和灵活的 session 库,它实现了 Secure Cookie Pr ...

  8. golang学习笔记16 beego orm 数据库操作

    golang学习笔记16 beego orm 数据库操作 beego ORM 是一个强大的 Go 语言 ORM 框架.她的灵感主要来自 Django ORM 和 SQLAlchemy. 目前该框架仍处 ...

  9. amazeui学习笔记--css(布局相关1)--网格Grid

    amazeui学习笔记--css(布局相关1)--网格Grid 一.总结 基本使用 1.div+class布局:amaze里面采取的就是div+class的布局方式  <div class=&q ...

随机推荐

  1. 服务器保存所有用户的操作指令(history)

    参考地址:https://helpcdn.aliyun.com/knowledge_detail/41210.html #!/bin/bash LOGIP=`who -u am i 2>/dev ...

  2. JDK1.5新特性,基础类库篇,扫描类(Scanner)用法

    一. 背景 这是一个简单的文本扫描类,能够解析基本数据类型与字符串.它是StringTokenizer和Matcher类之间的某种结合. 最大的优点是读取控制台输入非常方便,其它功能,有点鸡肋. 二. ...

  3. Python 父目录获取

    # coding=utf-8import os currentPath = os.getcwd() # 当前目录parent_path = os.path.dirname(currentPath) # ...

  4. CodeSign error: code signing is required for product type Application in SDK iOS XXX的解决办法

    转自:http://www.tuicool.com/articles/jYRNbm 在真机测试的时候往往会突然出现这样一个错误,code signing is required for product ...

  5. innobackupex在线备份及恢复(全量和增量)

    Xtrabackup是由percona开发的一个开源软件,它是innodb热备工具ibbackup(收费的商业软件)的一个开源替代品.Xtrabackup由个部分组成:xtrabackup和innob ...

  6. mongoose修改数组中某个特定的值

    写博客的时候有一个这样的业务,一个标签集合和一个文章集合,它们是多对多的关系,文章集合中tags字段包含它对应的标签,现在修改标签集合中某条标签记录的名字,文章集合中所有包含这个标签的tags字段的值 ...

  7. my stackoverflow

    https://stackoverflow.com/questions/48017641/how-to-monitor-elastic-stack-without-x-pack https://sta ...

  8. (转)用stunnel给普通http通信加密

    转自:https://www.digitalocean.com/community/tutorials/how-to-set-up-an-ssl-tunnel-using-stunnel-on-ubu ...

  9. 【Java】Java复习笔记-第二部分

    类和对象 类:主观抽象,是对象的模板,可以实例化对象 习惯上类的定义格式: package xxx; import xxx; public class Xxxx { 属性 ······; 构造器 ·· ...

  10. Asp.Net MVC TryUpdateModel使用说明

    修改功能每个网站里都有,也有很多写法 写法1:要修改的字段刚好等于表中的字段 [HttpPost] [ValidateAntiForgeryToken] public ActionResult Edi ...