这里将介绍一下Django 3.0的版本说明!!!!!!!


一,Python兼容性

1,Django 3.0支持Python 3.6、3.7、3.8和3.9(自3.0.11起)。强烈建议并仅正式支持每个系列的最新版本。
2,Django 2.2.x系列是最后一个支持Python 3.5的系列。


二,数据库的支持

在数据库支持方面,一方面Django 3.0将放弃对PostgreSQL 9.4版本和Oracle 12.1版本的支持。但是另一方面Django 3.0将支持使用MariaDB 10.1或更高版本的数据库。对于开发者来说,最初上手Django框架一般是Django+MySQL/PostgreSQL来搞Web,现在可以借此机会尝试下MariaDB,相比于PostgreSQL,MariaDB更类似与MySQl,而且MariaDB相比MySQL来说会有更多的存储引擎类型和稍微快一点的查询效率,所以对于基于MySQL作为存储引擎的后端开发,可以尝试切换成MariaDB。更多的对比可以参考mariadb-vs-mysql。


三,PostgreSQL的排斥约束

1,新ExclusionConstraint类允许在PostgreSQL上添加排除约束。使用Meta.constraints选项将约束添加到模型。
2,ExclusionConstraint定义类普通的约束定义类似

class ExclusionConstraint(*, name, expressions, index_type=None, condition=None) 

3,同样的,我们也可以使用Meta.constraints把约束加入Model。

from django.contrib.postgres.fields import DateTimeRangeField, RangeOperators
from django.db import models
from django.db.models import Q

class Room(models.Model): # 建议房间模型
    number = models.IntegerField()

class Reservation(models.Model): # 建立预约模型
    room = models.ForeignKey('Room', on_delete=models.CASCADE) # 级联外键
    timespan = DateTimeRangeField() # 新建两个字段
    cancelled = models.BooleanField(default=False)

 class Meta: # 定义约束
        constraints = [
 ExclusionConstraint( # 排斥约束
                name='exclude_overlapping_reservations',
                expressions=[ # timespan字段不在函数范围内排斥
 ('timespan', RangeOperators.OVERLAPS),
 ('room', RangeOperators.EQUAL),
 ],
                condition=Q(cancelled=False),
 ),
 ] 

四,过滤器表达式

这个变动是在QuerySet过滤器中的,现在BooleanField可以直接在QuerySet过滤器中使用输出的表达式,而不必首先注释,然后针对注释进行过滤。


五,模型字段选择的枚举

1,在之前的Django版本,我们在model的field字段需要枚举的时候通常需要这么做

from django.utils.translation import gettext_lazy as _

class Student(models.Model): # 定义模型

 class YearInSchool(models.TextChoices): # 定义TextChoices类
        FRESHMAN = 'FR', _('Freshman')
        SOPHOMORE = 'SO', _('Sophomore')
        JUNIOR = 'JR', _('Junior')
        SENIOR = 'SR', _('Senior')
        GRADUATE = 'GR', _('Graduate')

    year_in_school = models.CharField( # 引用TextChoices类作为枚举选择
        max_length=2,
        choices=YearInSchool.choices,
        default=YearInSchool.FRESHMAN,
 )

 def is_upperclass(self):
 return self.year_in_school in {YearInSchool.JUNIOR, YearInSchool.SENIOR}

2,从上面可以看出,Django中没有特定的枚举字段,需要我们手动去指定,而在Django 3.0中,自定义枚举类型TextChoices,IntegerChoices和Choices现在作为一个的方式来定义Field.choices。为文本和整数字段提供了类型TextChoices 和IntegerChoices类型。在 Choices类允许定义为其他具体的数据类型兼容的枚举。这些自定义枚举类型支持人类可读的标签,可以通过枚举或其成员上的属性来翻译和访问这些标签。举个例子,上面的代码我们可以这么来写:

class Student(models.Model):
    FRESHMAN = 'FR'
    SOPHOMORE = 'SO'
    JUNIOR = 'JR'
    SENIOR = 'SR'
    GRADUATE = 'GR'
    YEAR_IN_SCHOOL_CHOICES = [
 (FRESHMAN, 'Freshman'),
 (SOPHOMORE, 'Sophomore'),
 (JUNIOR, 'Junior'),
 (SENIOR, 'Senior'),
 (GRADUATE, 'Graduate'),
 ]
    year_in_school = models.CharField(
        max_length=2,
        choices=YEAR_IN_SCHOOL_CHOICES,
        default=FRESHMAN,
 )

 def is_upperclass(self):
 return self.year_in_school in {self.JUNIOR, self.SENIOR} 

六,ASGI(重点)

1,什么是ASGI。

  • CGI就是(通用网关接口, Common Gateway Interface/CGI),举个例子就是正常的客户端发送HTTP请求到服务端,服务端经过某些请求处理,再构建出符合HTTP的响应返回,这个过程中的处理程序就是CGI。
  • 了解了什么是CGI之后,那什么是WSGi呢?引用维基上的解释为,Web服务器网关接口(Python Web Server Gateway Interface,WSGI),其实作用和CGI的差不多,即在WSGI服务器和WSGI应用之间起调解作用,一句话概括,其实可以说WSGI就是基于Python的以CGI为标准做一些扩展。
  • 既然WSGi是这样,那ASGi又是什么呢?ASGI的A其实就是Async,也就是异步的意思,理解起来就是异步的WSGI,它产生的原因是因为在如今Web环境越来越复杂的情况下,有很多WSGI不支持的协议,例如WebSocket,HTTP2等等并且WSGI是基于同步的服务,因此针对这些情况,Django团队首创了ASGi的概念,也是因为他们不满足于Django基于WSGI的种种低效表现,ASGI模式将Django作为原生异步应用程序运行,原有的WSGI模式将围绕每个Django调用运行单个事件循环,以使异步处理层与同步服务器兼容。
  • 具体可以浅显的理解为这样:在ASGI中,将一个网络请求划分成三个处理层面,最前面的一层,interface server(协议处理服务器),负责对请求协议进行解析,并将不同的协议分发到不同的Channel(频道);频道属于第二层,通常可以是一个队列系统。频道绑定了第三层的Consumer(消费者)。比如说,HTTP协议的频道绑定了HTTP的消费者,当有新的HTTP请求过来时,interface server将该请求分发到HTTP频道,HTTP 频道绑定的HTTP消费者对该请求进行处理,将处理结果返回给HTTP频道,最终传回给客户端。

2,ASGI支持。

  • Django 3.0通过提供对作为ASGI应用程序运行的支持,开始了使Django具有完全异步功能的旅程。
  • 这是对我们现有的WSGI支持的补充。Django打算在可预见的将来为这两者提供支持。但是,异步功能仅适用于在ASGI下运行的应用程序。
  • 在此阶段,异步支持仅适用于外部ASGI应用程序。内部一切保持同步。尚不支持异步中间件,视图等。但是,您可以在Django应用程序周围使用ASGI中间件,从而可以将Django与其他ASGI框架结合使用。除非您想开始尝试异步代码,否则无需切换应用程序。
  • 请注意,作为此更改的副作用,Django现在知道异步事件循环,并将阻止您从异步上下文中调用标记为“异步不安全”的代码(例如ORM操作)。如果您以前使用的是异步代码中的Django,则可能会在操作不正确时触发它。如果看到SynchronousOnlyOperation错误,请仔细检查代码,并将所有数据库操作移至同步子线程中。

3,Django+ASGI+Uvicorn实战。

  • ASGI既然是基于WSGI扩展开发的,那么使用的方法和WSGI类似,我们同样需要一个application对象,然后使用应用服务器把这个对象启动起来,就像使用Gunicorn/UWsgi启动WSGI一样,这样我们使用Uvicorn,Uvicorn是基于uvloop和httptools的ASGI服务器,它理论上是Python中最高性能的框架了,我们首先下载它。
    pip install uvicorn
  • 对于一个典型的Django项目,调用Uvicorn如下所示。
    uvicorn myproject.asgi:application
  • 然后进程监听一个8000端口,我们就这样很轻易的基于ASGI开发了Django的实战项目了。

七,其他特性。

1,django.contrib.admin

  • 增加了对admin_order_field属性属性,支持ModelAdmin.list_display。
  • 新ModelAdmin.get_inlines()方法允许根据请求或模型实例指定内联。
  • Select2库从4.0.3版本升级到4.0.7。
  • jQuery从3.3.1版本升级到3.4.1。

2,django.contrib.auth

  • 新增reset_url_token属性,其中PasswordResetConfirmView允许指定显示为密码重置URL组件的令牌参数。
  • 添加了BaseBackend类,以简化身份验证后端的自定义。
  • 添加了get_user_permissions()方法,类似于现在的get_group_permissions()方法。
  • createsuperuser现在变化为当非交互模式下未提供相应的命令行参数时,退回到密码和必填字段的环境变量。
  • REQUIRED_FIELDS现在支持ManyToManyField。
  • 新UserManager.with_perm()方法将返回具有指定权限的用户。
  • PBKDF2密码哈希器的默认迭代计数从150,000增加到180,000。

3,表格 表单集可以通过can_order设置ordering_widget属性或覆盖来控制在订购表单时使用的小部件。
4,文件存储 Storage.get_alternative_name()如果已经存在带有上载名称的文件,则新方法允许自定义生成文件名的算法。
5,国际

  • 增加了LANGUAGE_COOKIE_HTTPONLY,LANGUAGE_COOKIE_SAMESITE和LANGUAGE_COOKIE_SECURE参数来设置HttpOnly,SameSite以及Secure对语言的cookie标志。这些设置的默认值和之前的版本相同。
  • 添加了对乌兹别克语的支持和翻译。

6,缓存 add_never_cache_headers()然后 never_cache()将private 指令添加到Cache-Control标题中。

posted on 2020-12-29 10:53  我爱罗2012  阅读(424)  评论(0编辑  收藏  举报