Django前后端分离之后端实践

django-admin  startproject  djweb  生成djweb项目

django-admin  startapp   news      生成news应用

配置models文件

class NewInfo(models.Model):
    title = models.CharField(max_length=30)
    content = models.TextField()
    b_date=  models.DateField()
    read = models.IntegerField()

插入数据,进入交互环境: python manage.py shell
 

In [1]: from news.models import NewInfo

In [2]: NewInfo.objects.all()
Out[2]: 

# 查询为空,这时插入数据
In [11]: n1= NewInfo()

In [12]: n1.title = 'title1'

In [13]: n1.read = 999

In [14]: n1.b_date= '2024-01-01'

In [15]: n1.save()

In [20]: res = NewInfo.objects.all()[0]

In [21]: res.title  # 保存成功
Out[21]: 'title1'

配置admin文件

from .models import NewInfo
# Register your models here.
admin.site.register(NewInfo)

创建超级用户:python manage.py createsuperuser

用户名 (leave blank to use 'pass'): pass
电子邮件地址: [email protected]
Password:
Password (again):
密码跟 用户名 太相似了。
密码长度太短。密码必须包含至少 8 个字符。
这个密码太常见了。
Bypass password validation and create user anyway? [y/N]: y
Superuser created successfully.

启动项目:python manage.py runserver

登录web页面:http://127.0.0.1:8000/admin

点击增加信息:

Django前后端分离之后端实践_第1张图片

 展示中文信息及调整时区:

# LANGUAGE_CODE = 'en-us'
LANGUAGE_CODE = 'zh-hans'

# TIME_ZONE = 'UTC'
TIME_ZONE = 'Asia/Shanghai'

点击删除信息:

Django前后端分离之后端实践_第2张图片

自定义admin模型类展示数据

class NewInfoAdmin(admin.ModelAdmin):
    # 自定义模型类
    list_display = ['id','title','b_date','read']
# 自定义模型定义到系统中
admin.site.register(NewInfo,NewInfoAdmin)

 展示结果:

Django前后端分离之后端实践_第3张图片

 总路由分配:

from django.contrib import admin
from django.urls import path,re_path,include

urlpatterns = [
    path('admin/', admin.site.urls),
    re_path(r'^news/',include('news.urls'))
]

子路由配置:

from .views import home
urlpatterns = [
    path('home/',home),
]

debug模式调试代码:

Django前后端分离之后端实践_第4张图片

 关闭原有terminal进程,点击debug模式,选择红色按钮断点,此时刷新web页面的访问url地址.

Django前后端分离之后端实践_第5张图片

Django前后端分离之后端实践_第6张图片

templates模板配置:
# 项目目录位置的模板
# 'DIRS': [],
'DIRS': [BASE_DIR / 'templates'],

msyql数据库配置:

mysql> create database djweb charset = utf8;
Query OK, 1 row affected, 1 warning (0.00 sec)

mysql> exit
Bye
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'djweb',
        'USER':'root',
        'PASSWORD':'****',
        'HOST':'localhost',
        'PORT':3306
    }
}

ORM常用字段类型:

  • AutoField
  • BooleanField
  • CharField
  • TextField
  • DecimalField
  • TimeField
  • DateTimeField
  • FileField

常用字段选项:

  • default
  • primary_key
  • unique
  • db_index  # 索引
  • null
  • blank
  • verbose_name  # web可读
  • help_text

关系字段类型:

ForeignKey :一对多,将字段定义在多的一方中

goods = models.ForeginKey('Goods',on_delete=models.CASCADE)

ManyToManyField: 多对多

users = models.ManToManyField('Users',on_delete=models.CASCADE)

OneToOneField:一对一

goods = models.OneToOneField('Goods',on_delete=models.CASCADE)

自定义关联:使用self指定

goods = models.ForeginKey('self',null=True,blank = True)
goods = models.ManyToManyField('self',null=True,blank = True)

多对对模型类实践案例:

class NewInfo(models.Model):
    title = models.CharField(max_length=30,verbose_name='标题',help_text="标题")
    content = models.TextField(max_length=30,verbose_name="内容",help_text='内容')
    # b_date=  models.DateField()
    read = models.IntegerField(verbose_name='阅读量',help_text='评论数量')
    type  = models.ManyToManyField('NewsType',verbose_name='新闻类型',help_text='类型')

class NewsType(models.Model):
    name = models.CharField(max_length=20,verbose_name='名称')

Django前后端分离之后端实践_第7张图片

 元选项:

class Meta:
    # 自定义表名,若无此设置默认为表名:应用名+模型类小写
    db_table = 'news'
    verbose_name = '新闻类型'  # 后台可以看到

结果实例:

Django前后端分离之后端实践_第8张图片

魔术方法__str__应用

def __str__(self):  #  魔术方法 -- 更改对象显示的内容
    return self.name

Django前后端分离之后端实践_第9张图片

Django前后端分离之后端实践_第10张图片

模糊条件查询:

  1. xxx.objects.filter(模型类名__条件名 = 值)
  2. xxx.objects.filter(name__contains='xxx')
  3. xxx.objects.filter(name__startswith='xxx')
  4. xxx.objects.filter(name__endswith='xxx')
  5. xxx.objects.filter(name__in=[1,2,3])

比较条件查询:

  1. xxx.objects.filter(id__gt=1) # 大于
  2. xxx.objects.filter(id__lt=1) # 小于
  3. xxx.objects.filter(id__gte=1) # 大于等于
  4. xxx.objects.filter(id__lte=1) # 小于等于

F对象与Q对象(from django.db.models import F)

  1. F对象用于类属性比较   eg:  xxx.objects.filter(read__gte=F('comment'))
  2. Q对象用于逻辑与或非(&|~)  eg:  xxx.objects.filter(Q(read__gte=40) & Q(comment__gt=30))

聚合函数(from django.db.models import Sum,Avg,Max,Min)

eg:    xxx.objects.all().aggregate(Sum('read'))

  • Sum    
  • Count   
  • Avg
  • Max
  • Min

查询和对象关联的数据

一到多查询:

data = xxx.objects.get(id=1)
data.newinfo_set.all()  #  模型类名小写+_set实现

多到一查询:

data = xxx.object.get(id=1)
data.title  # 通过关联的对象直接获取对应的数据

由一模型类查询多模型类数据

语法: 关联模型类名小写__属性名__条件运算符=值

data=xxx.objects.filter(类名小写__属性名__contains='q') # 查询某一属性包含q的字段

由多模型类查询一模型类数据

语法: 一模型类名小写__一模型类属性名__条件运算符=值

data=xxx.objects.filter(类名小写__属性名='yyy') # 查询属性包含yyy的所有字段

ORM增删改查操作:

  • 修改数据:  查到要修改的对象,直接修改字段xxx.title='yyy',save()方法保存
  • 增加数据:  xxx.属性值=特定值, xxx.save()保存
  • 删除数据:  获取data = xxx.objects.all(),然后xxx.delete()直接删除   

路由参数匹配

  1. 位置参数: 
    re_path(r'^index/(\d+)/$',views.show)  # 直接使用小括号
  2. 关键字参数:
    re_path(r'^index/(?P\d+)/$',views.show)  

 requests对象的属性

  • path
  • method
  • encoding
  • GET       #   ?'key1'='value1'&'key2'='value2'
  • POST
  • FILES
  • COOKIES
  • session

HttpResponse对象

  • content
  • charset
  • status_code
  • content-type

常用方法

set_cookie(key,value='',max_age=None,expires=None)
# max_age  整数,指定过期时间
# expires  指定日期的特定过期时间
# 上面二选一,若无指定关闭浏览器时cookies会过期

eg:  
response = HttpResponse(res_list,status)
response.set_cookie('token','xxx',max_age=4)
response.delete_cookie('token')

session的操作

  1. request.session['key']='value'
  2. request.session.get('key',None)
  3. request.session.clear()  # 清除所有session数据
  4. request.session.flush()  # 清除存储中的整条数据
  5. del  request.session['key']
  6. request.session.set_expiry(value)  # 设置会话的超时时间

类视图的使用步骤:

# views.py
from django.views import View
class NewsView(View):
    def get(self,request):
        pass
    def post(self,request):
        pass    

# urls.py

re.path(r'news/$',views.NewView.as_view())

模板变量

语法:{{ 变量 }}

顺序解析dict.title:

  1. 字典dict['title'] 先属性后方法,若无此属性,再查询对应方法
  2. 若格式dict.0则解析为列表dict[0],若变量不存在则为空字符串

模板标签

语法:{%  xxx  %}

for标签

{% for x in xxx %}
{{forloop.counter} # 表示当前第几次循环,从1开始
{% empty %}  # 列表为空或不存在时执行该逻辑
{% endfor %}

if标签

{% if ... %}
{% elif ... %}
{% else %}
{% endif %}

过滤器

语法:{{ 管道符号 | 过滤器 }}  eg:{{ xxx | lower}}

  • {{ xxx | upper }}
  • {{ xxx | lower }}
  • {{ xxx | add:2 }}
  • {{ datex | date:'y-m-d' }}

注释

语法: {# xxx #}

父模板
 

{% block xxx %}

{% endblock xxx %}

子模板
 

{{% extends '父路径path'%}}

{% block xxx %}

{% endblock xxx %}

中间件

# 初始化
def __init__(self):
    pass
# 处理请求前
def process_request(self,request):
    pass
# 处理视图前
def process_view(self,request,func,*args,**kwargs):
    pass
# 处理视图后
def process_response(self,request,response):
    pass
# 处理异常
def process_exception(self,request,exception):
    pass

自带认证方式登录

from django.contrib.auth import authenticate

username = request.POST['name']
password = request.POST['passwd']
user = authenticate(request,username=username,password=password)
if not user:
    pass

你可能感兴趣的:(django,python,后端)