Ajax コードはサーバーにリクエストを送信できませんが、同じ URL に対して通常の http リクエストを行うと機能します。URL フィールドを「http://」URL に置き換えようとしましたが、まだ機能しません。誰でもアイデアがありますか?
Environment:
django 1.5.4;
python 2.7.4;
jquery 2.0.3;
test.html
<html>
<head>
<title></title>
<script type='text/javascript' src="http://code.jquery.com/jquery-2.0.3.min.js"></script>
<script type="text/javascript">
$(document).ready(function() {
$("#button").click(function(){
$.ajax({
type : "POST",
url : "{% url 'getlist' %}",
data : {
msg : 'abcd'
},
}).done(function(data){
alert(data.message);
});
});
});
</script>
</head>
<body>
<input id="button" type="button" value="Get message from server!">
{% if resource_list %}
<ul>
{% for resource in resource_list %}
<li><a href="{{ resource.url }}">{{ resource.name }}</a></li>
{% endfor %}
</ul>
{% else %}
<p>No Resources</p>
{% endif %}
</body>
view.py
def getList(request):
print "Reach getLists"
if request.is_ajax():
try:
msg = request.POST['msg']
except:
return HttpResponse(simplejson.dumps({'message':'Error From Server'}))
return HttpResponse(simplejson.dumps({'message':msg}))
else:
return HttpResponse(simplejson.dumps({'message':'Not an ajax request'}))
urls.py
url(r'^test$', views.test),
url(r'^getlist/$', views.getList, name='getlist'),
====================================更新============= ======================== エラー情報
Forbidden (403)
CSRF 検証に失敗しました。リクエストは中止されました。ヘルプ 失敗の理由: CSRF トークンが見つからないか、正しくありません。
============================= 解決済み ================== ===============
解決策: JavaScript ファイルのデータ フィールドに「csrfmiddlewaretoken:'{{ csrf_token }}',」を追加すると、動作しました。その理由は、django が CSRF 保護を有効にしているためです。
============================== ありがとう ================== =================
@dkp2442 と @Christian Ternus、特に @dkp2442 の助けに感謝します。