Форум сайта python.su
Есть форма обратной связи. заполняем 4 поля, отправляем и без перезагрузки страницы получаем в ответ надпись, что форма отправлена. Без ajax все работает. Ajax прикручиваю, запрос формируется, отправляется, получаю ответ обратно, но данные из формы не заносятся в базу. Т.е. ошибок явных нет, в базе ничего не появляется, надписи об успешном выполнении нет.
Думаю проблема в изъятии данных из POST или в записи в базу, хочу вашего мнения. Валидации и перехвата ошибок нет (да я плох, но пока так).
На скриншоте видно(консоль Firefox), что скрипт отрабатывает, данные уходят.
Модель:
class zForm(models.Model): name = models.CharField(max_length=128, verbose_name="Имя", null=True, blank=True) email = models.CharField(verbose_name='email', max_length=256, null=True, blank=True) subject = models.CharField(max_length=128, verbose_name="Тема", null=True, blank=True) message = models.TextField(max_length=2056, verbose_name="Сообщение", null=True, blank=True) date = models.DateTimeField(default=timezone.now(), verbose_name="Дата сообщения", null=True, blank=True) def __str__(self): return self.name class Meta(): db_table = "Форма связи" verbose_name = "Форма связи"
[code html+django]<section id="six">
<div class="container">
<h3>Контакты</h3>
<p>Отправьте мне сообщения по форме ниже или свяжитесь со мной через социальные сети.</p>
{% if form_ok %}
<div id="results"></div>
{% endif %}
<form method="post" id="post-form">{% csrf_token %}
<div class="row uniform">
<div class="6u 12u(xsmall)"><input type="text" name="name" id="name" placeholder="Имя" required/></div>
<div class="6u 12u(xsmall)"><input type="email" name="email" id="email" placeholder="Email" required/></div>
</div>
<div class="row uniform">
<div class="12u">
<div class="select-wrapper">
<select name="subject" id="subject" style="font-style:Italic;color:#aaaaaa;" required aria-required="true">
<option value="">- Тема -</option>
<option value="Вопросы">Вопросы</option>
<option value="Сотрудничество">Сотрудничество</option>
<option value="Нашел ошибку">Нашел ошибку</option>
<option value="Люблю общаться">Люблю общаться</option>
</select>
</div>
</div>
</div>
<div class="row uniform">
<div class="12u"><textarea maxlength="2056" name="message" id="message" placeholder="Сообщение" rows="6" required aria-required="true"></textarea></div>
</div>
<div class="row uniform">
<div class="12u">
<ul class="actions">
<li><input type="submit" class="special" value="Отправить" /></li>
<li><input type="reset" value="Отчистить" /></li>
<li><input type="checkbox" id="demo-human" name="demo-human" required aria-required="true">
<label for="demo-human">Я человек, а не робот</label></li>
</ul>
</div>
</div>
</form>
</div>
</section>[/code]
def create_post(request): if request.method == 'POST': name = request.POST.get('name', '') email = request.POST.get('email', '') subject = request.POST.get('subject', '') message = request.POST.get('message', '') response_data = {} a = zForm.objects.create( name=name, email=email, subject=subject, message=message ) a.save() response_data['form_ok'] = 1 response_data['result'] = "Сообщение отправлено!" response_data.update(csrf(request)) return HttpResponse( json.dumps(response_data), content_type="application/json" ) else: return HttpResponse( json.dumps({"nothing to see": "this isn`t happening"}), content_type="application/json" )
$(function() { $('#post-form').on('submit', function(event){ event.preventDefault(); console.log("form submited!") create_post(); }); function create_post() { console.log("create post is working!") var name = $('#name').val() var email = $('#email').val() var subject = $('#subject').val() var message = $('#message').val() $.ajax({ url: 'create_post/', type: "POST", data: { 'name': name, 'email': email, 'subject': subject, 'message': message }, success: function(json) { $('#name').val('') $('#email').val('') $('#subject').val('') $('#message').val(''); $('#results').html("<b>"+json.result+"</b>"); console.log("success"); }, error: function(xhr,errmsg,err) { $('#results').html("<div>oops! error: "+errmsg+"</div>"); console.log(xhr.status + ": " +xhr.responseText); } }); }; });
Прикреплённый файлы:
1.jpg (64,0 KБ)
Офлайн
Поставьте все же перед def create_post(request) для начала декоратор csrf_exempt, ибо все же
вы не передаете в { ‘name’: name, ‘email’: email, ‘subject’: subject, ‘message’: message } csrftoken.
Проверьте, будет ли работать с csrf_exempt.
Офлайн
scidamпоставил и @csrf_protect и @csrf_exempt , но итог тот же. CSRF передается вроде в заголовке, в консоле виден X-CSRF
Поставьте все же перед def create_post(request) для начала декоратор csrf_exempt, ибо все жевы не передаете в { ‘name’: name, ‘email’: email, ‘subject’: subject, ‘message’: message } csrftoken.Проверьте, будет ли работать с csrf_exempt.
Офлайн
у меня 403 яя не возвращает, разве может быть связано с csrf? у меня в JS скрипте еще для CSRF такое(с офф сайта):
// This function gets cookie with a given name function getCookie(name) { var cookieValue = null; if (document.cookie && document.cookie != '') { var cookies = document.cookie.split(';'); for (var i = 0; i < cookies.length; i++) { var cookie = jQuery.trim(cookies[i]); // Does this cookie string begin with the name we want? if (cookie.substring(0, name.length + 1) == (name + '=')) { cookieValue = decodeURIComponent(cookie.substring(name.length + 1)); break; } } } return cookieValue; } var csrftoken = getCookie('csrftoken'); /* The functions below will create a header with csrftoken */ function csrfSafeMethod(method) { // these HTTP methods do not require CSRF protection return (/^(GET|HEAD|OPTIONS|TRACE)$/.test(method)); } function sameOrigin(url) { // test that a given url is a same-origin URL // url could be relative or scheme relative or absolute var host = document.location.host; // host + port var protocol = document.location.protocol; var sr_origin = '//' + host; var origin = protocol + sr_origin; // Allow absolute or scheme relative URLs to same origin return (url == origin || url.slice(0, origin.length + 1) == origin + '/') || (url == sr_origin || url.slice(0, sr_origin.length + 1) == sr_origin + '/') || // or any other URL that isn't scheme relative or absolute i.e relative. !(/^(\/\/|http:|https:).*/.test(url)); } $.ajaxSetup({ beforeSend: function(xhr, settings) { if (!csrfSafeMethod(settings.type) && sameOrigin(settings.url)) { // Send the token to same-origin, relative URLs only. // Send the token only if the method warrants CSRF protection // Using the CSRFToken value acquired earlier xhr.setRequestHeader("X-CSRFToken", csrftoken); } } });
Офлайн
вот консоль с камнем
Прикреплённый файлы:
2.jpg (104,6 KБ)
Офлайн
Отбой тревоги. Респонз возвращал не данные json, а страницу. Я ошибся в юрлах! ппц… (пример рабочий)
Офлайн