鱼C论坛

 找回密码
 立即注册
查看: 1126|回复: 1

[已解决]有懂django的大佬么?想问个csrf的问题

[复制链接]
发表于 2018-1-5 03:57:09 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 yjsx86 于 2018-1-5 05:48 编辑

情况是这样的
模板中的{% csrf_token %}渲染不出来

1 setting文件 中间件 已经添加了django.middleware.csrf.CsrfViewMiddleware
  1. MIDDLEWARE = [
  2.     'django.middleware.security.SecurityMiddleware',
  3.     'django.contrib.sessions.middleware.SessionMiddleware',
  4.     'django.middleware.common.CommonMiddleware',
  5.     'django.middleware.csrf.CsrfViewMiddleware',
  6.     'django.contrib.auth.middleware.AuthenticationMiddleware',
  7.     'django.contrib.messages.middleware.MessageMiddleware',
  8.     'django.middleware.clickjacking.XFrameOptionsMiddleware',
  9. ]
复制代码


2 模板中给form标签添加了{% csrf_token %}
  1.     <form action="/blog/create/" method="post">
  2.         {%csrf_token%}
  3.         Title:
  4.         <input type=text name=title><br>
  5.         Body:
  6.         <textarea name=body rows=3 cols=60></textarea><br>
  7.         <input type=submit>
  8.     </form>
复制代码


3 视图函数(相当于控制器)中使用 render_to_response()来渲染模板
  1. #views.py
  2. def archive(request):
  3.     posts = BlogPost.objects.all()[:10]
  4.     return render_to_response('archive.html', {'posts': posts}, RequestContext(request))
复制代码


csrf_token死活渲染不出来

最后使用render()渲染成功,并且感觉更简单
  1. #views.py
  2. def archive(request):
  3.     posts = BlogPost.objects.all()[:10]
  4.     return render(request, 'archive.html', {'posts': posts})
复制代码


发这贴是想问问如何在使用render_to_response()渲染模板时显示csrf_token
最佳答案
2018-1-5 07:03:47
官方定义模版渲染,用的必须是render,要不然就自己获取token,加到form中
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-1-5 07:03:47 From FishC Mobile | 显示全部楼层    本楼为最佳答案   
官方定义模版渲染,用的必须是render,要不然就自己获取token,加到form中
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-3 08:10

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表