這篇“java后臺(tái)調(diào)用接口及處理跨域問題的方法是什么”文章的知識(shí)點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價(jià)值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“java后臺(tái)調(diào)用接口及處理跨域問題的方法是什么”文章吧。
創(chuàng)新互聯(lián)公司服務(wù)項(xiàng)目包括永州網(wǎng)站建設(shè)、永州網(wǎng)站制作、永州網(wǎng)頁制作以及永州網(wǎng)絡(luò)營(yíng)銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,永州網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到永州省份的部分城市,未來相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
在做系統(tǒng)的時(shí)候,有些時(shí)候系統(tǒng)A的js代碼需要調(diào)用系統(tǒng)B的接口,這就會(huì)產(chǎn)生跨域現(xiàn)象,可以通過后臺(tái)調(diào)用處理跨域
問題,這就有點(diǎn) “代理” 的意思了。
public String httpPost(String urlStr,Mapparams){ 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 請(qǐng)求的參數(shù) 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(); }
背景:在我們系統(tǒng)上,從外部引用了一個(gè)建議系統(tǒng),在建議系統(tǒng)當(dāng)用戶被給予評(píng)論或回復(fù)之后,我的消息中顯示未讀消息數(shù)。
實(shí)現(xiàn)的效果:在建議系統(tǒng)中當(dāng)未讀消息數(shù)大于0時(shí),我們的系統(tǒng)引入建議系統(tǒng)的位置上會(huì)出現(xiàn)提示有未讀消息的紅點(diǎn)。
在建議系統(tǒng)的后臺(tái),我們寫了一個(gè)countBlog的接口,用來獲取未讀消息數(shù)量(json格式)
在我們的系統(tǒng)的前臺(tái),引入接口通過返回的未讀消息數(shù)量來控制紅點(diǎn)顯示
運(yùn)行后報(bào)跨域問題的bug:
方法一:注解@CrossOrigin
方法二:addCorsMappings配置
@Override public void addCorsMappings(CorsRegistry registry) { registry.addMapping("/**") .allowedOrigins("*") .allowedMethods("GET", "HEAD", "POST", "PUT", "DELETE", "OPTIONS") .allowCredentials(true) .maxAge(3600) .allowedHeaders("*"); }
弊端:使用此方法配置之后再使用自定義攔截器時(shí)跨域相關(guān)配置就會(huì)失效。
原因是請(qǐng)求經(jīng)過的先后順序問題,當(dāng)請(qǐng)求到來時(shí)會(huì)先進(jìn)入攔截器中,而不是進(jìn)入Mapping映射中,所以返回的頭信息中并沒有配置的跨域信息。瀏覽器就會(huì)報(bào)跨域異常。
方法三:使用CorsFilter過濾器
private CorsConfiguration corsConfig() { CorsConfiguration corsConfiguration = new CorsConfiguration(); * 請(qǐng)求常用的三種配置,*代表允許所有,當(dāng)時(shí)你也可以自定義屬性(比如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); }
以上就是關(guān)于“java后臺(tái)調(diào)用接口及處理跨域問題的方法是什么”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對(duì)大家有幫助,若想了解更多相關(guān)的知識(shí)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。