- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章在Django框架中编写Contact表单的教程由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
虽然我们一直使用书籍搜索的示例表单,并将起改进的很完美,但是这还是相当的简陋: 只包含一个字段,q。这简单的例子,我们不需要使用Django表单库来处理。 但是复杂一点的表单就需要多方面的处理,我们现在来一下一个较为复杂的例子: 站点联系表单.
这个表单包括用户提交的反馈信息,一个可选的e-mail回信地址。 当这个表单提交并且数据通过验证后,系统将自动发送一封包含题用户提交的信息的e-mail给站点工作人员.
我们从contact_form.html模板入手:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
<
html
>
<
head
>
<
title
>Contact us</
title
>
</
head
>
<
body
>
<
h1
>Contact us</
h1
>
{% if errors %}
<
ul
>
{% for error in errors %}
<
li
>{{ error }}</
li
>
{% endfor %}
</
ul
>
{% endif %}
<
form
action
=
"/contact/"
method
=
"post"
>
<
p
>Subject: <
input
type
=
"text"
name
=
"subject"
></
p
>
<
p
>Your e-mail (optional): <
input
type
=
"text"
name
=
"email"
></
p
>
<
p
>Message: <
textarea
name
=
"message"
rows
=
"10"
cols
=
"50"
></
textarea
></
p
>
<
input
type
=
"submit"
value
=
"Submit"
>
</
form
>
</
body
>
</
html
>
|
我们定义了三个字段: 主题,e-mail和反馈信息。 除了e-mail字段为可选,其他两个字段都是必填项。 注意,这里我们使用method=”post”而非method=”get”,因为这个表单会有一个服务器端的操作:发送一封e-mail。 并且,我们复制了前一个模板search_form.html中错误信息显示的代码.
如果我们顺着上一节编写search()视图的思路,那么一个contact()视图代码应该像这样:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
from
django.core.mail
import
send_mail
from
django.http
import
HttpResponseRedirect
from
django.shortcuts
import
render_to_response
def
contact(request):
errors
=
[]
if
request.method
=
=
'POST'
:
if
not
request.POST.get(
'subject'
, ''):
errors.append(
'Enter a subject.'
)
if
not
request.POST.get(
'message'
, ''):
errors.append(
'Enter a message.'
)
if
request.POST.get(
'email'
)
and
'@'
not
in
request.POST[
'email'
]:
errors.append(
'Enter a valid e-mail address.'
)
if
not
errors:
send_mail(
request.POST[
'subject'
],
request.POST[
'message'
],
request.POST.get(
'email'
,
'noreply@example.com'
),
[
'siteowner@example.com'
],
)
return
HttpResponseRedirect(
'/contact/thanks/'
)
return
render_to_response(
'contact_form.html'
,
{
'errors'
: errors})
|
(如果按照书中的示例做下来,这这里可能乎产生一个疑问:contact()视图是否要放在books/views.py这个文件里。 但是contact()视图与books应用没有任何关联,那么这个视图应该可以放在别的地方? 这毫无紧要,只要在URLconf里正确设置URL与视图之间的映射,Django会正确处理的。 笔者个人喜欢创建一个contact的文件夹,与books文件夹同级。这个文件夹中包括空的__init__.py和views.py两个文件.
现在来分析一下以上的代码:
确认request.method的值是'POST'。用户浏览表单时这个值并不存在,当且仅当表单被提交时这个值才出现。 (在后面的例子中,request.method将会设置为'GET',因为在普通的网页浏览中,浏览器都使用GET,而非POST)。判断request.method的值很好地帮助我们将表单显示与表单处理隔离开来.
我们使用request.POST代替request.GET来获取提交过来的数据。 这是必须的,因为contact_form.html里表单使用的是method=”post”。如果在视图里通过POST获取数据,那么request.GET将为空.
这里,有两个必填项,subject 和 message,所以需要对这两个进行验证。 注意,我们使用request.POST.get()方法,并提供一个空的字符串作为默认值;这个方法很好的解决了键丢失与空数据问题.
虽然email非必填项,但如果有提交她的值则我们也需进行验证。 我们的验证算法相当的薄弱,仅验证值是否包含@字符。 在实际应用中,需要更为健壮的验证机制(Django提供这些验证机制,稍候我们就会看到).
我们使用了django.core.mail.send_mail函数来发送e-mail。 这个函数有四个必选参数: 主题,正文,寄信人和收件人列表。 send_mail是Django的EmailMessage类的一个方便的包装,EmailMessage类提供了更高级的方法,比如附件,多部分邮件,以及对于邮件头部的完整控制.
注意,若要使用send_mail()函数来发送邮件,那么服务器需要配置成能够对外发送邮件,并且在Django中设置出站服务器地址。 参见规范:http://docs.djangoproject.com/en/dev/topics/email/ 。
当邮件发送成功之后,我们使用HttpResponseRedirect对象将网页重定向至一个包含成功信息的页面。 包含成功信息的页面这里留给读者去编写(很简单 一个视图/URL映射/一份模板即可),但是我们要解释一下为何重定向至新的页面,而不是在模板中直接调用render_to_response()来输出.
原因就是: 若用户刷新一个包含POST表单的页面,那么请求将会重新发送造成重复。 这通常会造成非期望的结果,比如说重复的数据库记录;在我们的例子中,将导致发送两封同样的邮件。 如果用户在POST表单之后被重定向至另外的页面,就不会造成重复的请求了.
我们应每次都给成功的POST请求做重定向。 这就是web开发的最佳实践.
contact()视图可以正常工作,但是她的验证功能有些复杂。 想象一下假如一个表单包含一打字段,我们真的将必须去编写每个域对应的if判断语句?
另外一个问题是表单的重新显示。若数据验证失败后,返回客户端的表单中各字段最好是填有原来提交的数据,以便用户查看哪里出现错误(用户也不需再次填写正确的字段值)。 我们可以手动地将原来的提交数据返回给模板,并且必须编辑HTML里的各字段来填充原来的值.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
|
# views.py
def
contact(request):
errors
=
[]
if
request.method
=
=
'POST'
:
if
not
request.POST.get(
'subject'
, ''):
errors.append(
'Enter a subject.'
)
if
not
request.POST.get(
'message'
, ''):
errors.append(
'Enter a message.'
)
if
request.POST.get(
'email'
)
and
'@'
not
in
request.POST[
'email'
]:
errors.append(
'Enter a valid e-mail address.'
)
if
not
errors:
send_mail(
request.POST[
'subject'
],
request.POST[
'message'
],
request.POST.get(
'email'
, `
'noreply@example.com`_'
),
[`
'siteowner@example.com`_'
],
)
return
HttpResponseRedirect(
'/contact/thanks/'
)
return
render_to_response(
'contact_form.html'
, {
'errors'
: errors,
*
*
'subject'
: request.POST.get(
'subject'
, ''),
*
*
*
*
'message'
: request.POST.get(
'message'
, ''),
*
*
*
*
'email'
: request.POST.get(
'email'
, ''),
*
*
})
# contact_form.html
<html>
<head>
<title>Contact us<
/
title>
<
/
head>
<body>
<h1>Contact us<
/
h1>
{
%
if
errors
%
}
<ul>
{
%
for
error
in
errors
%
}
<li>{{ error }}<
/
li>
{
%
endfor
%
}
<
/
ul>
{
%
endif
%
}
<form action
=
"/contact/"
method
=
"post"
>
<p>Subject: <
input
type
=
"text"
name
=
"subject"
*
*
value
=
"{{ subject }}"
*
*
><
/
p>
<p>Your e
-
mail (optional): <
input
type
=
"text"
name
=
"email"
*
*
value
=
"{{ email }}"
*
*
><
/
p>
<p>Message: <textarea name
=
"message"
rows
=
"10"
cols
=
"50"
>
*
*
{{ message }}
*
*
<
/
textarea><
/
p>
<
input
type
=
"submit"
value
=
"Submit"
>
<
/
form>
<
/
body>
<
/
html>
|
这看起来杂乱,且写的时候容易出错。 希望你开始明白使用高级库的用意——负责处理表单及相关校验任务.
最后此篇关于在Django框架中编写Contact表单的教程的文章就讲到这里了,如果你想了解更多关于在Django框架中编写Contact表单的教程的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我对 Python-Django 和 web 开发还很陌生,我被困在这个使用 POST 创建新资源的特殊问题上。 我正在为 REST API 使用 Django REST 框架,我正在尝试创建一个新资
我已经使用 Django-storages 成功地将 Word 文档存储到 S3。 class Document(TitleSlugDescriptionModel, TimeStampedModel
我有 2 个关于模型代理的问题, 如何从模型对象创建代理对象? 如何从模型查询集创建代理查询集? 例如,假设我们定义了: from django.contrib.auth.models import
我想编写一个直接执行 HTTP 请求的单元测试(而不是使用 django.test.client.Client)。 如果您好奇为什么 - 那是因为我想测试我从 Django 应用程序公开的 Thrif
我为我的个人网站启动了一个 django 项目来学习 django。到目前为止,我已经将我的开发环境设置为我需要的一切,并遵循 this很棒的教程来创建一些基本的数据结构和模板。现在我想开始使用我之前
我已经阅读了很多关于如何在使用 Django 注册时添加额外字段的信息,例如 here 、 here 和 here 。代码片段是: forms.py(来自注册应用程序) class Registrat
我正在编写小型社交应用程序。功能之一是在网站标题中写入用户名。因此,例如,如果我登录并且我的名字是Oleg(用户名),那么我应该看到: Hello, Oleg | Click to edit prof
我有一个使用 Django 和 Django Rest 框架开发的应用程序。我想将 django-reversion 功能添加到我的应用程序中。 我已经尝试过http://django-reversi
我有一个简单的 HTML 表单,我没有使用 Django 表单,但现在我想添加一个选择。 选择最容易创建为 Django ChoiceField (与通过循环等手动创建选择相反),但是,如果没有在 D
我不明白为什么人们以两种方式编写外键,这样做的目的是什么?它们是相同还是不同? 我注意到有些人这样写: author = models.ForeignKey(Author, on_delete=mod
我想在我的 Django 应用程序中获取评论最多的十个帖子,但我做不到,因为我想不出合适的方法。 我目前正在使用 django 评论框架,并且我已经看到使用 aggregate or annotate
这对于 Django 1.2 仍然有效吗? Custom Filter in Django Admin on Django 1.3 or below 我已经尝试过,但管理类中的 list_filter
问题在于,当 django-compressor 编译为 .js 文件的 CoffeeScript 文件中引用 {{ STATIC_URL }} 时,它无法正确加载。 在我的 django 模板中,我
我正在尝试将一些字段从一个 django 模型移动到一个新模型。假设我有一个书籍模型: class Book(models.Model): title = models.CharField(max
我想在我的 Django 应用程序中获取评论最多的十个帖子,但我做不到,因为我想不出合适的方法。 我目前正在使用 django 评论框架,并且我已经看到使用 aggregate or annotate
目前我正在寻找在 Django 中实现访问控制。我已经阅读了有关内置权限的内容,但它并不关心每个对象的基础。例如,我想要“只有创建者可以删除自己的项目”之类的权限。所以我读到了 django-guar
嗨,我正在将我的 Django 模型的一个字段的值设置为其他模型的另一个字段的值。这个值应该是动态变化的。 这是我的第一个模型 class MainModel(AbstractBaseUser, Pe
我正在尝试为我的模型创建一个编辑表单。我没有使用模型表单,因为根据模型类型,用户可以使用不同的表单。 (例如,其中一个表单有 Tinymce 小部件,而另一个没有。) 有没有什么方法可以使用模型设置表
Django 模板中的搜索字段 如何在类似于此图像的 Django 模板中创建搜索字段 http://asciicasts.com/system/photos/1204/original/E354I0
根据 Django documentation ,如果 Django 安装激活了 AuthenticationMiddleware,HttpRequest 对象有一个“user”属性代表当前登录的用户
我是一名优秀的程序员,十分优秀!