Django高级
静态文件
包含工程中的CSS, JS, 图片,Json等文件
{% load static from staticfiles %}
<!DOCTYPE html>
<html>
<script type = 'text/javascript' src = '{% static "js/nian.js" %}'></script>
</html>
中间件
概述
一个轻量级、底层的插件系统,可以介入Django的请求和响应处理过程,修改Django的输入和输出。每一个中间组件都是一个独立的Python类
自定义中间件
- 工程目录下创建名为middlewares的目录
- 在middlewares目录下创建项目目录同名的目录
- 在上一步创建的目录下创建中间件的Py文件
- 在文件中定义中间件类
- 在settings.py文件中的MIDDLEWARE中添加’middlewares.myApp.myMiddle.MyMiddle’
- 注意:使用中间件,可以干扰整个处理过程,每次请求都会执行中间件的这些方法
方法
- __init__.py:无需任何参数,服务器响应第一个请求时调用一次,用于确认是否启用当前中间件
- process_request(request):执行试图之前被调用,每个请求都会调用,返回None或者HttpResponse对象
- process_view(request, view_func, view_args, view_kwags):执行视图之前被调用,每个请求上都会调用,返回None或者HttpResponse
- process_template_response(request, response):在视图刚好执行完毕之后被调用,每个请求中都会调用,返回实现了render方法的响应对象
- process_response(request, response):响应浏览器之前被调用,每个请求都会调用,返回HttpResponse对象
- process_exception(request, exception):当视图抛出异常时调用,每个请求都会调用,返回HttpResponse对象
示例
from django.utils.deprecation import MiddlewareMixin
from django.http import HttpResponse
class MyMiddle(MiddlewareMixin):
def process_request(self, request):
if request.COOKIES.get('nian') == 'bad':
return HttpReponse('Nice day')
上传文件
概述
当Django在处理文件时,文件的 数据会被保存在request.FILES
服务器接收上传文件
在static目录下创建名为media的目录
MEDIA_ROOT = os.path.join(BASE_DIR, r'static\media')
# html代码
<form action = '/upfile/' method = 'post' enctype = 'multipart/form-data'>
<input type = 'file' name = 'file'>
<input type = 'submit' value = '提交'>
</form>
# 视图函数
import os
from django.conf import settings
def upfile(request):
if request.method == 'GET':
return render(request, 'upfile.html')
else:
# 保存文件
for key in request.FILES:
fileObj = request.FILES[key]
filePath = os.