在web运行中很重要的一个功能就是加载静态文件,在django中可能已经给我们设置好了,我们只要直接把模板文件
放在templates就好了,但是你知道在基础中,像图片是怎么加载以及找到相应位置的吗?
下面我们来看看。
在上篇文章中我把,静态文件的路径单独出来在这里说说了,正好说说全局变量request的作用。
首先,我们写前端图片的路径:
1
|
< img src = "/static?file=1.gif" /> |
看到这里,可能已经有人看出来了,对的,我们把图片路径看成url路径和参数。
这里要说下,当浏览器看到img标签,它会给服务器发请求,所以路径相当于:
1
|
127.0.0.1/static?file=1.gif |
懂了吧,实际上就是请求的路径是static,参数是file = 1.gif
然后这里我们有个函数parse_path(),
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
def parsed_path(path): """ /ss?message=hello world&author=fei 返回如下字典形式 { 'message': 'hello world', 'author': 'fei', } """ index = path.find('?') if index == -1: return path, {} else: path, query_string = path.split('?', 1) args = query_string.split('&') query = {} for arg in args: k, v = arg.split('=') query[k] = v return path, query |
把路径传进去,就会把file和1.gif传进request里,如下
1
2
3
|
{ 'file' = '1.gif', } |
这样,我们就把参数化为字典形式,然后
1
2
3
|
r = { '/static': route_static, } |
当请求的路径为static是就会转向route_static函数,这个函数写在路由里,所以我们需要引入一下
1
|
response = r.get(path, error) |
1
|
return response(request) |
这样,显示图片就会转向route_static函数。
我们看下这个函数:
1
2
3
4
5
6
7
8
9
10
|
def route_static(request): """ 静态资源的处理函数, 读取图片并生成响应返回 """ filename = request.query.get('file', '1.gif') path = 'static/' + filename with open(path, 'rb') as f: header = b'HTTP/1.1 200 OK\r\nContent-Type: image/gif\r\n\r\n' img = header + f.read() return img |
我们看下,下面这句话
1
|
filename = request.query.get('file', 'ceshi.gif') |
这样filename就会去request的query里找file键,如果有就返回,如果没有就返回ceshi.gif
然后就是同样的套路,读取,然后返回。
这样,一个把静态文件放在指定位置,并读取,就完成了
以上这篇python web基础之加载静态文件实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:http://blog.csdn.net/qq_37561761/article/details/79322067