Java中的跨域请求如何利用cors实现

本篇文章为大家展示了Java中的跨域请求如何利用cors实现,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

10年积累的成都做网站、网站建设经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站制作后付款的网站建设流程,更有北戴河免费网站建设让你可以放心的选择与我们合作。

什么是跨域?

跨域,指的是浏览器不能执行其他网站的脚本。它是由浏览器的同源策略造成的,是浏览器对JavaScript施加的安全限制。

ajax本身实际上是通过XMLHttpRequest对象来进行数据的交互,而浏览器出于安全考虑,不允许js代码进行跨域操作,所以会警告。

常见解决跨域的方式

  1. script标签
  2. iframe
  3. jsonp
  4. 服务端中转请求
  5. cors

今天的主角cors

全称:Cross-Origin Resource Sharing

中文意思:跨域资源共享

它在维基百科上的定义是:跨域资源共享(CORS )是一种网络浏览器的技术规范,它为Web服务器定义了一种方式,允许网页从不同的域访问其资源。而这种访问是被同源策略所禁止的。CORS系统定义了一种浏览器和服务器交互的方式来确定是否允许跨域请求。 它是一个妥协,有更大的灵活性,但比起简单地允许所有这些的要求来说更加安全。

下面就说一下cors在java tomcat下如何配置

首先下载jar包

cors-filter与java-property-utils



  com.thetransactioncompany
  cors-filter
  2.5



  com.thetransactioncompany
  java-property-utils
  1.10

修改web.xml

增加以下代码(最好放在其他filter前边)

     
  CORS 
  com.thetransactioncompany.cors.CORSFilter 
   
   cors.allowOrigin 
    * 
   
   
   cors.supportedMethods 
    GET, POST, HEAD, PUT, DELETE 
   
   
   cors.supportedHeaders 
    Accept, Origin, X-Requested-With, Content-Type, Last-Modified 
   
   
    cors.exposedHeaders 
    Set-Cookie 
   
   
    cors.supportsCredentials 
    true 
  
 
 
 
  CORS 
  /* 

jQuery请求示例

$.ajax("url", {
  type: "POST",
  xhrFields: {
    withCredentials: true,
    useDefaultXhrHeader: false
  },
  data: {
    type: "test"
  },
  dataType: 'json',
  crossDomain: true,
  success: function(data, status, xhr) {
   console.log(data);
  }
});

上述内容就是Java中的跨域请求如何利用cors实现,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注创新互联行业资讯频道。


新闻名称:Java中的跨域请求如何利用cors实现
本文来源:http://scyanting.com/article/jddcij.html