在 Google App Engine 中的 redirect() 函数中在页面之间传递数据
Passing data between pages in a redirect() function in Google App Engine
我正在尝试使用 GAE 构建一个简单的博客,并且编写了以下代码(我删除了与此问题无关的部分):
# LOADING THE TEMPLATE INTO THE JINJA ENVIRONMENT
template_dir = os.path.join(os.path.dirname(__file__), 'templates')
jinja_env = jinja2.Environment(loader = jinja2.FileSystemLoader(template_dir), autoescape = True)
# HELPER FUNCTION
def render_str(template, **params):
t = jinja_env.get_template(template)
return t.render(params)
# GOOGLE DATASTORE DATABASE
class Entries(db.Model):
title = db.StringProperty(required = True)
body = db.TextProperty(required = True)
created = db.DateTimeProperty(auto_now_add = True)
# HANDLER FUNCTIONS
class SignUp(webapp2.RequestHandler):
def get(self):
self.response.write(render_str('signup.html'))
def post(self):
have_error = False
username = self.request.get('username')
password = self.request.get('password')
verify = self.request.get('verify')
email = self.request.get('email')
params = dict(username = username, email = email)
if not valid_username(username):
params['error_username'] = "That's not a valid username."
have_error = True
if not valid_password(password):
params['error_password'] = "That wasn't a valid password."
have_error = True
elif password != verify:
params['error_verify'] = "Your passwords didn't match."
have_error = True
if not valid_email(email):
params['error_email'] = "That's not a valid email."
have_error = True
pwhash = make_secure_val(password)
self.response.headers.add_header('Set-Cookie', 'uid: %s' % str(pwhash))
if have_error:
self.response.write(render_str('signup.html', **params))
else:
self.redirect('/welcome')
class Welcome(webapp2.RequestHandler):
def get(self):
self.response.write(render_str('welcome.html'))
# APP HANDLERS
app = webapp2.WSGIApplication([('/', MainPage),
('/newpost', NewPost),
('/newpost/(\d+)', Permalink),
('/signup', SignUp),
('/welcome', Welcome)
], debug=True)
signup.html
是一个简单的形式,它再次接受 username
、password
、password
来验证和一个可选的 email
.
make_secure_val()
只是一个哈希函数,它 returns 一个 HMAC
格式的参数字符串的哈希版本 argument|HMAC(argument)
.
所以,这是我的问题:一旦用户注册,我想要重定向到另一个 URL /welcome
,从而让我使用 redirect()
功能。但我也想打印 username
用户在欢迎页面上输入的表单。我知道如何在 redirect()
中传递变量的唯一方法是通过 GET
传递到 URL。但我不希望 URL 显示用户名。我想像 render_str()
一样将它作为模板变量传递。但是如果我在SignUp
的POST
方法中使用render_str()
,URL仍然是/signup
。
如何将数据传递给 redirect()
?
您可以使用 webapp2 sessions 以更加灵活和安全的方式跨多个请求共享数据,而无需将其编码为 URL。
查看此问答示例:Webapp2 Sessions in Google app engine
我正在尝试使用 GAE 构建一个简单的博客,并且编写了以下代码(我删除了与此问题无关的部分):
# LOADING THE TEMPLATE INTO THE JINJA ENVIRONMENT
template_dir = os.path.join(os.path.dirname(__file__), 'templates')
jinja_env = jinja2.Environment(loader = jinja2.FileSystemLoader(template_dir), autoescape = True)
# HELPER FUNCTION
def render_str(template, **params):
t = jinja_env.get_template(template)
return t.render(params)
# GOOGLE DATASTORE DATABASE
class Entries(db.Model):
title = db.StringProperty(required = True)
body = db.TextProperty(required = True)
created = db.DateTimeProperty(auto_now_add = True)
# HANDLER FUNCTIONS
class SignUp(webapp2.RequestHandler):
def get(self):
self.response.write(render_str('signup.html'))
def post(self):
have_error = False
username = self.request.get('username')
password = self.request.get('password')
verify = self.request.get('verify')
email = self.request.get('email')
params = dict(username = username, email = email)
if not valid_username(username):
params['error_username'] = "That's not a valid username."
have_error = True
if not valid_password(password):
params['error_password'] = "That wasn't a valid password."
have_error = True
elif password != verify:
params['error_verify'] = "Your passwords didn't match."
have_error = True
if not valid_email(email):
params['error_email'] = "That's not a valid email."
have_error = True
pwhash = make_secure_val(password)
self.response.headers.add_header('Set-Cookie', 'uid: %s' % str(pwhash))
if have_error:
self.response.write(render_str('signup.html', **params))
else:
self.redirect('/welcome')
class Welcome(webapp2.RequestHandler):
def get(self):
self.response.write(render_str('welcome.html'))
# APP HANDLERS
app = webapp2.WSGIApplication([('/', MainPage),
('/newpost', NewPost),
('/newpost/(\d+)', Permalink),
('/signup', SignUp),
('/welcome', Welcome)
], debug=True)
signup.html
是一个简单的形式,它再次接受 username
、password
、password
来验证和一个可选的 email
.
make_secure_val()
只是一个哈希函数,它 returns 一个 HMAC
格式的参数字符串的哈希版本 argument|HMAC(argument)
.
所以,这是我的问题:一旦用户注册,我想要重定向到另一个 URL /welcome
,从而让我使用 redirect()
功能。但我也想打印 username
用户在欢迎页面上输入的表单。我知道如何在 redirect()
中传递变量的唯一方法是通过 GET
传递到 URL。但我不希望 URL 显示用户名。我想像 render_str()
一样将它作为模板变量传递。但是如果我在SignUp
的POST
方法中使用render_str()
,URL仍然是/signup
。
如何将数据传递给 redirect()
?
您可以使用 webapp2 sessions 以更加灵活和安全的方式跨多个请求共享数据,而无需将其编码为 URL。
查看此问答示例:Webapp2 Sessions in Google app engine