問題分析:我的ajax的代碼在IE浏覽器,360的IE核心的浏覽器,以及在火狐都是運行正常的,但是在GOOGLE CHROME下卻讓我非常頭疼,總是沒有顯示正確結果。
我本機的開發環境如下:
google chrome 版本 28.0.1469.0m
服務器Tomcat6.0
服務器端Spring MVC 的代碼如下:
控制器部分:
@RequestMapping(value="/searchRecordBlackListByCardId.json")
public String searchRecordBlackListByCardId(HttpServletRequest request,HttpServletResponse response,String cardId,ModelMap mm){
response.setContentType("application/json;charset=UTF-8");
PwCardSpeciallist pcs = blackListService.getRecordBlackListByCardId(cardId);
mm.addAttribute("pwCardSpeciallist", pcs);
return "jsonView";
}
xxx-Servlet.XML配置部分:
<bean id="jsonView" class="net.sf.json.spring.web.servlet.view.JsonView"/> <bean id="beanNameResolver" class="org.springframework.web.servlet.view.BeanNameViewResolver"> <property name="order" value="0" /> </bean> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" p:viewClass="org.springframework.web.servlet.view.JstlView" p:order="100" p:prefix="/WEB-INF/jsp/" p:suffix=".jsp" />
前台頁面部分:
<script type="text/javascript">
$(document).ready(function(){
$("#searchBlack").click(function(){
$.get('${requestScope.basePath}searchRecordBlackListByCardId.json', {
cardId : encodeURI( '123456789' )
}, function (data, textStatus){
alert(data.pwCardSpeciallist.cardId);
},'json');
return false;
})
});
</script>
對於上面出現的問題,給出三個截圖,大家就能知道為什麼了。。。。
第一張,使用localhost:8080/cardDemo/searchRecordBlackList.html#地址訪問的時候:

第二張,使用127.0.0.1:8080:8080/cardDemo/searchRecordBlackList.html#訪問的時候:

第三張,使用我的本機IP訪問的時候192.168.1.100:8080/cardDemo/searchRecordBlackList.html#

原來,google chrome是由於某種安全策略的需要,禁止訪問本地的ajax資源!這個還是有點坑爹,畢竟我之前所在那個公司在某些項目上號稱“只支持GOOGLE CHROME浏覽器的”。
這個故事告訴我們....在以後調試的時候,要盡量使用本機IP來訪問SERVER端,而不要使用127.0.0.1或者是localhost,這樣就不會像我一樣花費好幾個小時的時間去尋找這個錯誤。