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

280
19 октября 2017, 10:28

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

 <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>

Вьюха:

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);
            }
        });
    };
// 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);
            }
        }
    });
});

READ ALSO
Ползунок треугольником JQuery CSS

Ползунок треугольником JQuery CSS

ЗдравствуйтеСтолкнулся с проблемой

219
не отображается блок в ios [требует правки]

не отображается блок в ios [требует правки]

Тестирую верстку сайта в browserstackНа iPhone У меня внутри подвала два div'а, при этом один не отображается совсем, пишет, что height: 0

272
Python MySQL запрос с подстановкой значений

Python MySQL запрос с подстановкой значений

Пытаюсь создать во Flask sql запрос с подстановкой параметраТакой код выдает ошибку:

268
Sql работа с таймером

Sql работа с таймером

Добрый день надо реализовать такой скриптЕсть таблица в ней есть колонка статус по деффалту она оффлайн

339