数学建模社区-数学中国
标题:
为什么ajax发GET请求就成功,POST请求则报错?
[打印本页]
作者:
拉克丝
时间:
2015-4-20 09:45
标题:
为什么ajax发GET请求就成功,POST请求则报错?
(1)首先说明的是请求的URL是一个静态资源,比如一个json文件。
! Y( ~) N+ g6 Y
(2)现在现象是发GET请求就成功,POST请求则报错。
8 A& H0 C) P0 X9 x+ |
(3)最新发现:就算是GET请求,如果把JSON数据的序列化字符串直接作为query string也会导致报错。就是这样:some_url?{%22username%22:%22username%22,%22password%22:%22password%22}
% _0 }1 T* M3 x
(4)所报错误都是一样的:Failed to load resource: the server responded with a status of 500 (Internal Server Error)
! h% w3 e2 s" x/ C5 ?' d! B# t
添加修改:
9 w& e& R. G3 X; p1 g
(5)我请求的是一个静态资源,不存在后端逻辑代码,所以是打不了断点的。
- ^2 _- p; Q m
(6)有人要问我获取一个静态资源,直接用GET方式,而且也不用传参数啊。实际上我是一个前端开发,这里只是用一个json文件来作为返回值来模拟后端。等到和后端开发人员集成的时候,需要换成实际的URL,那时候就需要传参数了,而且也可能是POST方式。
, T; C4 L5 `$ t* t8 o* N
(7)我现在就是用jQuery的ajax实现的,传递query string就是用的其中的data属性。
% |6 @4 m4 e1 p) ^, G8 @
如果是:
& h8 e! w" Q3 g: r: W7 T# I4 k* V
(a)data: JSON_OBJECT 那么会使用jQuery本身的序列化方式来序列化,就没有问题
6 y7 N! v$ E- x0 [$ P6 u7 U
但如果是:
3 }' y" x% F6 ~7 I; U
(b)data: JSON.stringify(JSON_OBJECT) 直接传递这个序列化后的字符串就会报错
) K2 S! G' h o0 P0 v$ U
(8)已经和后端开发人员测试过,如果是存在后端逻辑代码,也就是不直接请求一个静态文件。那么所有情况都不会报错。
# t! r8 j) ]: h! v; l' l0 Y
(9)我用的编辑器是HBuilder,用的是它自带的web服务器。具体的实现代码可以查看我在HBuilder论坛上发的求助帖:
ajax只能发起GET请求,而不能发POST请求,否则报500错误
) B- P9 K3 b* p; m- o; J) M: t( E) O" G
(10)经过测试,发现如果是提交表单的时候,也存在类似的问题:将表单的action指向一个temp.html文件,如果method=post,那么会报500错误;如果method=get,则可以正常转到temp.html文件。
8 [) q6 O1 I0 I6 N0 z% O
(11)解决的方法当然就是把后端也搞起来。实际上我更想知道为什么会有这种现象。大家经常讨论GET和POST有什么区别,一说就是一大堆,但却没有指出这一点。
. M3 G' Y8 S. L3 I8 @8 D& G2 Q
$.ajax({ url: "abc.json", type: "GET" //不报错 //type: "POST" //报错});
; R7 k* D+ h1 {- X& s2 u! l
, B' y3 x: U3 ~5 f1 H0 m
6 W7 F1 w; Z0 c( r
- I% a) m4 d* |: H3 F) F" l
7 O5 ]9 P* i3 z
欢迎光临 数学建模社区-数学中国 (http://www.madio.net/)
Powered by Discuz! X2.5