【nodejs学习笔记】用户登录相关:cookie、session 和 redis的使用和优缺点

cookie

什么是 cookie:

  • 存储在浏览器的一段字符串,最大 5kb
  • 跨域不共享
  • 格式形如:key1=value1; key2=value2
  • 每次发送 http 请求,会将请求域的 cookie 一起发送给 server

客户端查看、修改 cookie

开发者工具查看:
在这里插入图片描述
domain: cookie生效的域名;
可以直接这样追加cookie:
在这里插入图片描述
注意:每对 key=value 之间,是用“; ”分隔的,分号后面还有空格

server 端操作 cookie

获取-示例

const serverHandle = (req, res) => {
   
    // 解析 cookie
    req.cookie = {
   }
    const cookieStr = req.headers.cookie || '' 
    console.log(cookieStr)  // 格式:key1=value1; key2=value2
    cookieStr.split(';').forEach(item => {
   
        if(!item) return
        const [key, val] = item.split('=')
        req.cookie[key.trim()] = val.trim() // 用 trim 去掉首尾空格
    })
}
const server = http.createServer(serverHandle)
server.listen(8000)

写入-示例

// 设置 cookie 过期时间的方法
const getCookieExpires = () => {
   
    const d = new Date()
    d.setTime(d.getTime() + (24 * 60 * 60 * 1000))
    return d.toGMTString()
}
const handleUserRouter = (req, res) => {
   
    const method = req.method
    // 模拟一下登录
    if(method === 'GET' && req.path === '/api/user/login'){
   
        const {
    username, password } = req.query
        const result = login(username, password)  // login 方法是去数据库查询对应的用户数据并返回
        return result.then(data => {
   
            if(data.username) {
   
               // 设置 cookie
               res.setHeader('Set-Cookie', `username=${
     data.username
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值