python3+flask 开发web(二)

本文深入讲解了Flask框架中的请求对象request,解析其基于ThreadLocal的工作原理,以及如何通过装饰器增强视图函数功能,实现对请求头信息的获取。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、Flask中的请求对象request

在介绍flask中的request之前,先简单介绍下python中的ThreadLocal对象。ThreadLocal,故名思义,就是线程中的全局变量,

看一下下面的代码:

import threading

localobj=threading.local()

def threadfunc(name):
    localobj.name=name
    print ('localobj.name is %s' %name)

if __name__=="__main__":
    t1=threading.Thread(target=threadfunc,args=('Hyman',))
    t2 = threading.Thread(target=threadfunc, args=('navylu',))
    t1.start()
    t2.start()
    t1.join()
    t2.join()

执行结果:

localobj就是一个Threadlocal对象,他对于每个线程来说是全局的,但是对于不同线程之间又可以保持不同。而flask中的请求对象request就是这类对象。在多线程服务器中客户端每建立一个链接,服务器就创建一个线程,每个线程中就会有一个request来表示客户端的链接请求信息。


再来段代码:

from flask import Flask
from flask import request

app=Flask(__name__)


@app.route('/')
def index():
    user_agent=request.headers.get('User_Agent')
    return 'user_agent is %s' %user_agent
    return 'hello world'

if __name__=='__main__':

    app.run()

执行后,浏览器打开:

2、python中修饰器/装饰器,它的作用:装饰器本质上是一个Python函数,它可以让其他函数在不需要做任何代码变动的前提下增加额外功能,装饰器的返回值也是一个函数对象

来上一段代码:

from time import ctime,sleep

def settime(myfunc):
    def tempfun():
        print('[%s] %s called' %(ctime(),myfunc.__name__))
        return myfunc
    return tempfun

@settime
def myfunc():
    pass

myfunc()
sleep(4)

for i in range(2):
    myfunc()
    sleep(1)

settime就是myfunc的一个修饰器,修饰器分为带参和不带参两种,这里的参数是指除被修饰函数以外的参数,上述修饰器属于不带参修饰器,修饰器中需要自己定义一个额外的函数(temfun()),该函数把被修饰函数(myfunc())作为返回值,而修饰器将该函数(temfun())作为返回值。函数一旦被修饰器修饰 ,以后再调用时就不是单纯的调用该函数,上述代码实现了在每次调用myfunc前打印输出当前的时间。

flask中将每个视图函数都用修饰器进行了修饰,并将其保存在全局的映射中,当IE客户端输入所需的URL时,会从该映射中查找到对应的视图函数,然后进行调用

参考博文:https://blog.youkuaiyun.com/hyman_c/article/details/52551250

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值