• flask-session


    一、session
                 session和cookie的原理和区别:
                 cookie是保存在浏览器上的键值对
                 session是存在服务端的键值对(服务端的session就是一个大字典,字典中是随机字符串)(session与request原理相同)(session原理跟上下文也有关系)
                 session依赖于cookie存在
                 session流程
                     当请求第一次进来,生成随机字符串
                      -发给用户cookie
                      -保存到session字典中时
                      它调用stark将随机字符串和对应的值放到local
                    视图函数
                     -使用时导入用top(它拿的是session)
                         session=LocalProxy(partile(_lookup_req_object,'session '))
                   请求处理完毕:
                         内存处理完毕后,将session做持久化(session存到数据库,存到Redis,存到加密的cookie中)

    二、session源码解析     

                  1.先执行Flask的__call__方法 ,调用出来wsgi_app,它先做request的上下文做完,请求刚进来到push中,它先处理request将请求相关的数据,然后添加到了local中,
                     紧接着处理session(将RequestContext对象(request,session)添加到local中),request(将request信息封装到Request(environ)对象并复制给requestContext 对                       象),然后获取cookie中的随机字符串,检验是否有,没有就生成。根据随机字符串,获取服务端session保存的值。把session放到内存中,
                     执行wsgi_app方法下面的视图函数。执行完视图函数返回到full_dispatch_requesthong ,触发只执行一次的装饰器中(触发Flask信号),
                     执行完这个装饰器,紧接着执行下面的特殊的装饰器,如果这些特殊装饰器没有返回值,那么rv=None,如果有返回值,页面时就显示这个返回值,
                     如果没有返回值,触发执行那个视图函数,拿返回值。请求执行完返回后,调用finalize_request,对它的返回值进行封装。

     如何处理的request
              ctx = self.request_context(environ)
              将request信息封装到Request(environ)对象并复制给
              requestContext 对象
          class RequestContext:
             def __init__(self, app, environ, request=None):
                   self.app = app
                   if request is None:
                   request = app.request_class(environ)
                   self.request = request
                   self.url_adapter = app.create_url_adapter(self.request)
                   self.flashes = None
                   self.session = None
    
    如何处理的session
          class RequestContext:
                 def push(self):
     将RequestContext对象(request,session)添加到local中
                       _request_ctx_stack.push(self)
    刚开始处理session
    #return app.session _interface.open_session(self,request)
    #app.session _interface=SecureCookieSessionInterface()
    
                     self.session = self.app.open_session(self.request)
                     if self.session is None:
                     self.session = self.app.make_null_session()           

    三、Flask和Django的区别  

               请求相关的数据

                    -Django:参数

                    -Flask:    基于Local,LocalStark对象

                多个请求进来会不会混淆

                      -单线程

                      -多线程

                      -协程

                        解决: from greenlet import getcurrent as get_ident

            

  • 相关阅读:
    理解 Delphi 的类(十) 深入方法[15] 调用其他单元的函数
    理解 Delphi 的类(十) 深入方法[13] 在 interface 区声明的方法
    理解 Delphi 的类(十) 深入方法[12] implementation 区中的方法
    理解 Delphi 的类(十) 深入方法[6] Result
    什么是B*树倒排索引技术 已解决 搜搜问问
    caoruntao的博客 数据结构及算法分类文章列表 ITeye技术网站
    PForDelta索引压缩算法的实现
    计算机词汇(融合了搜狗所有的计算机词库)_搜狗输入法词库
    一种由B+树实现的倒排索引《电脑知识与技术》2011年08期
    海量数据处理专题(九)——外排序
  • 原文地址:https://www.cnblogs.com/mengqingjian/p/8258938.html
Copyright © 2020-2023  润新知