程序员Python和Django中间件基础用法详解
首先django的中间件可以在视图函数执行前执行,比如登陆验证、日志记录等,下面简单说明一下中间件的基础用法吧。
1.在django项目文件夹下创建一个用于存放中间件函数的文件夹
文件夹的名字可自定义,本文使用utils作为文件夹名
2.在utils文件夹中创建中间件py文件
如用于登陆验证的中间件loginCheck.py
from django.http import HttpResponseRedirect
from django.utils.deprecation import MiddlewareMixin
class UserLoginCheck(MiddlewareMixin):
‘’’
登录验证中间件
‘’’
def process_request(self, request):
用户request请求前
path = [’/login/’, ‘/logout/’] # 不需要进行登录检测的url
if request.path in path:
return
userinfoSession = request.session.get(‘userinfo’)
if not userinfoSession:
return HttpResponseRedirect(’/login/’)
return
3.配置使用中间件
在setting.py文件中配置中间件
MIDDLEWARE = [
‘django.middleware.security.SecurityMiddleware’,
‘django.contrib.sessions.middleware.SessionMiddleware’,
‘django.middleware.common.CommonMiddleware’,
‘django.middleware.csrf.CsrfViewMiddleware’,
‘django.contrib.auth.middleware.AuthenticationMiddleware’,
‘django.contrib.messages.middleware.MessageMiddleware’,
‘django.middleware.clickjacking.XFrameOptionsMiddleware’,
‘utils.loginCheck.UserLoginCheck’, # 此处为自定义的中间件
]
扩展
中间件可定义的五种方法
Request预处理函数:process_request(self,request)
这个方法的调用时机在Django接收到request之后,但仍未解析URL以确定应当运行的视图函数。Django向它传入相应的Request对象,以便在方法中修改。
如果返回None,Django将继续处理这个request,执行后续的中间件,然后调用相应的view。
如果返回HttpResponse对象,https://www.7dadi.com/siteinfo/27672.htmlDjango将不再执行任何除了process_response以外其它的中间件以及相应的view,Django将立即返回该HttpResponse。
View预处理函数:process_view(self,request,callback,callback_args,callback_kwargs)
这个方法的调用时机在Django执行完request预处理函数并确定待执行的view(即callback参数)之后,但在view函数实际执行之前。
request:HttpRequest对象。
callback:Django将调用的处理request的python函数.这是实际的函数对象本身,而不是字符串表述的函数名。
args:将传入view的位置参数列表,但不包括request参数(它通常是传入view的第一个参数)。
kwargs:将传入view的关键字参数字典。
process_view()应当返回None或HttpResponse对象。如果返回None,Django将继续处理这个request,执行后续的中间件,然后调用相应的view。
如果返回HttpResponse对象,Django将不再执行任何其它的中间件(不论种类)以及相应的view,Django将立即返回。
Template模版渲染函数:process_template_response()
默认不执行,只有在视图函数的返回结果对象中有render方法才会执行,并把对象的render方法的返回值返回给用户(注意不返回视图函数的return的结果了,而是返回视图函数return值(对象)中rende方法的结果)
Exception后处理函数:process_exception(self,request,http://www.xingkongmj.com/news/id/76.htmlexception)
这个方法只有在request处理过程中出了问题并且view函数抛出了一个未捕获的异常时才会被调用。这个钩子可以用来发送错误通知,将现场相关信息输出到日志文件,或者甚至尝试从错误中自动恢复。
这个函数的参数除了一贯的request对象之外,还包括view函数抛出的实际的异常对象exception。
process_exception()应当返回None或HttpResponse对象。
如果返回None,Django将用框架内置的异常处理机制继续处理相应request。
如果返回HttpResponse对象,Django将使用该response对象,而短路框架内置的异常处理机制。
Response后处理函数:process_response(self,request,http://www.xingkongmj.com/news/id/75.htmlesponse)
这个方法的调用时机在Django执行view函数并生成response之后。
该处理器能修改response的内容;一个常见的用途是内容压缩,如gzip所请求的HTML页面。
这个方法的参数相当直观:request是request对象,而response则是从view中返回的response对象。
process_response()必须返回HttpResponse对象.这个response对象可以是传入函数的那一个原始对象(通常已被修改),也可以是全新生成的。
希望对同学们学习java开发有所帮助,首先对于java工程师来说,static非常容易在面试的时候被问到。书面上说static是静态的。其实我把它理解为“全局的”。什么叫全局的?全局的属性,全局的方法,全局的代码块。
全局属性,全局方法,比较好理解就是这个类所有的对象都共有的属性和方法。因为是整个类共有的,所以可以通过声明直接调用。我把它理解为“单例模式”的属性和方法。所谓单例模式就是指这个类声明的所有对象共享这些属性和方法。一个对象对这个属性进行了修改,所有对象再调这个属性都是修改后的值了。
下面主要说一下static修饰的代码块,面试的一大考点就是static代码块是什么时候被加载的。
首先我们需要了解一下java虚拟机对类的加载过程。首先JVM会通过classloader将类的字节码转换成相应的Class对象。其中classloader是双亲委托的方法来查找类文件的。
就是首先委托父类的classloader查找(父类也有父类就交由父类的父类查找以此类推,直到不再继承别的classloader的类),如果查找不到再由自己来查找。如果自己也找不到就抛出异常。以上是准备工作,当这个类抽次被使用,我们会显出石化这个类(如果有父类就先初始化他的父类),在初始化的过程中我们会处理static修饰的代码。就是我们这里要说的static代码块。每个类知会初始化1次。(我们可以通过改变方法Class.forName()中的第二个参数来控制是否初始化一个类)。
以下为网上找的一个经典的例子。
面试题目如下:请写出程序执行完成之后的结果。
package http://lingduxh.com/article/2.htmlextend;
public class X {
Y y=new Y();
static{
System.out.println(“tttt”);
}
X(){
System.out.println(“X”);
}
public static void main(String[] args) {
new Z();
}
}
class Y{
Y(){
System.out.println(“Y”);
}
}
class Z extends X{
Y y=new Y();
static{
System.out.println(“tt”);
}
Z(){
System.网络软文发布out.println(“Z”);
}
}
先不告诉最后结果,我们先来分析下。一步一步推出结果。
1.首先分析一段程序的执行后的结果,我们得先找到程序的入口,然后才能着手分析。也就是main()方法。
2.我们发现main()方法在X类中,要执行main()方法,还得先将X类加载到内存中。
3.X类加载完成后,会做什么事情呢?别急,先来看看static的作用,不知道吧。告诉你:static就是在类被第一次加载的时候执行,以后就不再执行。
4.知道了static的作用,那么X类被加载,那么就会先执行X类的静态属性和静态语句块(static),执行先后顺序看谁在前面就先执行谁。只在此时执行,以后都不会。
5.所以一个输出结果为tttt,没问题了吧。
6.X类的static语句块执行完了,就该执行main()方法啦。
7.newZ();此方法被执行。
8.既然newZ();那么Z类就要被加载。因为Z类继承X类。所以必须先加载X类才行。因为X类已经被加载。所以此时不用再加载X类了。Z类加载好了就要执行Z类的static语句块
软文营销范文与广告文案如何相互关联从而达成潜在效果
9.那么就会打印出tt了吧。
10.都加在完后就要实例化对象了。
11.实例化Z之前,还得先实例化X对吧。因为子类的构造方法都会调用父类的构造方法。
12.那就先实例化X类吧。
13.执行X方法前还得先初始化对不。也就是获取所有属性。那么X类的属性Y就会获取。
14.即X类的Yy=newY();要被执行。也就是会打印Y。
15.接着执行System.out.println(“X”);
16.然后就是执行Z的构造方法
17.同样先获取Z的属性Yy=newY();打印Y。
18.再执行System.out.println(“Z”);
整个过程就是这样了。现在知道结果了吧:
tttt
tt
Y
X
Y
Z
记住,面试有可能会标出一些语句的,让你选择这些语句的执行顺序。不过只要知道原理,就没什么难的了。
以上就是关于好程序员Java培训之类的实例化步骤详解的全部内容,希望本文的内容对大家的学习或者工作具有一定的参考学习价值。
本文地址:https://blog.csdn.net/weixin_52850661/article/details/110153428
上一篇: webpack的使用与理解
下一篇: 单调队列——滑动窗口