【问题标题】:Origin is not allowed by Access-Control-Allow-Origin without solution没有解决方案的 Access-Control-Allow-Origin 不允许 Origin
【发布时间】:2017-07-20 16:43:29
【问题描述】:

我在 10 多天以来一直在尝试解决以下问题。我在没有解决方案的情况下将该站点上的所有指南和页面都涂红了。 我在 java 中使用 Jersey 库开发了一个 REST Web 服务器。服务的结果是 JSON 格式。在我的服务器中,我添加了 CORS 过滤器

服务器

package server;

import java.io.IOException;
import javax.ws.rs.container.ContainerRequestContext;
import javax.ws.rs.container.ContainerResponseContext;
import javax.ws.rs.container.ContainerResponseFilter;

public class CORSFilter implements ContainerResponseFilter {

   @Override
   public void filter(final ContainerRequestContext requestContext,
                      final ContainerResponseContext cres) throws IOException {
      cres.getHeaders().add("Access-Control-Allow-Origin", "*");
      cres.getHeaders().add("Access-Control-Allow-Headers", "origin, content-type, accept, authorization");
      cres.getHeaders().add("Access-Control-Allow-Credentials", "true");
      cres.getHeaders().add("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE, OPTIONS, HEAD");
      cres.getHeaders().add("Access-Control-Max-Age", "1209600");
   }

}

web.xml 是:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"     xmlns="http://xmlns.jcp.org/xml/ns/javaee"     xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee     http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" version="3.1">
  <display-name>conferenceServer</display-name>
  <welcome-file-list>
    <welcome-file>index.html</welcome-file>
    <welcome-file>index.htm</welcome-file>
    <welcome-file>index.jsp</welcome-file>
    <welcome-file>default.html</welcome-file>
    <welcome-file>default.htm</welcome-file>
    <welcome-file>default.jsp</welcome-file>
  </welcome-file-list>

  <servlet>
        <servlet-name>Jersey REST Service</servlet-name>
        <servlet-    class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
        <init-param>
            <param-name>jersey.config.server.provider.packages</param-name>
            <param-value>server</param-value>
        </init-param>

        <init-param>
            <param-    name>javax.ws.rs.container.ContainerResponseFilter</param-name>
            <param-value>server.CORSFilter</param-value>
        </init-param>

        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>Jersey REST Service</servlet-name>
        <url-pattern>/*</url-pattern>
    </servlet-mapping>

</web-app>

响应的 JSON 格式是有效的,但是当我在我的应用程序中调用服务时,我收到此消息错误:

[Error] Failed to load resource: Origin http://localhost:8100 is not allowed by Access-Control-Allow-Origin. (all, line 0)
[Error] XMLHttpRequest cannot load http://****/myServer/service. Origin http://localhost:8100 is not allowed by Access-Control-Allow-Origin. 

您认为问题出在哪里?

【问题讨论】:

  • 您的 XML 无效 &lt;param- name&gt; -> &lt;param-name&gt;
  • 这是一个复制粘贴错误。它不在我的程序中

标签: angularjs json rest cors jersey-2.0


【解决方案1】:

我认为这不能作为参数名称使用

<param-name>javax.ws.rs.container.ContainerResponseFilter</param-name>

您可以做两件事来确保过滤器已注册:

  1. 在过滤器类的顶部添加@Provider。初始化参数

    jersey.config.server.provider.packages
    

    将确保从包裹扫描中提取并注册。

  2. 使用 init-param ...classnames 注册过滤器

    <init-param>
        <param-name>jersey.config.server.provider.classnames</param-name>
        <param-value>server.CORSFilter</param-value>
    </init-param>
    

【讨论】:

  • 我刚刚对您进行了更正,但错误没有得到更正。我怎样才能确保它是错误的 SERVER 端(因此问题 CORS 过滤器设置错误)而不是 CLIENT 端?
  • 过滤器被调用了吗?
  • 我应该如何检查?
  • 你可以在过滤器中添加一个简单的日志语句
  • 过滤器被调用(我在函数中放了一个System.out)!当我在浏览器中使用服务的链接时,结果是正确的(我收到 JSON 向量)。如果我在我的 Cordova 应用程序中调用该服务,我会收到错误消息。我可以发布链接吗?我在外部服务器上上传了我的服务器应用程序
猜你喜欢
  • 2013-09-09
  • 2012-06-07
  • 2011-11-05
相关资源
最近更新 更多