一、从Request对象中获取信息

1、URL相关的信息

属性/方法 说明 举例
request.path 除域名以外的请求路径,以正斜杠开头 “/hello/”
request.get_host() 主机名(通常所说的域名)

“127.0.0.1:8000”

“www.example.com”

request.get_full_path() 请求路径,可能包含查询字符串 “/hello/?print=true”
request.is_secure() 如果通过HTTPS访问,则此方法返回true,否则返回false TRUE或者false

2、其他信息:

(1)request.META:包含本次所有HTTP请求的Header信息(如用户IP地址,用户Agent(通常是浏览器名称和版本号))

常见的键值:HTTP_REFERER:进站前链接网页;

      HTTP_USER_AGENT:浏览器的user-agent字符串;

      REMONT_ADDR:客户端IP;

3、下来我们来创建一个简单的表单:

#views.py
def search_form(request):
return render_to_response('search_form.html')
def search(request):
if 'q' in request.GET:
message = '您搜索了 :%r'% request.GET['q']
else:
message = '你提交了一个空表单'  #如果不进行判断,如果提交空表单就会出错
return HttpResponse(message)
#search_form.html
<form action="/search/" method="get">
<input type="text" name="q"/>
<input type="submit" value="search">
</form>
 url(r'^search-form/$',views.search_form),
url(r'^search/$',views.search),

    

4、测试完成之后来实现书籍的查询;

def search(request):
error = False
if 'q' in request.GET:
q = request.GET['q']
if not q:
error = True
else:
books = Book.objects.filter(title__icontains = q) #__icontains查询关键字:模糊匹配,不区分大小写
return render_to_response('search_results.html',
{'books':books,'query':q})
return render_to_response('search_form.html',
{'error':error})
<body>
{% if error %}
<p style="color:red">please submit a search term</p>
{% endif %}
<form action="" method="get">
<input type="text" name="q"/>
<input type="submit" value="search">
</form>
</body>
<body>
<p>you searched for:<strong>{{ query }}</strong></p> {% if books %}
<p>Found {{ books|length }}book{{ books|pluralize }}.</p>  <!--单词的复数形式,如列表字符串个数大于1,返回s,否则返回空串-->
<ul> 
{% for book in books %}
  <li>{{ book.title }} : {{ book.publisher }}</li>
{% endfor %}
</ul>
{% else %}
<p>No books matched your search criteria</p>
{% endif %}
</body>

访问127.0.0.1:60500/search-form/,如图一,若提交空表单,显示如图二;查询“python”关键字得到图三:

    

5、接下来我们队用户的输入进行一个简单的验证(不超多20个字符):

def search(request):
errors = []
if 'q' in request.GET:
q = request.GET['q']
if not q:
errors.append('please submit a search term')
elif len(q) > 20:
errors.append('please enter at most 20 charactors')
else:
books = Book.objects.filter(title__icontains = q) #__icontains查询关键字:模糊匹配,不区分大小写
return render_to_response('search_results.html',
{'books':books,'query':q})
return render_to_response('search_form.html',
{'errors':errors})
#search_form.html
<body>
{% if errors %}
<ul>
{% for error in errors %}
<li>{{ error }}</li>
{% endfor %}
</ul>
{% endif %}
<form action="" method="get">
<input type="text" name="q"/>
<input type="submit" value="search">
</form>
</body>

      提交空表单                              关键字超过20个字符                                  正常提交

    

6、体验站点联系表单:

我们想要创建一个表单含有三个字段:subject,message和email

(1)先 在firstSite目录下(books的同级目录)新建一个app,使用命令:python manage.py startapp contact,然后再contact目录下新建一个名为forms.py的文件,在这个文件里面创建我们的Form类。

  django带有一个form库成为django.forms,这个库可以处理表单HTML的显示和验证;

#    -*- coding:utf-8 -*-
from django import forms #引入form库 class ContactForm(forms.Form):
subject = forms.CharField(max_length= 100)  #设置最大值
email = forms.EmailField(required= False,label= 'Your e-mail address') #email为非必填选项
message = forms.CharField(widget= forms.Textarea)  #设置HTML里面message的标签为textarea,而不是input type=‘text’

(2)在我们的views.py文件中:

#    -*- coding:utf-8 -*-
from django.shortcuts import render
from django.http import HttpResponseRedirect
from django.shortcuts import render_to_response
from django.core.mail import send_mail
from contact.forms import ContactForm
from django.template import RequestContext
# Create your tests here.
def contact(request):
if request.method == 'POST':
form = ContactForm(request.POST)
if form.is_valid(): #检验输入数据是否合法
cd = form.cleanded_data #清理数据
send_mail( #发送邮件函数,四个必选参数:(主题,正文,寄信人,收件人)
cd['subject'],
cd['message'],
cd.get('email', 'noreply@example.com'),
['siteowner@example.com'],
)
return HttpResponseRedirect('/contact/thanks/')
else:
form = ContactForm(
initial= {'subject': "it's nice"}  #设置初始值
)
return render_to_response('contact_form.html',
{'form':form},

(3)在我们的Contact.html里:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>contact_form</title>
</head>
<body>
<h1>Contact us</h1>
{% if form.errors %} <!--内置errors字典-->
<p style="color:red">
Please corrent the error{{ form.errors|pluralize }} below
</p>
{% endif %} <form action="" method="post">
<table>
{{ form.as_table }} <!--按照<table>输出,还有其他形式的输出:form.as_ul(),form.as_p-->
</table>
<input type="submit" value="submit"/>
</form>
</body>
</html>

(4)接下来我们如果要自定义一些验证方式(比如说message字段不可以少于4个)可以在ContactForm类中定义函数:

#    -*- coding:utf-8 -*-
from django import forms #引入form库 class ContactForm(forms.Form):
subject = forms.CharField(max_length= 100)
email = forms.EmailField(required= False,label= 'Your e-mail address') #email为非必填选项,自定义标签
message = forms.CharField(widget= forms.Textarea)  #改变html显示 def clean_message(self): #命名规范:名称以clean_开头,以字段名称结束;
message = self.cleaned_data['message']
num_words = len(message.split())
if num_words < 4:
raise forms.ValidationError('not enough words!') #如果不足,抛出异常
return message

(5)接下来我们来配置url,在firstSite目录下的urls配置:

#    -*- coding:utf-8 -*-
from django.conf.urls import url #导入 django.conf.urls 模块下的url类
from django.contrib import admin
from django.conf.urls import url,include
admin.autodiscover() urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^books/',include('books.urls')),
url(r'^contact/',include('contact.urls')),
]

(6)在Contact目录下的urls中配置:

#    -*- coding:utf-8 -*-from django.conf.urls import url
from . import views urlpatterns = [
url(r'^contact/$',views.contact),
]

(7)我们对其进行访问:

    

(7)如果你得到如下报错页面,

可以按照以下步骤解决:

(8)自动显示HTML是很方便的,但是我们在需要的时候也可以重写默认显示;{{ form.as_table}}和其他的方法可以帮你这个忙;每一个字段部件(input type='text',<select>,<textarea>等)都可以通过访问{{form.字段名}}进行单独的渲染;

<form action="" method="post" class="form_1">{% csrf_token %}
<div class="field">
{{ form.subject.errors }}
<label class="left" for="id_message">Subject:</label>
{{ form.subject }}
</div>
<div class="field">
{{ form.email.errors }}
<label class="left" for="id_message">Your e-mail address:</label>
{{ form.email }}
</div>
<div class="field">
{{ form.message.errors }}
<label class="left_last" for="id_message">Message:</label>
{{ form.message }}
</div>
<!--<table>-->
<!--{{ form.as_table }} &lt;!&ndash;按照<table>输出,还有其他形式的输出:form.as_ul(),form.as_p&ndash;&gt;-->
<!--</table>-->
<input class="submit" type="submit" value="submit"/>
</form>

django-表单的更多相关文章

  1. python 全栈开发,Day111(客户管理之 编辑权限(二),Django表单集合Formset,ORM之limit_choices_to,构造家族结构)

    昨日内容回顾 1. 权限系统的流程? 2. 权限的表有几个? 3. 技术点 中间件 session orm - 去重 - 去空 inclusion_tag filter 有序字典 settings配置 ...

  2. python3之Django表单(一)

    1.HTML中的表单 在HTML种,表单是在<form>...</form>种的元素,它允许用户输入文本,选择选项,操作对象等,然后发送这些数据到服务器 表单元素允许用户在表单 ...

  3. django表单的api

    django表单的api,参考文档:https://yiyibooks.cn/xx/Django_1.11.6/ref/forms/api.html 绑定与未绑定形式: Form要么是绑定的,要么是未 ...

  4. Django表单API详解

    声明:以下的Form.表单等术语都指的的广义的Django表单. Form要么是绑定了数据的,要么是未绑定数据的. 如果是绑定的,那么它能够验证数据,并渲染表单及其数据,然后生成HTML表单.如果未绑 ...

  5. 9:django 表单

    django自带表单系统,这个表单系统不仅可以定义属性名,还可以自己定义验证,更有自己自带的错误提示系统 这节我们仅仅粗略的来看一下django表单系统的入门运用(具体的实在太多东西,主要是我觉得有很 ...

  6. django 表单系统 之 forms.Form

    继承forms.Form实现django表单系统 参考: https://www.cnblogs.com/zongfa/p/7709639.html https://www.cnblogs.com/c ...

  7. 关于创建Django表单Forms继承BaseForm的问题

    在创建Django表单时,因为需要验证用户输入的验证码是否正确,因此需要在session里提取当前验证码的值和POST提交过来的值进行比对,如图: form.py from django import ...

  8. Django 表单处理流程

    Django 的表单处理:视图获取请求,执行所需的任何操作,包括从模型中读取数据,然后生成并返回HTML页面(从模板中),我们传递一个包含要显示的数据的上下文.使事情变得更复杂的是,服务器还需要能够处 ...

  9. 第四章:Django表单 - 2:Django表单API详解

    声明:以下的Form.表单等术语都指的的广义的Django表单. Form要么是绑定了数据的,要么是未绑定数据的. 如果是绑定的,那么它能够验证数据,并渲染表单及其数据,然后生成HTML表单.如果未绑 ...

  10. 第四章:Django表单 - 1:使用表单

    假设你想从表单接收用户名数据,一般情况下,你需要在HTML中手动编写一个如下的表单元素: <form action="/your-name/" method="po ...

随机推荐

  1. [one day one question] Vue数组变更不能触发刷新

    问题描述:Vue数组变更不能触发刷新,特别是数组的每个元素都是对象的时候,对象中某个属性的值发生变化,根本无法触发Vue的dom刷新,这怎么破? 解决方案:this.$set(array, index ...

  2. 关于今天esp8266运行失控问题和oled与串口共存尝试成功的总结

    今天2017-12-1720:24:22下午esp8266再次无法刷入固件,导致我一度崩溃,本来已经认为esp8266已经相当稳定了,没想到今天又运行出错,总结如下 今天2017-12-17esp无法 ...

  3. _2_head_中标签

    创:20_3_2017修:5_4_2017 什么是title标签? --title   页面名(双) -- 整个html的页面名字,相当于一本书的书名 <title>北门吹雪</ti ...

  4. 使用copy命令合并二进制文件

    CMD下的copy命令可以将一份或多份文件复制到另一个位置. 也具备连接文件的功能. 使用如下命令格式可以将多个二进制文件合并为一个二进制文件: copy  /b  file1+file2+...+f ...

  5. 解决eclipse maven工程中src/main/resources目录下创建的文件夹所显示样式不是文件夹,而是"包"图标样式的问题

    参考:http://blog.csdn.net/luwei42768/article/details/72268246 eclipse项目中创建maven项目后,有时在执行命令maven update ...

  6. JavaSE基础篇—数据类型和运算符

       本章知识点内容概括 数据类型:  1.基本数据类型 数值型 整数类型 byte(128~127),占1个字节的储存间 short(-2^15~2^15-1),占2个字节 int(默认类型-2^3 ...

  7. pat 1022 digital library

    #include <iostream> #include <sstream> #include <string> #include <vector> # ...

  8. 程序员之殇 —— (Are you afraid of me? Don't be.)灵感=神秘感

    Are you afraid of me? (你们怕我吗?) Don't be.(不用怕) I am a programmer who just won't die.(我是不会死的程序员) 自从跟踪到 ...

  9. XAML: 自定义控件中事件处理的最佳实践

    在开发 XAML(WPF/UWP) 应用程序中,有时候,我们需要创建自定义控件 (Custom Control) 来满足实际需求.而在自定义控件中,我们一般会用到一些原生的控件(如 Button.Te ...

  10. [DeeplearningAI笔记]ML strategy_2_2训练和开发/测试数据集不匹配问题

    机器学习策略-不匹配的训练和开发/测试数据 觉得有用的话,欢迎一起讨论相互学习~Follow Me 2.4在不同分布上训练和测试数据 在深度学习时代,越来越多的团队使用和开发集/测试集不同分布的数据来 ...