NodeJssession使用-创新互联
以登录为例
为槐荫等地区用户提供了全套网页设计制作服务,及槐荫网站建设行业解决方案。主营业务为网站设计、成都网站制作、槐荫网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!基本实现原理:
- 客户端通过账号密码登录
- 服务器接收请求参数,生成sessionId 将sessionId存储到客户端的cookie中
- 下一次客户端请求的时候带上cookie ,服务器获取cookie中的sessionId验证身份
- 响应验证通过的客户端,也就是登录成功的用户
使用方法:
- node.js中需要借助express-session实现session功能。使用 npm instsall express-session下载。
- 导入express-session模块 const session = require('express-session');
- 配置session
app.use(session({ secret: 'secret key', //使用随机自定义字符串进行加密 saveUninitialized: false,//不保存未初始化的cookie,也就是未登录的cookie cookie: { maxAge: 24 * 60 * 60 * 1000 //设置cookie的过期时间为1天 activeDuration: 5* 60*1000, // 激活时间,比如设置为30分钟,那么只要30分钟内用户有服务器的交互,那么就会被重新激活。 } }))
4.在用户登录的时候保存用户的信息
app.post('/login', async (req,res) => { const { email, password } = req.body; let user = await User.findOne({ email: email }); if (user.password == password){ req.session.user = user;//登录成功将用户信息存储到session下面 res.redirect('/home/'); }else{ res.render('login.art',{error:'账号或者密码错误'}) } })
另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
分享名称:NodeJssession使用-创新互联
文章起源:http://scpingwu.com/article/cojeod.html