Python中Tornado下用户身份认证的实现方法


本文摘自php中文网,作者不言,侵删。

本篇文章给大家带来的内容是关于Python中Tornado下用户身份认证的实现方法,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

在Tornado的RequestHandler类中有一个current_user属性用于保存当前请求的用户名。RequestHandler.get_current_user的默认值是None,在get()、post()等处理函数中可以随时读取该属性以获取当前的用户名。RequestHandler.current_user是一个只读属性,所以如果想要设置该属性值,需要重载RequestHandler.get_current_user()函数以设置该属性值。

实例:使用RequestHandler.current_user属性及RequestHandler.get_current_user()方法来实现用户身份控制。

代码:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

import tornado.web

import tornado.ioloop

import uuid  #UUID 生成库

 

dict_sessions={}  #保存所有登录的Session

 

class BaseHandler(tornado.web.RequestHandler):  #公共基类

    #写入current_user的函数

    def get_current_user(self):

        session_id=self.get_secure_cookie("session_id")

        return dict_sessions.get(session_id)

 

class MainHandler(BaseHandler):

    @tornado.web.authenticated    #需要身份认证才能访问的处理器

    def get(self):

        name=tornado.escape.xhtml_escape(self.current_user)

        self.write("Hello,"+name)

 

class LoginHandler(BaseHandler):

    def get(self):   #登陆页面

        self.write('<html><>body'

                   '<form action="/login" method="post">'

                   'Name:<input type="text" name="name">'

                   '<input type="submit" value="Sign in">'

                   '</form></body></html>')

    def post(self):  #验证是否运行登陆

        if len(self.get_argument("name"))<3:

            self.redirect("/login")

        session_id=str(uuid.uuid1())

        dict_sessions[session_id]=self.get_argument("name")

        self.set_secure_cookie("session_id",session_id)

        self.redirect("/")

setting={

    "cookie_secret":"SECRET_DONT_LEAK", #Cookie加密秘钥

    "login_url":"/login"  #定义登陆页面

}

application=tornado.web.Application([

    (r"/",MainHandler),        #URL映射定义

    (r"/login",LoginHandler)

],**setting)

 

def main():

    application.listen(8888)

    tornado.ioloop.IOLoop.current().start()     #挂起监听

 

if __name__ == '__main__':

    main()

本例演示了一个完整的身份认证编程框架,整体构思如下:

  • 用全局字典dict_sessions保存已经登录的用户信息,为了简单些,本例只保存了【回话ID:用户名】的键值对。

  • 定义公共基类BaseHandler,该类继承自tornado.web.RequestHandler,用于定义本网站所有处理器的公共属性和行为。重载它的get_current_user()函数,其在访问RequestHandler.current_user属性时自动被Tornado调用。该函数首先用get_secure_cookie()获得本次访问的回话ID,然后利用该ID从dict_sessions中获得用户名并且返回。

  • MainHandler类是一个要求用户经过身份认证才能访问的处理器实例。该处理器中的处理函数get()使用了装饰器tornado.web.authenticated,具有该装饰器的处理函数在执行之前根据current_user是否已经被赋值来判断用户的身份认证情况,如果已经被赋值则可以进行正常逻辑,否则自动重定向到网站的登录页面。

  • LoginHandler类是登录页面处理器,其get()函数用于渲染登录页面,post()函数用于验证是否允许用户登陆。

  • 在tornado.web.Application的初始化函数中通过login_url参数给出网站的登陆页面地址。该地址被用于tornado.web.authenticated装饰器在发现用户尚未验证时重定向到一个URL。

注意:加入身份认证的所有页面处理器需要继承自BaseHandler类,而不是直接继承原来的tornado.web.RequestHandler类。

商用的身份认证还要完善更多的内容,比如加入密码验证机制、管理登陆超时、将用户信息保存到数据库等。

以上就是Python中Tornado下用户身份认证的实现方法的详细内容,更多文章请关注木庄网络博客!!

相关阅读 >>

用matplotlib如何绘制条形图、直方图和散点图

Python 2.7在linux下安装或升级的操作方法

Python怎么输出hello world代码

自学Python看什么

Python中关于strip使用方法的小妙招

Python多线程socket编程中将多客户端接入的方法

windows怎么打开Python

Python setup是什么

Python--条件语句与循环语句

如何截取一个字符串获得子串

更多相关阅读请进入《Python》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...