- 在线时间
- 5 小时
- 最后登录
- 2015-5-13
- 注册时间
- 2015-4-8
- 听众数
- 9
- 收听数
- 0
- 能力
- 0 分
- 体力
- 96 点
- 威望
- 0 点
- 阅读权限
- 20
- 积分
- 44
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 31
- 主题
- 31
- 精华
- 0
- 分享
- 0
- 好友
- 2
升级   41.05% TA的每日心情 | 擦汗 2015-4-30 14:17 |
|---|
签到天数: 3 天 [LV.2]偶尔看看I
- 自我介绍
- 德玛西亚
 |
(1)首先说明的是请求的URL是一个静态资源,比如一个json文件。
! }* B8 j3 C) r- Q7 J(2)现在现象是发GET请求就成功,POST请求则报错。
, m' C9 z3 q4 K5 G& N( g(3)最新发现:就算是GET请求,如果把JSON数据的序列化字符串直接作为query string也会导致报错。就是这样:some_url?{%22username%22:%22username%22,%22password%22:%22password%22}
7 S9 Z+ j+ H7 Q( w; N. h! [" O(4)所报错误都是一样的:Failed to load resource: the server responded with a status of 500 (Internal Server Error)- X# B5 C3 P0 Q: K$ t y8 S' V! f# e
添加修改:
8 ^+ f, ]2 O: `' l. j- k/ _# W1 G(5)我请求的是一个静态资源,不存在后端逻辑代码,所以是打不了断点的。
- x# C6 n& V' W4 N+ h4 T# Q(6)有人要问我获取一个静态资源,直接用GET方式,而且也不用传参数啊。实际上我是一个前端开发,这里只是用一个json文件来作为返回值来模拟后端。等到和后端开发人员集成的时候,需要换成实际的URL,那时候就需要传参数了,而且也可能是POST方式。
; _: T6 }* k- s# z( j' \(7)我现在就是用jQuery的ajax实现的,传递query string就是用的其中的data属性。
2 _0 j8 s U3 ?- t+ j0 n& v如果是:5 n# e: q4 T9 j/ d. F Y/ `
(a)data: JSON_OBJECT 那么会使用jQuery本身的序列化方式来序列化,就没有问题. w( l* l5 U) d/ G9 |
但如果是:
! z; U' T; A v) g5 z) m/ G' L(b)data: JSON.stringify(JSON_OBJECT) 直接传递这个序列化后的字符串就会报错
& X9 i' Y) e, A: Y8 g C* c7 m(8)已经和后端开发人员测试过,如果是存在后端逻辑代码,也就是不直接请求一个静态文件。那么所有情况都不会报错。$ G8 ], e$ H$ N& I% e1 q" K0 ?8 U
(9)我用的编辑器是HBuilder,用的是它自带的web服务器。具体的实现代码可以查看我在HBuilder论坛上发的求助帖:ajax只能发起GET请求,而不能发POST请求,否则报500错误
9 D: Z8 O/ i% W) m(10)经过测试,发现如果是提交表单的时候,也存在类似的问题:将表单的action指向一个temp.html文件,如果method=post,那么会报500错误;如果method=get,则可以正常转到temp.html文件。
9 ^. W- @; ]) Y! K" p(11)解决的方法当然就是把后端也搞起来。实际上我更想知道为什么会有这种现象。大家经常讨论GET和POST有什么区别,一说就是一大堆,但却没有指出这一点。2 U" s% S- G1 A; M, T) r
$.ajax({ url: "abc.json", type: "GET" //不报错 //type: "POST" //报错});8 T' x( k6 C3 s7 H
; g2 \$ E& t$ t1 a& C8 }
5 F9 c. P! e2 D1 `$ W
* ~7 j. G( M- D/ K: A8 X8 c( J. {! Q$ J, Y, T @& ]* G
|
zan
|