【问题标题】:Using CORS header filter with dropwizard 0.7.0在 dropwizard 0.7.0 中使用 CORS 标头过滤器
【发布时间】:2014-08-24 04:50:16
【问题描述】:

我正在尝试获取 dropwizard 0.7.0 (Jersey) REST 服务来发送 HTML CORS 标头,例如“Access-Control-Allow-Origin”。我找到了各种教程,还了解了如何在 0.7.0 和以前的版本中进行操作的区别。最有希望的方法似乎是described in the dropwizard group,但是当我使用给定的代码时,不会发送任何标题。过滤器似乎不起作用。当我使用自定义过滤器时,它正在被初始化但也没有被使用。到目前为止,日志中没有任何异常。

这是我(最新的)运行方法:

        @Override
public void run(BackendConfiguration configuration, Environment environment) throws Exception {

    // XXX why doesn't this work?
    FilterRegistration.Dynamic filter = environment.servlets().addFilter("CORS", CrossOriginFilter.class);
    filter.addMappingForUrlPatterns(EnumSet.allOf(DispatcherType.class), true, "/*");
    filter.setInitParameter("allowedOrigins", "*"); // allowed origins comma separated
    filter.setInitParameter("allowedHeaders", "Content-Type,Authorization,X-Requested-With,Content-Length,Accept,Origin");
    filter.setInitParameter("allowedMethods", "GET,PUT,POST,DELETE,OPTIONS,HEAD");
    filter.setInitParameter("preflightMaxAge", "5184000"); // 2 months
    filter.setInitParameter("allowCredentials", "true");


    final DBIFactory factory = new DBIFactory();
    final DBI jdbi = factory.build(environment, configuration.getDataSourceFactory(), "h2");

    environment.jersey().register(new UserResource(jdbi));
}

是不是我做错了什么?

【问题讨论】:

    标签: java filter jersey cors dropwizard


    【解决方案1】:

    来自 CrossOriginFilter:

        String origin = request.getHeader(ORIGIN_HEADER);
        // Is it a cross origin request ?
        if (origin != null && isEnabled(request))
    

    您必须在请求中发送 Origin 标头才能使过滤器正常工作。

    【讨论】:

    • 非常感谢!在reading up 再次讨论这个话题之后,我想我现在也理解了这个概念了:)
    猜你喜欢
    • 2014-06-11
    • 2021-05-28
    • 2017-12-08
    • 2019-01-31
    • 1970-01-01
    • 2015-12-10
    • 2016-08-25
    • 2019-11-19
    • 2018-08-19
    相关资源
    最近更新 更多