在做系統的時候,有些時候系統A的js程式碼需要呼叫系統B的接口,這就會產生跨域現象,可以透過後台呼叫處理跨域
問題,這就有點「代理」 的意思了。
public String httpPost(String urlStr,Map<String,String> params){ URL connect; StringBuffer data = new StringBuffer(); try { connect = new URL(urlStr); HttpURLConnection connection = (HttpURLConnection)connect.openConnection(); connection.setRequestMethod("POST"); connection.setDoOutput(true); connection.setDoInput(true); connection.setUseCaches(false);//post不能使用缓存 connection.setInstanceFollowRedirects(true); connection.setRequestProperty("accept", "*/*"); connection.setRequestProperty("connection", "Keep-Alive"); connection.setRequestProperty("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)"); OutputStreamWriter paramout = new OutputStreamWriter( connection.getOutputStream(),"UTF-8"); String paramsStr = ""; //拼接Post 请求的参数 for(String param : params.keySet()){ paramsStr += "&" + param + "=" + params.get(param); } if(!paramsStr.isEmpty()){ paramsStr = paramsStr.substring(1); } paramout.write(paramsStr); paramout.flush(); BufferedReader reader = new BufferedReader(new InputStreamReader( connection.getInputStream(), "UTF-8")); String line; while ((line = reader.readLine()) != null) { data.append(line); } paramout.close(); reader.close(); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } return data.toString(); }
## 背景:在我們系統上,從外部引用了一個建議系統,在建議系統當使用者被給予評論或回覆之後,我的訊息中顯示未讀訊息數。
實現的效果:在建議系統中當未讀取訊息數大於0時,我們的系統會引入建議系統的位置上會出現提示有未讀取訊息的紅點。
在建議系統的後台,我們寫了一個countBlog的接口,用來獲取未讀訊息數量(json格式)#在我們的系統的前台,引入接口通過返回的未讀取訊息數量來控制紅點顯示運行後報跨域問題的bug:解決問題方法一:註解@CrossOrigin
#方法二:addCorsMappings設定
@Override public void addCorsMappings(CorsRegistry registry) { registry.addMapping("/**") .allowedOrigins("*") .allowedMethods("GET", "HEAD", "POST", "PUT", "DELETE", "OPTIONS") .allowCredentials(true) .maxAge(3600) .allowedHeaders("*"); }弊端:使用此方法設定之後再使用自訂攔截器時跨域相關設定就會失效。 原因是請求經過的先後順序問題,當請求到來時會先進入攔截器中,而不是進入Mapping映射中,所以返回的頭信息中並沒有配置的跨域資訊。瀏覽器就會報跨域異常。
方法三:使用CorsFilter過濾器
private CorsConfiguration corsConfig() { CorsConfiguration corsConfiguration = new CorsConfiguration(); * 请求常用的三种配置,*代表允许所有,当时你也可以自定义属性(比如header只能带什么,只能是post方式等等) */ corsConfiguration.addAllowedOrigin("*"); corsConfiguration.addAllowedHeader("*"); corsConfiguration.addAllowedMethod("*"); corsConfiguration.setAllowCredentials(true); corsConfiguration.setMaxAge(3600L); return corsConfiguration; } @Bean public CorsFilter corsFilter() { UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource(); source.registerCorsConfiguration("/**", corsConfig()); return new CorsFilter(source); }
以上是java後台呼叫介面及處理跨域問題怎麼解決的詳細內容。更多資訊請關注PHP中文網其他相關文章!