日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

瀏覽器的同源策略

跨域的根本原因就是因為瀏覽器的同源策略,這是瀏覽器出于安全性考慮做出的限制,所謂同源是指:域名、協議、端口相同。

比如在互聯網上有兩個資源(網頁或者請求等),如果A想要訪問B的資源,如果A、B并非同源,即域名、協議、端口有任意一個不相同,那么就會出現跨域問題。

跨域的表現即是在瀏覽器控制臺中報類似于下圖中的錯誤。

瀏覽器跨域問題以及常用解決方案

 

No 'Access-Control-Allow-Origin' header is present on the requested resource.

下面是常見的幾種跨域的情況,除了前兩種都會出現跨域問題

瀏覽器跨域問題以及常用解決方案

 

跨域問題的解決

分享幾個比較常用的解決跨域的辦法

后端解決方案

對于JAVA后端來說,如果你使用的是SpringBoot來開發項目,那么解決跨域會非常的方便,只需要在需要開啟跨域支持的借口的控制層,就是是常說的Controller,添加類注解:@CrossOrigin,如下

@CrossOrigin
@RestController
public class HelloController {
    // ...具體請求
}

SpringBoot也可以編寫一個專門的配置類來解決跨域的問題,即CorsConfig,這樣做的好處就是不需要每一個Controller添加@CrossOrigin注解

import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

@Configuration
public class CorsConfig implements WebMvcConfigurer {

    @Override
    public void addCorsMAppings(CorsRegistry registry) {
        registry.addMapping("/**")
            .allowedOrigins("*")
            .allowCredentials(true)
            .allowedMethods("GET", "POST", "PUT", "DELETE", "OPTIONS")
            .maxAge(3600);
    }
}

還有一種方法也可以解決跨域問題,就是利用過濾器來解決,代碼如下

@Component
public class CORSFilter implements Filter {


    @Override
    public void init(FilterConfig filterConfig) throws ServletException {

    }

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        HttpServletResponse response = (HttpServletResponse) servletResponse;
        response.setHeader("Access-Control-Allow-Origin", "*");
        response.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE");
        response.setHeader("Access-Control-Max-Age", "3600");
        response.setHeader("Access-Control-Allow-Headers", "x-requested-with");
        filterChain.doFilter(servletRequest, servletResponse);
    }

    @Override
    public void destroy() {

    }
}

以上三種方法都可以實現對跨域的支持,個人最推薦使用第一種注解的方式,簡單粗暴!

前端解決方案

在Vue的項目中可以使用配置代理的方式解決跨域問題,以Vue2.X版本為例

這里后端端口8888,暴露一個moti-memo/hello請求,前端端口為8080,通過上文可知,在前后端均不處理的情況下,端口不同肯定會發生跨域問題。

瀏覽器跨域問題以及常用解決方案

 

export default {
name: 'App',
created() {
this.$http.get("http://localhost:8888/moti-memo/hello").then(res => {
console.log(res.data);
})
}
}

瀏覽器跨域問題以及常用解決方案

 

前端配置代理的方式也很簡單,編輯config/index.js配置文件,在dev對象的proxyTable屬性配置代理信息,如下

module.exports = {
  dev: {
    // Paths
    assetsSubDirectory: 'static',
    assetsPublicPath: '/',
    proxyTable: {
      '/api': {
        target:'http://127.0.0.1:8888',
        changeOrigin:true,
        pathRewrite:{
          '^/api': ''
        }
      }
    },

這里可以看到我們配置了/api前綴的代理,之后我們只需要在使用axIOS發送請求的時候把原來跨域的請求IP+端口替換成/api。

<script>
export default {
  name: 'App',
  created() {
    this.$http.get("/api/moti-memo/hello").then(res => {
      console.log(res.data);
    })
  }
}
</script>

在Vue-cli的3.X版本中,配置文件變為了vue.config.js,我們需要編輯這個配置文件,在devServer對象的proxy屬性加入代理信息,參考如下

module.exports = {
  lintOnSave: false,
  devServer: {
    proxy: {
      '/api': {
        target: 'http://127.0.0.1:8888',
        changeOrigin: true,
        pathRewrite: {
          '^/api': ''
        }
      }
    }
  }
}

Nginx解決方案

使用Nginx配置反向代理也是可以幫助我們解決跨域問題的,只需要修改nginx的配置文件,參考如下

server {
    listen 9000;
    server_name localhost;
    
    location /api/ {
        rewrite ^/api/(.*)$ /$1 break;   
        # 跨域服務的地址
        proxy_pass http://www.serverA.com;
    }
}

前端所有對跨域服務的請求都加一個/api前綴,Nginx做代理的時候會移除/api前綴。例如:請求路徑為/api/hello的請求將會訪問http://www.serverA.com/hello。

參考文章

  • www.jianshu.com/p/8fa2acd103ea
  • https://segmentfault.com/a/1190000010197683

分享到:
標簽:瀏覽器
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定