Django博客功能实现—文章评论功能
功能:在A网页提交一个评论Forms_B,提交之后自动刷新页面,能够显示刚刚的画面
思路:利用一个已经创建的表单,通过视图让其在网页中表现出来,填写玩信息之后提交,会提交到一个新的视图里面去做接受,接受之后重定向到另外一个地方。(是什么地方)
步骤:
一、在app里面的forms.py里面新建一个表单:
#blog/forms.py
from django import forms class CommentForm(forms.Form):
'''
评论表单
'''
#author使用CharField字段,字段内使用三个参数,分别是widget, max_length, error_messages
author = forms.CharField(
#为各个需要渲染的字段指定渲染成什么Html组件,主要是为了添加css样式
widget=forms.TextInput(attrs={"id": "author", "class": "comment_input",
"required": "required","size": "", "tabindex": ""}),
max_length=50,error_messages={"required":"username不能为空",})
email = forms.EmailField(widget=forms.TextInput(attrs={"id":"email","type":"email","class": "comment_input",
"required":"required","size":"", "tabindex":""}),
max_length=50, error_messages={"required":"email不能为空",})
url = forms.URLField(widget=forms.TextInput(attrs={"id":"url","type":"url","class": "comment_input",
"size":"", "tabindex":""}),
max_length=100, required=False)
comment = forms.CharField(widget=forms.Textarea(attrs={"id":"comment","class": "message_input",
"required": "required", "cols": "",
"rows": "", "tabindex": ""}),
error_messages={"required":"评论不能为空",})
article = forms.CharField(widget=forms.HiddenInput())
二、在文章详情视图里面让接入表单
def article(request):
# 评论表单
comment_form = CommentForm({'author': request.user.username,
'email': request.user.email,
'url': request.user.url,
'article': id} if request.user.is_authenticated() else{'article': id})
return render(request, 'article.html', locals())
三、在模板中将视图体现出来
<form action="{% url 'comment_post' %}" method="post">
{% csrf_token %}
<p>{{ comment_form.author }}
<label for="author">Name (required)</label></p> <p>{{ comment_form.email }}
<label for="email">Email (Will NOT be published) (required)</label></p> <p>{{ comment_form.url }}
<label for="url">URL</label></p> <p>{{ comment_form.comment }}</p> <p>
{{ comment_form.article }}
<input name="submit" type="submit" id="submit" tabindex="5" value="Submit" class="button" />
</p>
</form>
四、模板中的提交链接到URL中
url(r'^comment/post/$', comment_post, name='comment_post'),
五、在视图中接收提交的内容,并且重定向
# 提交评论
def comment_post(request):
try:
#获取表单内填入的内容
comment_form=CommentForm(request.POST)
#进行验证的第一个表单验证
if comment_form.is_vaild():
#获取表单信息
#cleaned_data()用来把接收到的文字清洗为符合django的字符
#create是一个在一步操作中同时创建对象并且保存的便捷方法。
comment=Comment.objects.create(username=comment_form.cleaned_data["author"],
eamil=comment_form.cleaned_data["email"],
url=comment_form.cleaned_data["url"],
content=comment_form.cleaned_data["comment"],
article_id=comment_form.cleaned_data["article"],
#如果用户已经登录,则获取已经登录的用户,非登录用户将返回None
#此处用的if语句有些特殊。
user=request.user if request.user.is_authenticated() else None)
comment.save() #保存实例
else:
return render(request, "failure.html", {"reason":comment_form.erros})
except Exception as e:
logger.error(e)
#重定向到进来之前的网页
#HTTP_REFERER是http的头文件的一部分,当浏览器向web服务器发送请求的时候,一般会带上Referer,告诉服务器我是从哪个页面链接过来的,服务器借此获得一些信息用于处理。
return redirect(request.META['HTTP_REFERER'])
'''
#判断用户是不是登录,也可以用这个写法,79行的写法也很简单
if request.user.is_authenticated(): #判断用户是否登录
user=request.user #获取已经登录的用户
else:
user=request.user #非登录用户将返回AnonymousUser
'''
request.META是一个里面包含了所有本次http请求的Header信息,比如用户IP,用户Agent
常见的键值有:
HTTP_REFERER,进站前链接网页,如果有的话。
redirec是重定向
redirec是重定向
Django博客功能实现—文章评论功能的更多相关文章
- 为hexo博客添加基于gitment评论功能
关于gitment gitment其实就是利用你的代码仓库的Issues,来实现评论.每一篇文章对应该代码仓库中的 一个Issues,Issues中的评论对应你的博客每篇文章中的评论.如果你是用git ...
- Django 博客单元测试:测试评论应用
作者:HelloGitHub-追梦人物 文中所涉及的示例代码,已同步更新到 HelloGitHub-Team 仓库 评论应用的测试和博客应用测试的套路是一样的. 先来建立测试文件的目录结构.首先在 c ...
- Django(博客系统):文章内容使用django-ckeditor、文章简介使用django-tinymce
文章内容使用django-ckeditor 1)安装django-ckeditor pip install django-ckeditorpip install Pillow 2)在settings. ...
- Django1.9开发博客(7)- 实现功能
到目前为止我们已经完成了一个django应用的所有基础部分. 包括url配置.视图.模型和模板.接下来开始继续完善我们的博客系统了. 首先我们需要一个显示每篇文章的详细页面,对不? 文章详情 对于首页 ...
- django博客项目8:文章详情页
首页展示的是所有文章的列表,当用户看到感兴趣的文章时,他点击文章的标题或者继续阅读的按钮,应该跳转到文章的详情页面来阅读文章的详细内容.现在让我们来开发博客的详情页面,有了前面的基础,开发流程都是一样 ...
- 为你的CSDN博客添加CNZZ流量统计功能
一.流量统计介绍 流量统计是指通过各种科学的方式,准确的纪录来访某一页面的访问者的流量信息,目前而言,必须具备可以统计. 1.简介 统计独立的访问者数量(独立用户.独立访客): 可以统计独立的IP地址 ...
- django博客项目6:Django Admin 后台发布文章
在此之前我们完成了 Django 博客首页视图的编写,我们希望首页展示发布的博客文章列表,但是它却抱怨:暂时还没有发布的文章!如它所言,我们确实还没有发布任何文章,本节我们将使用 Django 自带的 ...
- Django博客开发实践,初学者开发经验
python,Django初学者,开发简易博客,做了一下笔记,记录了开发的过程,功力浅薄,仅供初学者互相 交流,欢迎意见建议.具体链接:Django博客开发实践(一)--分析需求并创建项目 地址:ht ...
- django博客项目5:博客首页视图(2)
真正的 Django 博客首页视图 在此之前我们已经编写了 Blog 的首页视图,并且配置了 URL 和模板,让 Django 能够正确地处理 HTTP 请求并返回合适的 HTTP 响应.不过我们仅仅 ...
随机推荐
- 从零开始学 Java - CentOS 下 Nginx + Tomcat 配置负载均衡
为什么现在有非常多的聪明人都在致力于互联网? 最近在读埃隆·马斯克传记,他说「我认为现在有非常多的聪明人都在致力于互联网」. 仔细一想,好像真的是这样的. 我问了自己一个问题:如果你不敲代码了,你能做 ...
- 【工匠大道】svn使用总结
原文地址 SVN(Subversion)是一个自由.开源的项目源代码版本控制工具.目前,绝大多数开源软件和企业代码管理,都使用SVN作为代码版本管理软件. Subversion将文件存放在中心版本库里 ...
- 变通实现微服务的per request以提高IO效率(二)
*:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: 0 !important; } /* ...
- [Cordova] Plugin开发架构
[Cordova] Plugin开发架构 问题情景 开发Cordova Plugin的时候,侦错Native Code是一件让人困扰的事情,因为Cordova所提供的错误讯息并没有那么的完整.常常需要 ...
- window下 Sublime Text 3 安装
1.下载 官网 http://www.sublimetext.com/ 安装时,注意勾选Add to explorer context menu,这样Sublime Text可以被添加到右键中,在右键 ...
- jQuery实现右上角点击后滑下来的竖向菜单
效果体验请点击这里:http://keleyi.com/a/bjad/27095rgj.htm 这个菜单我觉得可以做成在线客服之类的,点击下滑后,带关闭按钮,因此在不想显示的时候可以关掉它. 以下是源 ...
- if语句,case语句
1.句式:if...then.判断赋值 例: if RadioButton1.Checked then sex:='男' else if RadioButton2.Checked then sex:= ...
- sharepoint报HRESULT:0x80131904的错误的原因和解决方法
在新建文件库的时候出现的.下上传文件和更改权限,都是在报这个HRESULT:0x80131904的错误,基本所有操作都报同一个错误,如下图: 错误原因 这个问题其实就是:sharepoint配置文件( ...
- SharePoint 2013 必备组件之 Windows Server AppFabric 安装错误
1.如下图,在使用SharePoint2013产品准备工具的时候,网上下载安装Windows Server AppFabric的时候,报错,点击完成重启计算机,重新安装依然报错. 2.无奈之下,只有选 ...
- VS2012 单元测试之泛型类(Generics Unit Test)
关于单元测试,如果不会用可以参照我的上篇博文————在Visual Studio 2012使用单元测试 首先分享一篇博文,[Visual Studio] 开启Visual Studio 2012通过右 ...