溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Java中的跨域請(qǐng)求怎么利用Ajax jsonp 實(shí)現(xiàn)

發(fā)布時(shí)間:2020-11-21 16:03:16 來(lái)源:億速云 閱讀:195 作者:Leah 欄目:編程語(yǔ)言

這篇文章將為大家詳細(xì)講解有關(guān)Java中的跨域請(qǐng)求怎么利用Ajax jsonp 實(shí)現(xiàn),文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。

1、什么是JSONP

一般來(lái)說(shuō)位于 server1.example.com 的網(wǎng)頁(yè)無(wú)法與不是 server1.example.com的服務(wù)器溝通,而 HTML 的<script> 元素是一個(gè)例外。利用 <script> 元素的這個(gè)開(kāi)放策略,網(wǎng)頁(yè)可以得到從其他來(lái)源動(dòng)態(tài)產(chǎn)生的 JSON 資料,而這種使用模式就是所謂的 JSONP。用 JSONP 抓到的資料并不是 JSON,而是任意的JavaScript,用 JavaScript 直譯器執(zhí)行而不是用 JSON 解析器解析。

JSONP是一種協(xié)議,為了解決客戶端請(qǐng)求服務(wù)器跨域的問(wèn)題,但是并非是正式的傳輸協(xié)議。該協(xié)議的一個(gè)要點(diǎn)就是允許用戶傳遞一個(gè)callback參數(shù)給服務(wù)端,然后服務(wù)端返回?cái)?shù)據(jù)時(shí)會(huì)將這個(gè)callback參數(shù)作為函數(shù)名來(lái)包裹住JSON數(shù)據(jù),這樣客戶端就可以隨意定制自己的函數(shù)來(lái)自動(dòng)處理返回?cái)?shù)據(jù)了.

2、Ajax 請(qǐng)求其他域接口

我這個(gè)項(xiàng)目要請(qǐng)求另外一個(gè)第一個(gè)后臺(tái)接口請(qǐng)求數(shù)據(jù),在頁(yè)面渲染的時(shí)候,通過(guò)ajax加載數(shù)據(jù)如下:

  $.ajax({
        url: 'http://www.xxx.cn/lalala&#63;method=10082&page=1&pageSize=10',
        type: 'GET',
        dataType: 'json',
        timeout: 5000,
        contentType: 'application/json; charset=utf-8',
        success: function (result) {
          alter("aaaa");
        }
      });

這樣就出現(xiàn)跨域的錯(cuò)誤,如下所示:

No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'null' is therefore not allowed access. The response had HTTP status code 500.

Java中的跨域請(qǐng)求怎么利用Ajax jsonp 實(shí)現(xiàn)

這里就說(shuō)明不允許跨域請(qǐng)求,那么怎么辦? 換成jsonp好了。就改了dataType這個(gè)字段。

  $.ajax({
        url: 'http://www.xxx.cn/lalala&#63;method=10082&page=1&pageSize=10',
        type: 'GET',
        dataType: 'jsonp',
        timeout: 5000,
        contentType: 'application/json; charset=utf-8',
        success: function (result) {
          alter("aaaa");
        }
      });

結(jié)果: Uncaught SyntaxError: Unexpected token!

what the fuck!Java中的跨域請(qǐng)求怎么利用Ajax jsonp 實(shí)現(xiàn) 明明請(qǐng)求回來(lái)數(shù)據(jù),結(jié)果還是報(bào)錯(cuò)。原因是ajax請(qǐng)求服務(wù)器,而返回的數(shù)據(jù)格式不符合jsonp的返回格式,那么jsonp格式是什么樣的?

Callback({msg:'this is json data'}) 

這是什么叼東西,奇葩誰(shuí)定義的!如果你這么想,看來(lái)你沒(méi)有仔細(xì)看第1點(diǎn),JSON是一種輕量級(jí)的數(shù)據(jù)交換格式,像xml一樣。JSONP是一種使用JSON數(shù)據(jù)的方式,返回的不是JSON對(duì)象,是包含JSON對(duì)象的javaScript腳本。但是上圖是一段json串,所以報(bào)錯(cuò)啦。

3、參數(shù)返回處理

有一點(diǎn)你會(huì)發(fā)現(xiàn)在你是用jsonp協(xié)議請(qǐng)求時(shí),在參數(shù)中除了自己填寫(xiě)的參數(shù)外還有名為callback的參數(shù),如圖:

Java中的跨域請(qǐng)求怎么利用Ajax jsonp 實(shí)現(xiàn)

看看這個(gè)參數(shù)是什么東西,因?yàn)槲以赼jax請(qǐng)求的時(shí)候沒(méi)有指定,jsonp這個(gè)參數(shù),那么系統(tǒng)默認(rèn)參數(shù)名為“callback”。沒(méi)有指定jsonpCallback參數(shù), 那么jquery會(huì)生成隨機(jī)的函數(shù)名,如上圖所示。

比如我如下配置:

$.ajax({
      url: 'http://www.xxx.cn/lalala&#63;method=10082&page=1&pageSize=10',
      type: 'GET',
      dataType: 'jsonp',
      jsonp:'callbacka',//傳遞給請(qǐng)求處理程序或頁(yè)面的,用以獲得jsonp回調(diào)函數(shù)名的參數(shù)名(默認(rèn)為:callback)
      jsonpCallback:"success_jsonpCallback",//自定義的jsonp回調(diào)函數(shù)名稱(chēng),默認(rèn)為jQuery自動(dòng)生成的隨機(jī)函數(shù)名
      timeout: 5000,
      contentType: 'application/json; charset=utf-8',
      success: function (result) {
        alter("aaaa");
      }
    });

那么服務(wù)器亦可以通過(guò)下面方法獲取回調(diào)的函數(shù)名:

復(fù)制代碼 代碼如下:

string callbackFunName =request.getParameter("callbacka");//獲取的就是success_jsonpCallback 字符串

注意:系統(tǒng)會(huì)區(qū)分函數(shù)名大小寫(xiě)。

Java中的跨域請(qǐng)求怎么利用Ajax jsonp 實(shí)現(xiàn)

那么下面按照格式包裝一下看看咯:

String callback = request.getParameter("callback"); //不指定函數(shù)名默認(rèn) callback

return callback+ "(" + jsonStr + ")"

包了一下,結(jié)果真的不報(bào)錯(cuò),看下返回?cái)?shù)據(jù)如下圖:

Java中的跨域請(qǐng)求怎么利用Ajax jsonp 實(shí)現(xiàn)

4、JSONP的執(zhí)行過(guò)程

首先在客戶端注冊(cè)一個(gè)callback (如:'jsoncallback'), 然后把callback的名字(如:jsonp1236827957501)傳給服務(wù)器。注意:服務(wù)端得到callback的數(shù)值后,要用jsonp1236827957501(......)把將要輸出的json內(nèi)容包括起來(lái),此時(shí),服務(wù)器生成 json 數(shù)據(jù)才能被客戶端正確接收。

然后,以 javascript 語(yǔ)法的方式,生成一個(gè)function, function 名字就是傳遞上來(lái)的參數(shù) 'jsoncallback'的值 jsonp1236827957501 .

最后,將 json 數(shù)據(jù)直接以入?yún)⒌姆绞剑胖玫?function 中,這樣就生成了一段 js 語(yǔ)法的文檔,返回給客戶端??蛻舳藶g覽器,解析script標(biāo)簽,并執(zhí)行返回的 javascript 文檔,此時(shí)javascript文檔數(shù)據(jù),作為參數(shù), 傳入到了客戶端預(yù)先定義好的 callback 函數(shù)(如上例中jquery $.ajax()方法封裝的的success: function (json))里。

關(guān)于Java中的跨域請(qǐng)求怎么利用Ajax jsonp 實(shí)現(xiàn)就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI