美文网首页
http 的cookie和session

http 的cookie和session

作者: 绩重KF | 来源:发表于2018-02-28 15:01 被阅读0次

cookie和session都是用来解决http请求无状态的问题。

cookie通过让客户端(浏览器缓存一个对应的文件来记录数据信息),下次请求的时候带上这个信息请求服务器
以别服务识别是那个用户的请求。

session基本也是这样的原理,只不过是客户端不缓存信息服务端来缓存信息,服务端处理每次请求的时候都带上
一个session对应的信息给客户端(浏览器),客户端下次发起请求的时候也带上这个信息,有效时间为客户端关闭浏览器.

cookie 大概实现思路是这样:
服务端通过一定的加密算法生成对应的cookie信息,发送给客户端
客户端请求的时候,服务端用算法验证这个cookie信息,并获取内容。

#python伪代码

import hashlib
import json

key = "123456"

def Get(self, Request):
    cookie = Request.get_cookie()
    if not cookie:
        #设置cookie
        user_name = "test"
        crypt_text = user_name + key
        cookie.value = hashlib.md5(crypt_text).hexdigest()
        cookie.user_name = user_name
        Request.set_cookie(cookie)
    #验证cookie
    user_name = cookie.user_name 
    cookie_value = cookie.value
    crypt_text = user_name + key
    
    if hashlib.md5(crypt_text).hexdigest() != cookie_value:
        return self.write("cookie 篡改")

    #其他逻辑处理 
    ....
    self.write(result) 

session 大概实现思路是这样:
通过存储技术(可以是内存,可以数据库等)缓存对应的每个用户的信息,并对应设置信息超时时间

#python 伪代码
#可以用数据管理,如mongodb和redis(有自动超时机制)等
memory_session = {
    session_id : {"name": test, ...}
}

def Login(self, Request):
    session Request.session: 
    if not session 
        #生成session
        session.set("sessionid", 12345) 
        session.set("userid", "user01")
        Request.session = session
    获取session之类处理
    session = Request.session
    sessionid = session.get("sessionid")
    if not memory_session.get(sessionid):
        return self.wirte("session 超时")

    通过后续逻辑处理
    ...
    self.write(result)

相关文章

  • session,cookie,token

    session和cookie session和cookie的区别session是解决http协议是无状态的这一问题...

  • 8月技术学习汇总

    HTTP 【HTTP】分布式session的管理 【HTTP】Cookie和Session 【HTTP】当我在谈论...

  • express中的 Cookie和 Session

    why Cookie and Session 我们为什么要引入Cookie和Session?因为HTTP是一个无状...

  • 代码写累了,cookie了解一下?

    一、什么是cookie? 什么是session Cookie和Session是为了在无状态的HTTP协议之上维护会...

  • 第15讲.Cookie&Session

    Cookie&Session 学习摘要: 今天主要是讲解Cookie和Session的问题。 重点深入理解HTTP...

  • Http Session和Cookie

    Session和Cookie原理

  • HTTP: Cookie 和 Session

    当第一次请求的时候,服务器会生成一个 Session ID,放在 Response 的 header 里。以后再发...

  • HTTP Cookie和Session

    Cookie:服务端标识客户端请求是否来自同一浏览器,让浏览器积累服务端特有的信息,每次访问都能把这些信息提供给客...

  • 一些面试题

    网络 http header ,Cookie和Session的区别?分别是用于什么场景?优缺点? session ...

  • http 的cookie和session

    cookie和session都是用来解决http请求无状态的问题。 cookie通过让客户端(浏览器缓存一个对应的...

网友评论

      本文标题:http 的cookie和session

      本文链接:https://www.haomeiwen.com/subject/ovabxftx.html