Session 是一种记录客户状态的机制,不一样的是 Cookie 保存在客户端浏览器中,而 Session 保存在服务器上的进程中。javascript
客户端浏览器访问服务器的时候,服务器把客户端信息以某种形式记录在服务器上,这就是 Session。客户端浏览器再次访问时只须要从该 Session 中查找该客户的状态就能够了。java
若是说 Cookie 机制是经过检查客户身上的“通行证”来肯定客户身份的话,那么 Session 机制就是经过检查服务器上的“客户明细表”来确认客户身份。express
Session 至关于程序在服务器上创建的一份客户档案,客户来访的时候只须要查询客户档案表就能够了。跨域
Session 不能跨域浏览器
const express = require('express') const path = require('path') const app = express(); const bodyParser = require('body-parser'); const cp = require('cookie-parser'); const session = require('express-session'); app.use(cp()); app.use(session({ secret: '12345',//用来对session数据进行加密的字符串.这个属性值为必须指定的属性 name: 'testapp', //这里的name值得是cookie的name,默认cookie的name是:connect.sid cookie: {maxAge: 5000 }, //设置maxAge是5000ms,即5s后session和相应的cookie失效过时 resave: false, saveUninitialized: true, })) app.use(bodyParser.urlencoded({extended: false})); app.use(express.static(path.join(__dirname, '/'))); app.get('/setsession', (request, response) => { request.session.user = {username: 'admin'}; response.send('set session success'); }) app.get('/getsession', (request, response) => { response.send(request.session.user); }) app.get('/delsession', (request, response) => { delete reqeust.session.user; response.send(request.session.user); }) app.listen(88)