Уведомления

Группа в Telegram: @pythonsu

#1 Окт. 18, 2017 10:23:53

Xa_xoo
Зарегистрирован: 2015-08-28
Сообщения: 58
Репутация: +  0  -
Профиль   Отправить e-mail  

Ajax response есть, а данных в базе нет

Есть форма обратной связи. заполняем 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 = "Форма связи"

HTML:
[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"
        )

JS ajax(только рабочая часть):
 $(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);
            }
        });
    };
});

Прикреплённый файлы:
attachment 1.jpg (64,0 KБ)

Офлайн

#2 Окт. 18, 2017 10:49:18

scidam
Зарегистрирован: 2016-06-15
Сообщения: 288
Репутация: +  35  -
Профиль   Отправить e-mail  

Ajax response есть, а данных в базе нет

Поставьте все же перед def create_post(request) для начала декоратор csrf_exempt, ибо все же
вы не передаете в { ‘name’: name, ‘email’: email, ‘subject’: subject, ‘message’: message } csrftoken.
Проверьте, будет ли работать с csrf_exempt.

Офлайн

#3 Окт. 18, 2017 12:43:06

Xa_xoo
Зарегистрирован: 2015-08-28
Сообщения: 58
Репутация: +  0  -
Профиль   Отправить e-mail  

Ajax response есть, а данных в базе нет

scidam
Поставьте все же перед def create_post(request) для начала декоратор csrf_exempt, ибо все жевы не передаете в { ‘name’: name, ‘email’: email, ‘subject’: subject, ‘message’: message } csrftoken.Проверьте, будет ли работать с csrf_exempt.
поставил и @csrf_protect и @csrf_exempt , но итог тот же. CSRF передается вроде в заголовке, в консоле виден X-CSRF

Офлайн

#4 Окт. 18, 2017 12:52:44

Xa_xoo
Зарегистрирован: 2015-08-28
Сообщения: 58
Репутация: +  0  -
Профиль   Отправить e-mail  

Ajax response есть, а данных в базе нет

у меня 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);
            }
        }
    });

Офлайн

#5 Окт. 18, 2017 13:04:31

Xa_xoo
Зарегистрирован: 2015-08-28
Сообщения: 58
Репутация: +  0  -
Профиль   Отправить e-mail  

Ajax response есть, а данных в базе нет

вот консоль с камнем

Прикреплённый файлы:
attachment 2.jpg (104,6 KБ)

Офлайн

#6 Окт. 18, 2017 14:39:26

Xa_xoo
Зарегистрирован: 2015-08-28
Сообщения: 58
Репутация: +  0  -
Профиль   Отправить e-mail  

Ajax response есть, а данных в базе нет

Отбой тревоги. Респонз возвращал не данные json, а страницу. Я ошибся в юрлах! ппц… (пример рабочий)

Офлайн

Board footer

Модераторировать

Powered by DjangoBB

Lo-Fi Version