Usersによるユーザー認証とエンティティ操作 (4/6)
作成:2010-01-03 19:11
更新:2010-05-10 21:37
更新:2010-05-10 21:37
■DeletePageクラスの作成
では、このdelete.htmlテンプレートを利用するコントローラークラスを作成しましょう。ここでは、'/del'アクセスすると、DeletePageクラスの処理が呼び出されるようにします。webapp.WSGIApplicationのインスタンス作成文を以下のように修正しておきましょう。
ここでは、getメソッドではusers.get_current_userで現在のユーザーのusersを取得し、これがNoneだった場合には、以下のようにしてログインページにリダイレクトをしています。
さて、肝心のエンティティを削除する処理ですが、これは以下のような形で行っています。
application = webapp.WSGIApplication([そして、main.pyに以下のリストのようにDeletePageクラスの処理を追記します。
('/', MainPage),
('/del',DeletePage)
], debug=True)
ここでは、getメソッドではusers.get_current_userで現在のユーザーのusersを取得し、これがNoneだった場合には、以下のようにしてログインページにリダイレクトをしています。
self.redirect(users.create_login_url(self.request.uri))このように、users.create_login_urlで取得したアドレスをself.redirectでリダイレクトすることで、ログインページにジャンプし、ログイン後に再び必要なページに戻る処理が作成できます。
さて、肝心のエンティティを削除する処理ですが、これは以下のような形で行っています。
data = MyData.get_by_id(long(id))「get_by_id」メソッドで指定したID番号のエンティティを取得し、その「delete」メソッドを呼び出すだけでエンティティは削除されます。実に単純ですね。
data.delete()
(by. SYODA-Tuyano.)
※プログラムリストが表示されない場合
AddBlockなどの広告ブロックツールがONになっていると、プログラムリスト等が表示されない場合があります。これらのツールをOFFにしてみてください。
●プログラム・リスト●
class DeletePage(webapp.RequestHandler):
def get(self):
usr = users.get_current_user()
if usr == None:
self.redirect(users.create_login_url(self.request.uri))
return
id = self.request.get('id')
if id:
data = MyData.get_by_id(long(id))
msg = 'これを削除していいですか?'
else:
data = None
msg = '削除するエンティティのIDが指定されていません。'
params = {'data':data,
'message':msg}
fpath = os.path.join(os.path.dirname(__file__),'views','delete.html')
html = template.render(fpath,params)
self.response.headers['Content-Type'] = 'text/html'
self.response.out.write(html)
def post(self):
id = self.request.get('id')
data = MyData.get_by_id(long(id))
data.delete()
self.redirect('/')
※関連コンテンツ
「PythonによるGoogle App Engine(GAE)プログラミング入門」に戻る