2011-04-17 11 views
9

Gdybym to {% csrf_token%} w moim szablonu formularza i RequestContext importowej moim zdaniemDjango csrf RequestContext

muszę to nic innego, moim zdaniem, albo ochrona csrf być załatwione tylko następujące:

from django.shortcuts import render_to_response 
from django import forms 
from django.http import HttpResponseRedirect 
from django.template import Template, RequestContext 
from dash.forms import GradeForm 


def register(request): 
    if request.method == 'POST': 
     form = GradeForm(data=request.POST) 
     if form.is_valid(): 
      new_dash_profile = form.save() 
      new_user = form.save() 
      return HttpResponseRedirect("/success/") 
     else: 
      form = RegisterForm() 
     return render_to_response('grade.html',{'form':form}) 

Odpowiedz

21

dla mnie najprostszym sposobem jest dodanie RequestContext do funkcji render_to_response

return render_to_response('grade.html', 
          {'form':form}, 
          context_instance=RequestContext(request)) 

jest tylko jedna możliwość, import Mrówka jest taka, że ​​należy przetworzyć gdzieś token csrf, a RequestContext to robi.

Inną możliwością jest to zrobić ręcznie IR:

from django.core.context_processors import csrf 

params = {} 
params.update(csrf(request)) 
return render_to_response('grade.html', params) 
Powiązane problemy