婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Ajax跨域問題的解決辦法匯總(推薦)

Ajax跨域問題的解決辦法匯總(推薦)

熱門標簽:ai機器人電銷資源 硅語電話機器人公司 騰訊地圖標注位置能用多久 地圖標注項目怎么樣 越南河內地圖標注 云呼外撥網絡電話系統 機器人電銷騙局揭秘 超級大富翁地圖標注 個人怎樣在百度地圖標注地名

本篇將講述一個小白從遇到跨域不知道是跨域問題,到知道是跨域問題不知道如何解決,再到解決跨域問題,最后找到兩種方法解決ajax 跨域問題的全過程。

不知是跨域問題

起 因是這樣的,為了復用,減少重復開發,單獨開發了一個用戶權限管理系統,共其他系統獲取認證與授權信息,暫且稱之為A系統;調用A系統以B為例。在B系統 中用ajax調用A系統系統的接口(數據格式為json),當時特別困惑,在A系統中訪問相應的url可正?;胤礿son數據,但是在B系統中使用 ajax請求同樣的url則一點兒反應都沒有,好像什么都沒有發生一樣。這樣反反復復改來改去好久都沒能解決,于是求救同事,提醒可能是ajax跨域問 題,于是就將這個問題當做跨域問題來解決了。

知跨域而不知如何解決

知道問題的確切原因,剩下的就是找到解決問題的方法了。google了好久,再次在同事的指點下知道jQuery的ajax有jsonp這樣的屬性可以用來解決跨域的問題。

找到一種解決方式

現在也知道了怎樣來解決跨域問題,余下的就是實現的細節了。實現的過程中錯誤還是避免不了的。由于不了解json和jsonp兩種格式的區別,也犯了錯誤,google了好久才解決。

首先來看看在頁面中如何使用jQuery的ajax解決跨域問題的簡單版:

$(document).ready(function(){
var url='http://localhost:8080/WorkGroupManagment/open/getGroupById"
+"?id=1callback=?';
$.ajax({
url:url,
dataType:'jsonp',
processData: false, 
type:'get',
success:function(data){
alert(data.name);
},
error:function(XMLHttpRequest, textStatus, errorThrown) {
alert(XMLHttpRequest.status);
alert(XMLHttpRequest.readyState);
alert(textStatus);
}});
}); 

這樣寫是完全沒有問題的,起先error的處理函數中僅僅是alert(“error”),為了進一步弄清楚是什么原因造成了錯誤,故將處理函數變 為上面的實現方式。最后一行alert使用為;parsererror。百思不得其解,繼續google,最終還是在萬能的stackoverflow找 到了答案,鏈接在這里。原因是jsonp的格式與json格式有著細微的差別,所以在server端的代碼上稍稍有所不同。

比較一下json與jsonp格式的區別:

json格式:

{
"message":"獲取成功",
"state":"1",
"result":{"name":"工作組1","id":1,"description":"11"}
} 

jsonp格式:

callback({
"message":"獲取成功",
"state":"1",
"result":{"name":"工作組1","id":1,"description":"11"}
}) 

看出來區別了吧,在url中callback傳到后臺的參數是神馬callback就是神馬,jsonp比json外面有多了一層,callback()。這樣就知道怎么處理它了。于是修改后臺代碼。

后臺java代碼最終如下:

@RequestMapping(value = "/getGroupById")
public String getGroupById(@RequestParam("id") Long id,
HttpServletRequest request, HttpServletResponse response)
throws IOException {
String callback = request.getParameter("callback");
ReturnObject result = null;
Group group = null;
try {
group = groupService.getGroupById(id);
result = new ReturnObject(group, "獲取成功", Constants.RESULT_SUCCESS);
} catch (BusinessException e) {
e.printStackTrace();
result = new ReturnObject(group, "獲取失敗", Constants.RESULT_FAILED);
}
String json = JsonConverter.bean2Json(result);
response.setContentType("text/html");
response.setCharacterEncoding("utf-8");
PrintWriter out = response.getWriter();
out.print(callback + "(" + json + ")");
return null;
} 

注意這里需要先將查詢結果轉換我json格式,然后用參數callback在json外面再套一層,就變成了jsonp。指定數據類型為jsonp的ajax就可以做進一步處理了。

雖然這樣解決了跨域問題,還是回顧下造成parsererror的原因。原因在于盲目的把json格式的數據當做jsonp格式的數據讓ajax處理,造成了這個錯誤,此時server端代碼是這樣的:

@RequestMapping(value = "/getGroupById")
@ResponseBody
public ReturnObject getGroupById(@RequestParam("id") Long id,
HttpServletRequest request, HttpServletResponse response){
String callback = request.getParameter("callback");
ReturnObject result = null;
Group group = null;
try {
group = groupService.getGroupById(id);
result = new ReturnObject(group, "獲取成功", Constants.RESULT_SUCCESS);
} catch (BusinessException e) {
e.printStackTrace();
result = new ReturnObject(group, "獲取失敗", Constants.RESULT_FAILED);
}
return result;
} 

至此解決ajax跨域問題的第一種方式就告一段落。

追加一種解決方式

追求永無止境,在google的過程中,無意中發現了一個專門用來解決跨域問題的jQuery插件-jquery-jsonp。

有第一種方式的基礎,使用jsonp插件也就比較簡單了,server端代碼無需任何改動。

來看一下如何使用jquery-jsonp插件解決跨域問題吧。

var url="http://localhost:8080/WorkGroupManagment/open/getGroupById"
+"?id=1callback=?";
$.jsonp({
"url": url,
"success": function(data) {
$("#current-group").text("當前工作組:"+data.result.name);
},
"error": function(d,msg) {
alert("Could not find user "+msg);
}
}); 

至此兩種解決跨域問題的方式就全部介紹完畢。

補充:Ajax跨域問題有三種解決方案:

1.通過中間過渡層解決跨域問題

(1)通過Web代理服務器將不同域的應用統一通過代理服務器進行隔離,所有的應用都在一個域名下面了。(比如apache,nginx等)

(2)跨域的安全限制都是指瀏覽器端來說的.服務器端是不存在跨域安全限制的,所以通過本機服務器端通過類似httpclient方式完成“跨域訪問”的工作。

2.通過script>標簽解決跨域問題

注意:凡是擁有"src"這個屬性的標簽都擁有跨域的能力,比如script>、img>、iframe>

示例:

前臺腳本:

script type="text/javascript"> 
var flightHandler = function(data){ 
alert('你查詢的航班結果是:票價 ' + data.price + ' 元,' + '余票 ' + data.tickets + ' 張。'); 
}; 
var url = "http://abc.com:8080/AjaxCrossDomain/data/data.jsp?code=CA1998callback=flightHandler"; 
var script = document.createElement('script'); 
script.setAttribute('src', url); 
document.getElementsByTagName('head')[0].appendChild(script); 
/script> 

后臺data.jsp內容:

%@ page language="java" pageEncoding="UTF-8"%> 
% 
String callback = request.getParameter("callback"); 
StringBuilder builder = new StringBuilder(); 
builder.append(callback).append("({").append("\"code\": \"CA1998\",").append("\"price\": 1780,").append("\"tickets\": 5").append("});"); 
out.println(builder.toString()); 
%>

使用jquery的jsonp來實現跨域訪問,例子如下:

script type="text/javascript"> 
$(function(){ 
$.ajax({ 
type: "get", 
async: false, 
url: "http://abc.com:8080/AjaxCrossDomain/jsonp/data.jsp", 
dataType: "jsonp", 
jsonp: "callback", 
jsonpCallback:"flightHandler", 
success: function(json){ 
alert('您查詢到航班信息:票價: ' + json.price + ' 元,余票: ' + json.tickets + ' 張。'); 
}, 
error: function(){ 
alert('fail'); 
} 
}); 
}); 
/script> 

您可能感興趣的文章:
  • Ajax跨域查詢完美解決通過$.getJSON()實現
  • 完美解決AJAX跨域問題
  • jquery ajax跨域解決方法(json方式)
  • jquery的ajax跨域請求原理和示例
  • ajax跨域請求js拒絕訪問的解決方法
  • IE9版本以下ajax 跨域問題可行解決方法
  • 服務端配置實現AJAX跨域請求
  • 解決ajax跨域請求數據cookie丟失問題
  • ajax跨域(基礎域名相同)表單提交的方法

標簽:林芝 鄭州 內蒙古 舟山 邢臺 洛陽 海南 遼源

巨人網絡通訊聲明:本文標題《Ajax跨域問題的解決辦法匯總(推薦)》,本文關鍵詞  Ajax,跨域,問,題的,解決,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Ajax跨域問題的解決辦法匯總(推薦)》相關的同類信息!
  • 本頁收集關于Ajax跨域問題的解決辦法匯總(推薦)的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产精品美女久久久久久2018| 丝袜亚洲另类欧美| 不卡一卡二卡三乱码免费网站| 亚洲精品中文在线观看| 国产亚洲欧洲一区高清在线观看| 91精品婷婷国产综合久久性色| 91在线视频免费观看| 国产传媒日韩欧美成人| 精品午夜久久福利影院| 日韩国产在线观看一区| 亚洲一线二线三线视频| ...中文天堂在线一区| 国产亚洲一本大道中文在线| 日韩欧美成人午夜| 日韩你懂的在线播放| 91精品国产一区二区| 911精品国产一区二区在线| 欧洲人成人精品| 91国偷自产一区二区三区观看 | 天天综合色天天| 亚洲人成7777| 亚洲激情图片小说视频| 一区二区在线观看免费视频播放| 亚洲欧美激情在线| 亚洲曰韩产成在线| 日韩av一区二区三区四区| 日本伊人午夜精品| 九九精品一区二区| 国产精品自拍一区| 成人午夜激情影院| 色哟哟亚洲精品| 欧美丰满一区二区免费视频| 欧美电影免费观看高清完整版在| 日韩欧美电影一区| 国产精品免费久久久久| 亚洲男人天堂av| 悠悠色在线精品| 午夜精品久久久久久久蜜桃app| 日本美女一区二区三区视频| 国产一区二区三区在线观看精品| 波多野结衣中文字幕一区二区三区| 一本大道综合伊人精品热热| 欧美日韩国产高清一区二区| 久久天堂av综合合色蜜桃网| 亚洲色图都市小说| 日韩高清一级片| 成人午夜激情在线| 欧美福利视频一区| 国产精品欧美经典| 日韩avvvv在线播放| 国产成人在线视频网站| 欧美丝袜丝交足nylons| 久久网站热最新地址| 亚洲国产精品一区二区久久恐怖片| 久久精品国产亚洲5555| 色婷婷av一区二区三区软件| 精品国产伦一区二区三区观看体验 | 精品欧美一区二区在线观看| 久久嫩草精品久久久精品| 亚洲伦理在线免费看| 男男gaygay亚洲| 91免费在线看| 日韩免费高清视频| 18欧美乱大交hd1984| 免费高清在线一区| 在线视频观看一区| 国产日韩欧美制服另类| 五月激情六月综合| 99久久国产综合精品色伊| 99久久久免费精品国产一区二区| 欧美人伦禁忌dvd放荡欲情| 久久精品夜色噜噜亚洲a∨| 婷婷国产在线综合| 色综合久久久久综合体| 久久日一线二线三线suv| 亚洲h动漫在线| 在线免费观看成人短视频| 国产香蕉久久精品综合网| 毛片一区二区三区| 91理论电影在线观看| 欧美激情在线看| 久久精品国产99国产| 欧美性感一类影片在线播放| 亚洲欧洲美洲综合色网| 国产成人自拍高清视频在线免费播放| 日韩欧美一区二区在线视频| 亚洲午夜在线电影| 欧美性受xxxx黑人xyx性爽| 亚洲激情六月丁香| 99热精品一区二区| 久久亚洲精华国产精华液| 国产呦精品一区二区三区网站| 欧美一级一区二区| 亚洲成人在线免费| 欧美老女人在线| 日韩精品国产欧美| 欧美高清视频在线高清观看mv色露露十八 | 色88888久久久久久影院野外| 国产精品国产三级国产aⅴ入口 | 亚洲精品久久久久久国产精华液| 成av人片一区二区| 国产欧美日韩一区二区三区在线观看| 精品一区二区成人精品| 5858s免费视频成人| 偷偷要91色婷婷| 欧美一区二区黄色| 日本视频中文字幕一区二区三区| 9色porny自拍视频一区二区| 亚洲精品成人精品456| 色吊一区二区三区| 亚洲无人区一区| 日韩一级大片在线观看| 国产精品一区二区三区四区 | 色婷婷一区二区| 亚洲一级二级在线| 欧美一级免费观看| 日本午夜一本久久久综合| 26uuu精品一区二区三区四区在线| 久久精品噜噜噜成人av农村| 国产日韩欧美不卡| 色美美综合视频| 日本不卡123| 久久蜜桃av一区精品变态类天堂| 国产在线一区二区| 亚洲色图视频网站| 欧美精品视频www在线观看| 美女看a上一区| 久久九九久久九九| 色婷婷一区二区| 国产在线视视频有精品| 成人免费一区二区三区视频| 欧美日韩和欧美的一区二区| 国产精品一色哟哟哟| 亚洲国产中文字幕| 日韩欧美国产不卡| 成人激情小说乱人伦| 一二三四区精品视频| 久久综合久久久久88| 一本一本久久a久久精品综合麻豆| 日本欧美一区二区三区乱码 | 天堂在线一区二区| 国产精品蜜臀在线观看| 欧洲在线/亚洲| 精品在线一区二区| 亚洲午夜国产一区99re久久| 国产日韩欧美在线一区| 欧美日韩激情一区二区三区| 成人免费高清在线观看| 日本欧美韩国一区三区| 亚洲精品亚洲人成人网在线播放| 欧美精品一区二区精品网| 欧美午夜一区二区三区| www.av亚洲| 国产九色sp调教91| 美女久久久精品| 视频在线观看国产精品| **网站欧美大片在线观看| 久久亚洲一区二区三区四区| 中文无字幕一区二区三区| 久久人人97超碰com| 91成人看片片| 久久久久99精品一区| 日本精品一区二区三区高清| 精品日韩成人av| 欧美一区二区三区色| 奇米影视7777精品一区二区| 欧美一卡二卡在线| 天天av天天翘天天综合网色鬼国产 | 中文字幕一区二区三| 免费在线看成人av| 欧美一级一区二区| 成人免费高清视频| 欧美区一区二区三区| 亚洲欧美色一区| hitomi一区二区三区精品| 日韩免费观看高清完整版 | 欧美精品乱码久久久久久按摩| 欧美精品丝袜久久久中文字幕| 午夜精品福利一区二区三区蜜桃| 韩国毛片一区二区三区| 欧美日韩一区二区三区在线看| 日韩精品一区二区三区在线| 这里只有精品免费| 国产精品一区二区三区乱码| 国产精品色呦呦| 欧美日韩国产成人在线免费| 2024国产精品| 精品少妇一区二区三区免费观看| 成人一区在线看| 精品一区二区三区在线播放视频| 日韩欧美在线网站| 精品久久久久久最新网址| 日韩欧美一二三四区| 亚洲国产精品成人综合色在线婷婷| 在线观看免费亚洲| 成人av免费在线| 99在线热播精品免费| 石原莉奈在线亚洲三区| 亚洲五码中文字幕| 日本欧美一区二区三区|