卡在会话中检索参数 - GAE webapp2

Stuck retrieving parameters in sessions - GAE webapp2

我试图让会话与带有 GAE 的 Webapp2 一起工作,但我无法检索存储的参数。也许我忽略了显而易见的东西。

精简版 with main.py 我在 webapp2 会话中存储了一个值:

import webapp2
from webapp2_extras import sessions
other imports...

class BaseHandler(webapp2.RequestHandler):  # Copied from Google's doc
    def dispatch(self):
        # Get a session store for this request.
        self.session_store = sessions.get_store(request=self.request)

        try:
            # Dispatch the request.
            webapp2.RequestHandler.dispatch(self)
        finally:
            # Save all sessions.
            self.session_store.save_sessions(self.response)

    @webapp2.cached_property
    def session(self):
        # Returns a session using the default cookie key.
        return self.session_store.get_session()

class MainPage(webapp2.RequestHandler):  # My main page proper
    def get(self):
        self.session['foo'] = 'bar'      # Store somehing in the session
        template_values = {

        }

        template = JINJA_ENVIRONMENT.get_template('index.html')
        self.response.write(template.render(template_values))


application = webapp2.WSGIApplication([
    ('/', MainPage, ),], debug = True)

我的问题是如何从另一个模块访问存储在会话中的值。在 test.py 中,我执行以下操作:

from webapp2_extras import sessions
import main
other imports ...


class Test(main.BaseHandler):
    def post(self):
        foo1 = self.session.get('foo')
        return foo1

class ProductsPage(webapp2.RequestHandler):
    def get(self):
        foo2 = Test.post()
        ...

但是我收到以下错误: TypeError: 未绑定方法 post() 必须使用测试实例作为第一个参数调用(没有得到任何东西)

我只是找不到使用测试 class 和检索存储在会话中的值的正确方法。我一定是在使用 class 时忽略了一些东西,但我被卡住了,找不到出路。

也许有人从外面看会很容易发现它?

进一步观察,我发现 post 对我有帮助 GAE webapp2 session handling not working when putting basehandler to a different file

经过一些修改后,这里是我在 webapp2 中设置会话并在不同 .py 文件之间共享会话的方法。希望它可以节省其他人一些时间。

1) 创建basehandler.py,所有使用会话的.py 文件都需要导入它。这直接来自 Google 的文档:

import webapp2
from webapp2_extras import sessions

class BaseHandler(webapp2.RequestHandler):
    def dispatch(self):
        # Get a session store for this request

        self.session_store = sessions.get_store(request = self.request)

        try:
            webapp2.RequestHandler.dispatch(self)
        finally:
            self.session_store.save_sessions(self.response)

    @webapp2.cached_property
    def session(self):
        # Returns a session using the default cookie key
        return self.session_store.get_session()

2) 创建 main.py 导入 BaseHandler。在我的例子中,我在会话中存储了一个值:

import os
import urllib
import webapp2
import jinja2
from basehandler import BaseHandler


JINJA_ENVIRONMENT = jinja2.Environment(
    loader=jinja2.FileSystemLoader(os.path.dirname(__file__)),
    extensions=['jinja2.ext.autoescape'])

class MainPage(BaseHandler):
    def get(self):

    self.session['foo'] = 'bar'    # Store a value in the session
                                   # you can store more than one :-)


    # Define values that will be passed onto the template 
    template_values = {
        'title': 'TITLE'
    }

    # search for an appropriate template and render it. 
    template =      JINJA_ENVIRONMENT.get_template('./templates/index.html')
    self.response.write(template.render(template_values))

config = {}
config['webapp2_extras.sessions'] = {   
'secret_key': 'my-super-secret-key'
}

application = webapp2.WSGIApplication([
    ('/', MainPage)
], config = config, debug = True)

3) 创建 another.py 并注意导入 BaseHandler 并使用相同的密钥。在这里,您可以检索 main.py 或共享同一会话的任何其他 .py 文件存储的值:

import os
import urllib
import webapp2
import jinja2
from basehandler import BaseHandler


JINJA_ENVIRONMENT = jinja2.Environment(
    loader=jinja2.FileSystemLoader(os.path.dirname(__file__)),
    extensions=['jinja2.ext.autoescape'])

class AnotherPage(BaseHandler):
    def get(self):

    foo1 = self.session.get('foo')

    # Now go and do something with foo1, even store a new value as in main.py
    # ...
    # ...

    # Define values that will be passed onto the template 
    template_values = {
        'title': 'TITLE'
    }

    # search for an appropriate template and render it. 
    template =      JINJA_ENVIRONMENT.get_template('./templates/additional.html')
    self.response.write(template.render(template_values))

config = {}
config['webapp2_extras.sessions'] = {   
'secret_key': 'my-super-secret-key'
}

application = webapp2.WSGIApplication([
    ('/', AdditionalPage)
], config = config, debug = True)