1

私はプログラミングに慣れていないので、これを間違えている可能性は十分にありますが、これが私がやろうとしていることです。

あるクラスでユーザー入力を受け取り、それを別のクラスに渡すフォームを持つプログラムを作成しようとしていますが、その方法がわかりません。関連するコードのスニペットは次のとおりです(渡そうとしているユーザー名変数の周りに*を付けます):

class MainHandler(webapp2.RequestHandler):
  #this is in a form
   def post(self):
    ***username*** = self.request.get('username')

  #if username and other info entered correctly, then it redirects user to a new page and the WelcomeHandler class, so how do I get the username into the "Welcome, " message below?:


class WelcomeHandler(webapp2.RequestHandler):
    def get(self):
        self.response.out.write("Welcome, " + ***username***)

編集:それが役立つなら、これが私のコード全体です:

import webapp2
import re
import cgi

form="""

<form method = "post">   
Signup
<br>

<table>
    <tbody>            
      <tr><td><label>Username</label></td><td><input type="text" name = "username" 
 value="%(username)s"><div style="color: red">%(error)s</div> </td></tr>

<br>
     <tr><td> <label>Password</label></td><td><input type="password" name = "password" 
value="%(password)s"><div>TK TK TK</div></td></tr>

<br>
    <tr><td> <label> Verify password</label></td><td><input type="password" name = 
"verify" value="%(verify)s"><div> TK TK TK</div></td></tr>

<br>
    <tr><td> <label> Email(optional)</label></td><td><input type = "text" name = "email"
 value ="%(email)s"><div> TK TK TK</div></td></tr>

 </tbody>
</table>
<br>
<br>
<input type = "submit">
</form>
"""


def escape_html(s):
    return cgi.escape(s, quote = True)

def valid_username(username):
    USER_RE = re.compile(r"^[a-zA-Z0-9_-]{3,20}$")
    return USER_RE.match(username)

def valid_password(password):
    USER_RE = re.compile(r"^.{3,20}$")
    return USER_RE.match(password)

def verify_password(password, verify):
    if verify == password:
        return True
    else:
        return False

def valid_email(email):
    USER_RE = re.compile(r"^[\S]+@[\S]+\.[\S]+$")
    return USER_RE.match(email)

class MainHandler(webapp2.RequestHandler):
    def write_form(self, error="", username="", password="", verify="", email=""):
        self.response.out.write(form % {'error': error, "username": 
escape_html(username), "password": escape_html(password), "verify": escape_html(verify),
 "email": escape_html(email)})

    def get(self):
        self.write_form()


    def post(self):
        username = self.request.get('username')
        password = self.request.get('password')
        verify = self.request.get('verify')
        email = self.request.get('email')

        username_check = valid_username(username)
        password_check = valid_password(password)
        verify_check = verify_password(password, verify)
        email_check = valid_email(email)

        if not (username_check and password_check and verify_check):
            self.write_form("That's not valid, you jive turkey", username, password, 
verify, email)
        else:
            self.redirect("/welcome")

class WelcomeHandler(webapp2.RequestHandler):
    def get(self):
        self.response.out.write("Welcome, " + username)


app = webapp2.WSGIApplication([
        ('/', MainHandler),
        ('/welcome', WelcomeHandler)], debug=True)
4

3 に答える 3

4

あなたはこれをしたくありません。これは単なる通常のクラスベースのプログラミングではありません。これらの各クラスは、ブラウザーからサーバーへの要求を表します。クラス間でそのデータを渡すとはどういう意味でしょうか?

実際にやりたいことは、ブラウザーに GET ハンドラーにリダイレクトするように指示することです。

于 2012-06-14T14:59:08.463 に答える
1

webapp2 doc でCookie の設定と Cookie読み取りを確認してください。

于 2012-06-14T15:00:17.960 に答える
1

ダニエルが言ったこと-HTTPリクエスト/レスポンスサイクルと、RequestHandlerインスタンスがそれにどのように結び付けられているかを理解する必要があります。

ここでの通常の解決策は、「セッション」を使用することです。これは、通常、ユーザーのブラウザーに Cookie として保存されている不透明なキーによって識別される特定のユーザーに対して、ある要求から別の要求にデータを永続化するメカニズムです。FWIW、適切な Web フレームワークはセッションのサポートを提供する必要があるため、ここでフレームワークのドキュメントを読むことをお勧めします。

于 2012-06-14T17:28:27.093 に答える