問題分析:我的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,這樣就不會像我一樣花費好幾個小時的時間去尋找這個錯誤。