2017-07-09 16 views
0

json POSTを受け取るためのウェブフックを構築しました。しかし、私はjsonデコーダからエラーを受け取っています。ここではウェブフックからview.pyファイルジャンソンのjson構文解析

import json 
from django.shortcuts import render 
from django.views.decorators.http import require_POST 
from django.views.decorators.csrf import csrf_exempt 
from django.http import HttpResponse 
from .models import UserText 

# Create your views here. 
@csrf_exempt 
@require_POST 
def webhookmb(request): 
    usrtxt = json.loads(request.body) 

    UserText.objects.create(
     id = usrtxt['id'], 
     recipient = usrtxt['recipient'], 
     originator = usrtxt['originator'], 
     body = usrtxt['body'], 
     createdDatetime = usrtxt['createdDatetime'], 
    ) 

    # redirect to API.AI 
    # TODO 


    return HttpResponse(200) 

これは私がこれを固定アプローチする方法が非常にわからない

2017-07-09T00:19:45.559146+00:00 app[web.1]: Internal Server Error: /webhookmb/ 
2017-07-09T00:19:45.559154+00:00 app[web.1]: Traceback (most recent call last): 
2017-07-09T00:19:45.559155+00:00 app[web.1]: File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 41, in inner 
2017-07-09T00:19:45.559156+00:00 app[web.1]: File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/base.py", line 187, in _get_respon 
se 
2017-07-09T00:19:45.559157+00:00 app[web.1]:  response = self.process_exception_by_middleware(e, request) 
2017-07-09T00:19:45.559155+00:00 app[web.1]:  response = get_response(request) 
2017-07-09T00:19:45.559159+00:00 app[web.1]:  response = wrapped_callback(request, *callback_args, **callback_kwargs) 
2017-07-09T00:19:45.559158+00:00 app[web.1]: File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/base.py", line 185, in _get_respon 
se 
2017-07-09T00:19:45.559160+00:00 app[web.1]:  return view_func(*args, **kwargs) 
2017-07-09T00:19:45.559159+00:00 app[web.1]: File "/app/.heroku/python/lib/python3.6/site-packages/django/views/decorators/csrf.py", line 58, in wrapped_v 
iew 
2017-07-09T00:19:45.559161+00:00 app[web.1]: File "/app/.heroku/python/lib/python3.6/site-packages/django/views/decorators/http.py", line 40, in inner 
2017-07-09T00:19:45.559161+00:00 app[web.1]:  return func(request, *args, **kwargs) 
2017-07-09T00:19:45.559162+00:00 app[web.1]: File "/app/webhookmb/views.py", line 12, in webhookmb 
2017-07-09T00:19:45.559162+00:00 app[web.1]:  usrtxt = json.loads(request.body) 
2017-07-09T00:19:45.559163+00:00 app[web.1]: File "/app/.heroku/python/lib/python3.6/json/__init__.py", line 354, in loads 
2017-07-09T00:19:45.559163+00:00 app[web.1]:  return _default_decoder.decode(s) 
2017-07-09T00:19:45.559164+00:00 app[web.1]: File "/app/.heroku/python/lib/python3.6/json/decoder.py", line 339, in decode 
2017-07-09T00:19:45.559165+00:00 app[web.1]:  obj, end = self.raw_decode(s, idx=_w(s, 0).end()) 
2017-07-09T00:19:45.559165+00:00 app[web.1]: File "/app/.heroku/python/lib/python3.6/json/decoder.py", line 357, in raw_decode 
2017-07-09T00:19:45.559166+00:00 app[web.1]:  raise JSONDecodeError("Expecting value", s, err.value) from None 
2017-07-09T00:19:45.559170+00:00 app[web.1]: json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) 

を受け付けておりますエラーでだ、私はトラブルの束を撮影してきましたしかし、私はどのように修正するには困惑しているjson.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0)フィードバックは素晴らしいだろう。ありがとう!

+0

クライアントがサーバーに適切なjsonを送信していない可能性がありますか? – akiva

+0

これはどんなバージョンのdjangoですか?おそらく、あなたはrequest.POST、request.bodyなどを印刷して、送信されているデータを見ることができますか?同様の質問が役に立つかもしれません:https://stackoverflow.com/questions/22368190/django-cant-access-raw-post-data – David542

答えて

0

エンコードの不一致による可能性があります。

あなたはjson自体を提供していないので、

代わりにこれを試してください。

json.loads(request.body.decode('utf-8'))