jsonp跨域請(qǐng)求實(shí)現(xiàn)示例
網(wǎng)上看了很多關(guān)于jsonp的資料,發(fā)現(xiàn)在本機(jī)運(yùn)行后實(shí)現(xiàn)不了,有的是有錯(cuò)漏,有的是說(shuō)的比較含糊,接合自己的情況,整了一個(gè)可運(yùn)行的示例;
前言:
ajax請(qǐng)求地址:http://192.168.1.102:8080/carop/jsonp
服務(wù)端要返回的jsonp字符串:jsonpCallback({"name":"劉德華","電話":"17688888888"})
jsonp寫法,寫法上可以理解成一個(gè)javascript函數(shù)的執(zhí)行,例如alert("hello world")會(huì)彈出hello world的窗口,再例如alert({"name":"劉德華"})會(huì)彈出[object Object]的窗口。(注意這里參數(shù)兩端沒(méi)加雙引號(hào),它是一個(gè)有屬性的對(duì)象而不是一個(gè)字符串)
那么本示例的jsonp中,可以將jsonpCallback理解成函數(shù)名,{"name":"劉德華","電話":"17688888888"}這個(gè)對(duì)象是這個(gè)函數(shù)執(zhí)行時(shí)所要傳遞的參數(shù)。
客戶端:
$.ajax({ type: "get", async:false, url: "http://192.168.1.102:8080/carop/jsonp", dataType: "jsonp", jsonpCallback:"jsonpCallback", success: function(data){ alert(data.name+"\n "+data.tel); } });
其他的ajax方法比如getjson亦可,寫法上有區(qū)別,這里僅采用一種方法。
說(shuō)明:jsonpCallback:"jsonpCallback",前一個(gè)ajax參數(shù)表示要執(zhí)行的函數(shù),后面的”jsonpCallback“,這個(gè)是服務(wù)器返回jsonp的javascript函數(shù)名。(網(wǎng)上有相關(guān)資料這個(gè)參數(shù)寫的是jsonp而不是jsonpCallback,經(jīng)實(shí)際測(cè)試要寫成jsonpCallback,jquery版本1.8,所測(cè)試瀏覽器為火狐和edge)
服務(wù)端
servlet控制器層直接返回jsonp;
import java.io.IOException; import java.io.PrintWriter; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; @WebServlet("/jsonp") public class jsonp extends HttpServlet{ @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { resp.setCharacterEncoding("UTF-8"); //System.out.println("進(jìn)入jsonp"); resp.setContentType("text/json;charset=utf-8"); String json="{\"name\":\"劉德華\",\"tel\":\"17688888888\"}"; String jsonp="jsonpCallback("+json+")"; PrintWriter pw=resp.getWriter(); System.out.println(jsonp); pw.print(jsonp); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { // TODO Auto-generated method stub doGet(req, resp); } }
以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,同時(shí)也希望多多支持腳本之家!
- 實(shí)例講解使用原生JavaScript處理AJAX請(qǐng)求的方法
- 原生js jquery ajax請(qǐng)求以及jsonp的調(diào)用方法
- 詳解JavaScript原生封裝ajax請(qǐng)求和Jquery中的ajax請(qǐng)求
- 原生javascript的ajax請(qǐng)求及后臺(tái)PHP響應(yīng)操作示例
- Javascript原生ajax請(qǐng)求代碼實(shí)例
- 輕松搞定jQuery+JSONP跨域請(qǐng)求的解決方案
- JavaScript用JSONP跨域請(qǐng)求數(shù)據(jù)實(shí)例詳解
- Ajax jsonp跨域請(qǐng)求實(shí)現(xiàn)方法
- JSONP跨域請(qǐng)求實(shí)例詳解
- 詳細(xì)解密jsonp跨域請(qǐng)求
- JSONP跨域請(qǐng)求
- 原生js實(shí)現(xiàn)ajax請(qǐng)求和JSONP跨域請(qǐng)求操作示例
相關(guān)文章
JavaScript中clientWidth,offsetWidth,scrollWidth的區(qū)別
這篇文章主要介紹了Element中clientWidth,offsetWidth,scrollWidth的區(qū)別,幫助大家更好的理解和使用JavaScript,感興趣的朋友可以了解下2021-01-01JS實(shí)現(xiàn)slide文字框縮放伸展效果代碼
這篇文章主要介紹了JS實(shí)現(xiàn)slide文字框縮放伸展效果代碼,涉及JavaScript響應(yīng)鼠標(biāo)事件動(dòng)態(tài)操作頁(yè)面元素屬性的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11JavaScript模擬文件拖選框樣式v1.0的實(shí)例
下面小編就為大家?guī)?lái)一篇JavaScript模擬文件拖選框樣式v1.0的實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-08-08JavaScript數(shù)據(jù)結(jié)構(gòu)與算法之二叉樹實(shí)現(xiàn)查找最小值、最大值、給定值算法示例
這篇文章主要介紹了JavaScript數(shù)據(jù)結(jié)構(gòu)與算法之二叉樹實(shí)現(xiàn)查找最小值、最大值、給定值算法,涉及javascript二叉樹定義、賦值、遍歷、查找等相關(guān)操作技巧,需要的朋友可以參考下2019-03-03使用原生JavaScript實(shí)現(xiàn)放大鏡效果
這篇文章主要為大家詳細(xì)介紹了如何使用原生JavaScript實(shí)現(xiàn)放大鏡效果(可自由大小適配),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2023-03-03webpack構(gòu)建打包的性能優(yōu)化實(shí)戰(zhàn)指南
webpack是前端開(kāi)發(fā)中比較常用的打包工具之一,另外還有g(shù)ulp,grunt,下面這篇文章主要給大家介紹了關(guān)于webpack構(gòu)建打包的性能優(yōu)化的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-03-03AJAX XMLHttpRequest對(duì)象創(chuàng)建使用詳解
這篇文章主要介紹了AJAX XMLHttpRequest對(duì)象創(chuàng)建使用詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08深入理解setTimeout函數(shù)和setInterval函數(shù)
下面小編就為大家?guī)?lái)一篇深入理解setTimeout函數(shù)和setInterval函數(shù)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-05-05