QueryDict
在HttpRequest对象中,GET和POST属性是django.http的实例。QueryDict类。
QueryDict是一个用户定义的类,类似于字典。它用于处理单个键对应多个值的情况。
QueryDict实现所有标准字典方法。它还包括一些独特的方法:
>>> q = QueryDict('a=1')
>>> q = q.copy() # to make it mutable
>>> q.update({'a': '2'})
>>> q.getlist('a')
['1', '2']
>>> q['a'] # returns the last
['2']
表单
在模板的末尾,我们添加了一个rlt令牌,为表处理结果预留空间。
表后面还有一个标签{%csrf_token%}。csrf的全称是跨站点请求伪造。这是Django提供的防止伪装提交请求的功能。POST方法提交的表单必须具有此标签。
在HelloWorld目录中创建一个search2.py文件,并使用search_post函数处理post请求:
from django.http import HttpResponse
from django.shortcuts import render
# 表单
def search_form(request):
return render(request, 'search_form.html')
# 接收请求数据
def search(request):
request.encoding='utf-8'
if 'q' in request.GET and request.GET['q']:
message = '你搜索的内容为: ' + request.GET['q']
else:
message = '你提交了空表单'
return HttpResponse(message)
HTTP协议在“请求-应答”模式下工作。当客户发送请求时,可以将数据附加到请求中。通过解析请求,服务器可以从客户端获取数据,并根据URL提供特定服务。
HttpRequest 对象
def runoob(request):
return redirect("/index/")
view函数,简称view,是一个简单的Python函数,它接受Web请求并返回Web响应。
响应可以是HTML页面、404错误页面、重定向页面、XML文档或图像
无论视图包含什么逻辑,都必须返回响应。代码可以在任何地方编写,只要它在Python目录中,通常在项目视图Py文件中。
每个视图函数负责返回一个HttpResponse对象,该对象包含生成的响应。
视图层中有两个重要的对象:请求对象和响应对象。
Admin 管理工具
我们可以自定义管理页面以替换默认页面。例如,上面的“添加”页面。我们只想显示姓名和电子邮件部分。修改TestModel/admin.py
from django.contrib import admin
from TestModel.models import Test,Contact,Tag
# Register your models here.
class ContactAdmin(admin.ModelAdmin):
fields = ('name', 'email')
admin.site.register(Contact, ContactAdmin)
admin.site.register([Test, Tag])
上面的代码定义了一个ContactAdmin类来解释管理页面的显示格式。
字段属性定义要显示的字段。
因为这个类对应于Contact数据模型,所以我们需要在注册时一起注册它们。显示效果如下:
from django.contrib import admin
from TestModel.models import Test,Contact,Tag
# Register your models here.
class ContactAdmin(admin.ModelAdmin):
fieldsets = (
['Main',{
'fields':('name','email'),
}],
['Advance',{
'classes': ('collapse',), # CSS
'fields': ('age',),
}]
)
admin.site.register(Contact, ContactAdmin)
admin.site.register([Test, Tag])
上面的联系人是标记的外部键,因此它具有外部引用关系。
在默认页面显示中,不能将两者分开以反映其相关性。我们可以使用内联显示将标记附加到联系人的编辑页面。
修改TestModel/admin.py:
from django.contrib import admin
from TestModel.models import Test,Contact,Tag
# Register your models here.
class TagInline(admin.TabularInline):
model = Tag
class ContactAdmin(admin.ModelAdmin):
inlines = [TagInline] # Inline
fieldsets = (
['Main',{
'fields':('name','email'),
}],
['Advance',{
'classes': ('collapse',),
'fields': ('age',),
}]
)
admin.site.register(Contact, ContactAdmin)
admin.site.register([Test])
原因是MySQL客户端目前只支持Python 3.4,因此如果您使用更高版本的Python,则需要按如下方式进行修改:
通过错误消息Py文件的文件路径,在…site packages django-2.0-py3.6.eggDjango-db-backends-mysql的路径中找到基,注释掉两行代码(代码位于文件的开头):
if version < (1, 3, 13):
raise ImproperlyConfigured('mysqlclient 1.3.13 or newer is required; you have %s.' % Database.__version__)
通常,单击报告错误的代码文件的路径信息将自动跳转到错误文件中的行数。此时,我们将注释掉错误文件中的行数。
此时,数据库runoob将为book创建app01_Table。
接下来,我们将视图添加到app01项目Py和模型Py文件app01项目目录结构中。
from django.contrib import admin
from django.urls import path
from . import views
urlpatterns = [
path('add_book/', views.add_book),
]
filter()方法用于查询限定数据。
返回的数据是QuerySet类型,类似于列表。它包含满足条件的模型类的对象。可以使用索引下标来检索模型类的对象。
Pk=3意味着主键=3,这相当于id=3。
由于id在pychar中具有特殊含义,它指的是内存地址的内置函数id(),因此使用pk。
from django.shortcuts import render,HttpResponse
from app01 import models
def add_book(request):
books = models.Book.objects.filter(pk=5)
print(books)
print("//////////////////////////////////////")
books = models.Book.objects.filter(publish='菜鸟出版社', price=300)
print(books, type(books)) # QuerySet类型,类似于list。
return HttpResponse("<p>查找成功!</p>")