欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React+Spring實(shí)現(xiàn)跨域問題的完美解決方法

 更新時(shí)間:2018年08月28日 14:55:30   作者:喝著啤酒寫bug  
這篇文章主要介紹了React+Spring實(shí)現(xiàn)跨域問題的完美解決方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

最近小編在學(xué)習(xí)react,在學(xué)習(xí)過程中遇到React+Spring實(shí)現(xiàn)跨域問題,下面小編記錄了整個(gè)問題過程,給大家做個(gè)參考。

react 跨域訪問后臺(tái),默認(rèn)是有跨域問題,并且火弧和谷歌瀏覽器,對(duì)跨域問題展示還不一樣.

谷歌瀏覽器如下圖:

此處狀態(tài)是200,然而在Response卻沒有任何信息,如下圖

然而火弧瀏覽器,對(duì)該問題的描述,就清淅得多,

火弧瀏覽器告訴我們,跨域了,關(guān)于react跨域的帖子,網(wǎng)上也有相關(guān)帖子,搜索到的方法,大約都是如下解決方式:

如果你是通過creat-react-app構(gòu)建的項(xiàng)目,請(qǐng)?jiān)趐ackage.json文件中的根目錄下,添加"proxy": "

配置完成后,再次訪問接口,還是出現(xiàn)一樣的跨域問題,既然recat的配置,未解決跨域問題,我就把思路轉(zhuǎn)到spring,在spring去處理跨域,

package com.gg.interceptor;
import java.util.ArrayList;
import java.util.List;
import java.util.Vector;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
public class ProcessInterceptor implements HandlerInterceptor{
 @Override
 public boolean preHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object handler)
   throws Exception {
  // TODO Auto-generated method stub 
  // 指定白名單域名 http://localhost:8000,http://localhost:8000
  List<String> whileList = new Vector<String>(); 
  whileList.add("http://127.0.0.1:8000");
  whileList.add("http://localhost:8000");
  String clientIp = httpServletRequest.getHeader("origin");
  boolean status = false;
  for(String ip : whileList) {
   if(clientIp!=null&&clientIp.equals(ip)) {
    status = true;
    break;
   }
  }
  /**
   * 網(wǎng)上解決方案是httpServletResponse.setHeader("Access-Control-Allow-Origin","*");設(shè)置后發(fā)現(xiàn),還是不能處理跨域問題,需要指定某一個(gè)ip,如:http://127.0.0.1:8000 
   * */
  httpServletResponse.setHeader("Access-Control-Allow-Origin",status?clientIp:null); 
  //響應(yīng)頭設(shè)置 
  httpServletResponse.setHeader("Access-Control-Allow-Headers", "Content-Type,Content-Length, Authorization, Accept,X-Requested-With"); 
  //響應(yīng)類型
  httpServletResponse.setHeader("Access-Control-Allow-Methods","PUT,POST,GET,DELETE,OPTIONS"); 
  httpServletResponse.setHeader("X-Powered-By","Jetty"); 
  httpServletResponse.setHeader("Access-Control-Allow-Credentials","true");
  String method= httpServletRequest.getMethod(); 
  if (method.equals("OPTIONS")){ 
   httpServletResponse.setStatus(200); 
   return false; 
  } 
  System.out.println(method+",status:"+status+",clientIp:"+clientIp); 
  return true; 
 }
 @Override
 public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,
   ModelAndView modelAndView) throws Exception {
  // TODO Auto-generated method stub
 }
 @Override
 public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
   throws Exception {
  // TODO Auto-generated method stub
 }
}

react客戶端代碼如下:

Model層js代碼:

*login({ payload }, { call, put }){
  let formData = new FormData();
  formData.append("loginId",payload.loginId);//賬號(hào)
  formData.append("passWord",payload.passWord);//密碼
  const response = yield call(requestGuangGao, formData); 
  yield put({
  type: 'changeLoginStatus',
  payload: response,
  });
 },

api層js代碼:

export async function requestGuangGao(formData){
 // let formData = new FormData();
 // formData.append("loginId",params.loginId);
 // formData.append("passWord",params.passWord);
 console.log("requestGua >url :" );
 return request('http://127.0.0.1:8080/guanggao/userController/login.do', {
 method: 'POST', 
 mode: 'cors', 
 body:formData,
 }); 
}

通過以下設(shè)置,react跨域問題就處理好了。

總結(jié)

以上所述是小編給大家介紹的React+Spring實(shí)現(xiàn)跨域問題的完美解決方法,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • React的組件協(xié)同使用實(shí)現(xiàn)方式

    React的組件協(xié)同使用實(shí)現(xiàn)方式

    這篇文章主要介紹了React的組件協(xié)同使用,文中給大家提到在React開發(fā)中,有哪些場(chǎng)景的組件協(xié)同?又如何去實(shí)現(xiàn)組件的協(xié)同使用呢?本文都給大家提到,感興趣的朋友跟隨小編一起看看吧
    2021-09-09
  • React Router V5:使用HOC組件實(shí)現(xiàn)路由攔截功能

    React Router V5:使用HOC組件實(shí)現(xiàn)路由攔截功能

    這篇文章主要介紹了React Router V5:使用HOC組件實(shí)現(xiàn)路由攔截功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-03-03
  • 關(guān)于react-router中的Prompt組件使用心得

    關(guān)于react-router中的Prompt組件使用心得

    這篇文章主要介紹了關(guān)于react-router中的Prompt組件學(xué)習(xí)心得,Prompt組件作用是,在用戶準(zhǔn)備離開該頁(yè)面時(shí),?彈出提示,?返回true或者false,?如果為true,?則離開頁(yè)面,?如果為false,?則停留在該頁(yè)面,本文結(jié)合示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-01-01
  • React?JSX深入淺出理解

    React?JSX深入淺出理解

    React使用JSX來替代常規(guī)的JavaScript。JSX是一個(gè)看起來很像 XML的JavaScript語法擴(kuò)展。我們不需要一定使用 JSX,但它有以下優(yōu)點(diǎn):JSX執(zhí)行更快,因?yàn)樗诰幾g為JavaScript代碼后進(jìn)行了優(yōu)化。它是類型安全的,在編譯過程中就能發(fā)現(xiàn)錯(cuò)誤。使用JSX編寫模板更加簡(jiǎn)單快速
    2022-12-12
  • React Native Popup實(shí)現(xiàn)示例

    React Native Popup實(shí)現(xiàn)示例

    本文主要介紹了React Native Popup實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • React使用useImperativeHandle自定義暴露給父組件的示例詳解

    React使用useImperativeHandle自定義暴露給父組件的示例詳解

    useImperativeHandle?是?React?提供的一個(gè)自定義?Hook,用于在函數(shù)組件中顯式地暴露給父組件特定實(shí)例的方法,本文將介紹?useImperativeHandle的基本用法、常見應(yīng)用場(chǎng)景,需要的可以參考下
    2024-03-03
  • 淺談react新舊生命周期鉤子

    淺談react新舊生命周期鉤子

    所謂的生命周期就是指某個(gè)事物從開始到結(jié)束的各個(gè)階段,本文主要介紹了淺談react新舊生命周期鉤子,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-12-12
  • react實(shí)現(xiàn)無限循環(huán)滾動(dòng)信息

    react實(shí)現(xiàn)無限循環(huán)滾動(dòng)信息

    這篇文章主要為大家詳細(xì)介紹了react實(shí)現(xiàn)無限循環(huán)滾動(dòng)信息,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • 利用React高階組件實(shí)現(xiàn)一個(gè)面包屑導(dǎo)航的示例

    利用React高階組件實(shí)現(xiàn)一個(gè)面包屑導(dǎo)航的示例

    這篇文章主要介紹了利用React高階組件實(shí)現(xiàn)一個(gè)面包屑導(dǎo)航的示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • react中fetch之cors跨域請(qǐng)求的實(shí)現(xiàn)方法

    react中fetch之cors跨域請(qǐng)求的實(shí)現(xiàn)方法

    本篇文章主要介紹了react中fetch之cors跨域請(qǐng)求的實(shí)現(xiàn)方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-03-03

最新評(píng)論