接上文基础(3),假如又有新的需求:在用户登录时候,加一个token验证功能,怎么破?

见代码:

#basic4.py

#coding:utf-8

def login(key):
    local_key = "78A7AS78AAGD68AH23JB23JH34J2JH42JH46N35NK24235SDMmasdaldjkasldkasdkla"
    if local_key == key:
        return True
    else:
        return False

def auth(func):
    def inner(*arg, **kwargs):
        print 'before'
        # key = kwargs['token']
        # del kwargs['token']
        key = kwargs.pop('token')  #kwargs.pop相当于上面2句,先取出key,然后删除key。
        is_login = login(key)
        if not is_login:
            return '非法用户!'
        # func代指 fetch_server_list 原函数
        temp = func(*arg,**kwargs)
        print 'after'
        return temp
    return inner

@auth
def fetch_server_list(arg):
    serve_list = ['c1','c2','c3']
    return serve_list

执行部分:

#b4.py
import basic4

key = "78A7AS78AAGD68AH23JB23JH34J2JH42JH46N35NK24235SDMmasdaldjkasldkasdkla"

ret_list = basic4.fetch_server_list('test',token=key)
print ret_list

执行结果:

#python b4.py
before
after
['c1', 'c2', 'c3']