WebWorks中使用JQuery的getJSON方法进行跨域访问

来源:岁月联盟 编辑:exp 时间:2012-10-16

遇到的问题:
1. 测试环境
 Firefox, Chrome都不能回调checkSIGNIN_callback方法
诊断:在服务器上监听89端口,数据请求到达,正常返回JSON格式的数据
解决:使用IM的Ripple进行调试

2. 黑莓真机上面上测试,该code没有成功执行网络访问
诊断:在服务器上监听89端口,发现根本没有数据请求到达,也没有数据返回。
可能问题:a)config.xml文件里面access controll   b)运营商(联通)网络对特殊端口89的访问限制
解决方法:服务器上做端口修改或者端口映射,最后把89端口改成了80端口;同时程序中把端口89改为80。
 (为保证原有exlive服务器用户能正常登录,我是在路由器上面把89映射为两个对外端口80和89)

代码片段:
[javascript] 
function checkSIGNIN_callback(data) { 
[javascript] view plaincopy
<span style="white-space:pre">  </span>if (data.signInTime == "") { //not sign in 
        $("#signin_button").text("签到");   
        $('#signin_button').button('refresh'); 
 
    }if (data.signOutTime == "") {  //not sign out 
        $("#signin_button").text("签出");   
        $('#signin_button').button('refresh'); 
    }else { 
        $("#signin_button").text("签到/签出");   
        $('#signin_button').button('refresh'); 
    } 
alert(6);    

function checkSIGNIN() { 
alert("gPhone is " + gPhone); 
    jQuery.support.cors = true; 
    checkSIGNIN_url = "http://shanghai.springworks.info:89/pgps/empPr/empParamAction_sendEmpParam.action?phone=" + gPhone; 
    $.getJSON(checkSIGNIN_url, checkSIGNIN_callback);