目录

1.ORM中的锁和事务

2.Ajax

3.中间件:Middleware

  3.1 什么是中间件?

  3.2 django请求的生命周期

  3.3 中间件可以定义的5个方法

  3.4 自定义中间件的流程

  3.5 关于中间件的方法的执行顺序

ORM中的锁和事务

select查询语句上锁

在mysql中create,update,delete语句是默认要上锁的,select查询默认是不上锁的,如果要给select语句上个锁,需要在后面加for update

select * from app01_book for update;

在ORM中,如果想对一个查询上锁,需要使用select_for_update()

models.Book.objects.filter(price=100).select_for_update()

事务

1.装饰器形式添加事务

@transaction.atomic  # 1.装饰器形式,所有的被装饰函数中的sql语句捆绑为事务
def xx(request):
pass

装饰器形式添加事务:要注意的是!!只能为被装饰函数里面的sql语句捆绑事务,其他的语句是不可以的!!

2.给逻辑中的部分sql加事务

with语句里面的sql都捆绑为事务

# 方式2 给逻辑中的部分sql加事务
with transaction.atomic():
models.Book.objects.filter(price=100).select_for_update()
# 等同于sql语句:select * from app01_book where price=100 for update

Ajax

1.Ajax简介

AJAX(Asynchronous Javascript And XML)翻译成中文就是“异步的Javascript和XML”。即使用Javascript语言与服务器进行异步交互,传输的数据为XML(当然,传输的数据不只是XML,现在更多使用json数据)。

  AJAX 不是新的编程语言,而是一种使用现有标准的新方法。

  AJAX 最大的优点是在不重新加载整个页面的情况下,可以与服务器交换数据并更新部分网页内容。(这一特点给用户的感受是在不知不觉中完成请求和响应过程)

  AJAX 不需要任何浏览器插件,但需要用户允许JavaScript在浏览器上执行。

    a.同步交互:客户端发出一个请求后,需要等待服务器响应结束后,才能发出第二个请求;

    b.异步交互:客户端发出一个请求后,无需等待服务器响应结束,就可以发出第二个请求。

   AJAX除了异步的特点外,还有一个就是:浏览器页面局部刷新;(这一特点给用户的感受是在不知不觉中完成请求和响应过程)

2.Ajax的使用

设计一个登陆界面,用户输入用户名和密码

验证成功,跳转到首页界面

验证失败,不刷新网页,在右方提示红字用户名或密码输入错误

views.py

def login(request):

    if request.method == 'GET':
return render(request, 'login.html')
uname = request.POST.get('username') # 获取用户在页面输入的用户名
if uname == 'chao': # 验证用户名
return HttpResponse('ok') # 如果登录成功,返回一个响应字符串ok,用来在ajax做验证用
else:
ret = HttpResponse('用户名或密码输入错误')
return ret def index(request):
return render(request, 'index.html')

login.html

{% load static %}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body> {# <form action=""> #}
用户名: <input type="text" id="uname">
密码: <input type="password" id="pwd">
<input type="button" value="确定" id="btn">
<span id="error_msg" style="color:red;font-size: 12px;"></span>
{#</form>#} </body>
<script src="{% static 'js/jquery.js' %}"></script>
<script> $('#btn').click(function () {
var uname = $('#uname').val(); // 获取用户输入的用户名
var pwd = $('#pwd').val(); // 获取用户输入的面膜
$.ajax({
url:'/login/',
type:'post',
data:{username:uname,password:pwd}, // 这里的username和password名称会作为request.POST.get的参数
success:function (res) { // ajax判断状态码是200的时候,走success分支
// res接收的是请求成功之后的响应结果,views中的HttpResponse
// 可以对响应结果做一些事情
if (res === 'ok'){
location.href = '/index/'; // 跳转到index
}else {
$('#error_msg').text('用户名或者密码有误'); // 红字错误提示
}
},
error:function (res) { // ajax判断状态码是4xx或者5xx的时候,走error分支
//res 请求失败之后获取到的响应结果 5xx,4xx
console.log('>>>>>>',res);
if (res.status === 403){
$('#error_msg').text(res.responseText);
}
}
})
})
</script>
</html>

当你输入的用户名不是chao的时候,网页不会刷新,并且会像如下这样显示

中间件:Middleware

什么是中间件?

1.中间件是介于request与response处理之间的一道处理过程。

2.如果你想修改请求,例如被传送到view中的HttpRequest对象。 或者你想修改view返回的HttpResponse对象,这些都可以通过中间件来实现。

3.可能你还想在view执行之前做一些操作,这种情况就可以用 middleware来实现。

4.说的直白一点中间件是帮助我们在视图函数执行之前和执行之后都可以做一些额外的操作,

5.中间件本质上就是一个自定义类,类中定义了几个方法,Django框架会在请求的特定的时间去执行这些方法。

django请求的生命周期

中间件可以定义的5个方法

中间件可以定义五个方法,分别是:(主要的是process_request和process_response)

  • process_request(self,request)

  • process_view(self, request, view_func, view_args, view_kwargs)

  • process_template_response(self,request,response)

  • process_exception(self, request, exception)

  • process_response(self, request, response)

以上方法的返回值可以是None或一个HttpResponse对象

  1.如果是None,则继续按照django定义的规则向后继续执行。

  2.如果是HttpResponse对象,则直接将该对象返回给用户。

当用户发起请求的时候会依次经过所有的的中间件

  1.这个时候的请求是process_request

  2.最后到达views的函数中,views函数处理后,

  3.在依次穿过中间件,这个时候是process_response,最后返回给请求者。

自定义中间件的流程

1.在应用下先创建一个文件夹,名字随便起。比如叫mymiddleware

2.在mymiddleware文件夹下创建一个py文件。比如叫mid.py

3.在mid.py写上如下内容

from django.utils.deprecation import MiddlewareMixin

class Auth(MiddlewareMixin):  # 类名随意,继承MiddlewareMixin
# 如果想对请求做一些统一处理,那么就定义process_request方法
def process_request(self,request):
print('请求来啦!!!快看!!!!') def process_response(self,request,response):
# response 视图响应回来的响应对象
print('请求走啦!!!慢走!!!!')
return response # 注意!一定要些return response

4.在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',
'app01.mymiddlewares.xx.Auth', #将中间件类的路径写到这里
]
'''
注意:要把自定义中间件写在最后一行,因为中间件的执行顺序是由上到下执行的
如果第一个中间件执行不通,后面的中间件根本就没有办法执行
'''

关于中间件的方法的执行顺序

1.process_request和process_response

顺序:请求1→请求2→响应2→响应1

2.process_request和process_response + process_view

顺序:请求1→请求2→url路由→视图1→视图2→视图函数→响应2→响应1

如果在中间件1中的process_view写了return HttpResponse方法后,执行过程是这样的

3.process_request和process_response + process_view + process_exception

1.如果视图函数时正确的,执行流程如下所示

2.如果视图函数错误,执行流程如图所示

3.如果视图函数出错,并且在MD1中的process_exception方法直接返回了一个响应对象,执行流程如下所示

......

day54:django:锁和事务&Ajax&中间件Middleware的更多相关文章

  1. Django 补充models操作,中间件, 缓存,信号,分页

    1.Model 一对多 补充 models如下: class UserType(models.Model): caption = models.CharField(max_length=16) cla ...

  2. {Django基础六之ORM中的锁和事务}一 锁 二 事务

    Django基础六之ORM中的锁和事务 本节目录 一 锁 二 事务 一 锁 行级锁 select_for_update(nowait=False, skip_locked=False) #注意必须用在 ...

  3. day 71 Django基础六之ORM中的锁和事务

    Django基础六之ORM中的锁和事务   本节目录 一 锁 二 事务 三 xxx 四 xxx 五 xxx 六 xxx 七 xxx 八 xxx 一 锁 行级锁 select_for_update(no ...

  4. day 58 Django基础六之ORM中的锁和事务

      Django基础六之ORM中的锁和事务   本节目录 一 锁 二 事务 三 xxx 四 xxx 五 xxx 六 xxx 七 xxx 八 xxx 一 锁 行级锁 select_for_update( ...

  5. Django中的事务与ajax

    一 事务与锁 1.行级锁 行级锁是由存储引擎实现的.如mysql里默认指定的InnoDB存储引擎,由它实现行级锁.InnoDB的行级锁定同样分为两种类型,共享锁(X)和排他锁(S). 对于UPDATE ...

  6. Django 源码小剖: 初探中间件(middleware)

    因为考虑到文章的长度, 所以 BaseHandler 的展开被推迟了. 在 BaseHandler 中隐藏着中间件的信息, 较常见的 SessionMiddleware 就已经默认安装.  BaseH ...

  7. django中间件Middleware

    熟悉web开发的同学对hook钩子肯定不陌生,通过钩子可以方便的实现一些触发和回调,并且做一些过滤和拦截. django中的中间件(middleware)就是类似钩子的一种存在.下面我们来介绍一下,并 ...

  8. 利用Django中间件middleware解决用户未登录问题(转)

    add by zhj: Django的中间件一般用于处理通用性的问题,分为五种,按处理顺序为request_middleware,view_middleware,exception_middlewar ...

  9. Django的锁和事务

    Django的锁和事务 锁 select_for_update(nowait=False, skip_locked=False) 返回一个锁住行直到事务结束的查询集,如果数据库支持,它将生成一个 SE ...

随机推荐

  1. linux 安装sftp

    1.定义sftp的数据目录 mkdir -p /data/sftp 2.将目录归到root用户,否则无法chroot chown root. -R /data/sftp/或者chown root:ro ...

  2. centos7上借助于xargs快速查询并卸载rpm软件

    在centos上卸载某些软件的时候,如果查询的软件包比较多,可以考虑使用xargs,边查询边卸载 如:下面在查询mysql包时候,将查询结果通过管道传送给xargs,然后使用rpm -e --node ...

  3. JavaScript学习系列博客_25_JavaScript 数组(Array)

    数组 - 数组也是一个对象,是一个用来存储数据的对象,和Object类似,但是它的存储效率比普通对象要高. - 数组中保存的内容我们称为元素 - 数组使用索引(index)来操作元素 - 索引指由0开 ...

  4. Golang omitempty 的用法

    原文链接:https://blog.csdn.net/skh2015java/article/details/90720692omitempty作用是在json数据结构转换时,当该字段的值为该字段类型 ...

  5. ubuntu 本地源搭建

    1.软件包放在 deps 目录下: dpkg-scanpackages deps /dev/null |gzip > deps/Packages.gz -r 2.更新 sources.list ...

  6. App 自动化,Appium 凭什么使用 UiAutomator2?

    1. UiAutomator2 是什么 可能很多人对 UiAutomator2 和 UiAutomator 傻傻分不清楚 UiAutomator 是 Google 开发的一款运行在 Android 设 ...

  7. SEO诊断方案以及执行方案

    http://www.wocaoseo.com/thread-127-1-1.html 今天和大家一起讨论一下SEO诊断方案以及SEO执行方案要怎么写,主要从哪些方面进行呢,做SEO的朋友们一直在探讨 ...

  8. C++ int与char[]的相互转换

    C++ int与char[]的相互转换 一.itoa函数与atio函数①把int类型数字转成char类型,可以使用itoa函数. itoa函数原型: char*itoa(int value,char* ...

  9. 2020.08.23 瞎扯周记之论短暂假期(QAQ)内要不要睡午觉

    蒟蒻的假期都是很短暂的嘛 作为一只合格的蒟蒻 假期自然是很短暂的QAQ 只有短短的26h93360s(手动微笑) 总体来讲 假期只有两件事要干: 1.满足人体自身需求 2.满足作业需求 2.5.摸鱼 ...

  10. 4-6年经验左右、优秀的 Java 程序员应该具备的技能

    4-6年经验左右.优秀的 Java 程序员应该具备的技能有哪些,按“专业技能”和“项目”两块,包括但不限于以下内容. 专业节能方面 基础:JDK 常用类的原理.源码.使用场景. 设计模式:常用几种的原 ...