AJAX опубликовать данные в колбе

Вот моя функция просмотра

@app.route('/share', methods=['GET', 'POST'])
def share():
    form = ShareForm(request.form)
    if request.method == 'POST':
        title = form.title.data
        body = form.body.data
        share_id = form.share_id.data
        print 'form data %s %s %s' % (title, body, share_id)
        if not share_id:
            share = Shares(title, body, 'PUBLISHED', current_user.id)
            db.session.add(share)
            db.session.commit()
            form.share_id.data = share.id
        return jsonify({'status': 204, 'body': {'status': True}})
    else:
        return render_template('share.html', form=form)

Код для пост-запроса ajax

<script>
    $(function(){
      $('#share').on('click', function(e){
        e.preventDefault(); // preventing default click action
        $.ajax({
          url: '/share',
          type: 'post',
          contentType: "application/json; charset=utf-8",
          data: $('#share-form').serialize(),
          success: function(){
            console.log('success');
            console.log( $('#share-form').serialize());
          }, error: function(xhr, textStatus, errorThrown) {
            alert(xhr.responseText);
            console.log( $('#share-form').serialize());
          }});
        })
        //return false;
      });
</script>

в представлении, когда я пытаюсь напечатать объект запроса, я получаю следующие данные

print request.data
'title=adsl%3Blsaj%3Blj%3Bl&body=j%3Bas%3Bl%3Bl+&share_id='

Но если я попытаюсь сделать,

print request.form.get('title', 'None')

Я получаю "Нет"

Может кто-нибудь сказать мне, как это исправить?

1 ответ

Решение

Вы устанавливаете тип контента на application/json но отправляем application/x-www-form-urlencoded данные вместо.

Установите правильный тип контента:

$.ajax({
  url: '/share',
  type: 'post',
  contentType: "application/x-www-form-urlencoded",
  data: $('#share-form').serialize(),

или, что еще лучше, оставьте значение по умолчанию, опустив contentType ключ в целом.

Другие вопросы по тегам