gpt4 book ai didi

cors - 如何在 JAX-RS Web 服务上启用跨域请求?

转载 作者:行者123 更新时间:2023-12-03 05:30:06 25 4
gpt4 key购买 nike

我开发了一套 Restful 网络服务。由于错误,我无法从远程客户端调用任何这些方法请求的资源上不存在“Access-Control-Allow-Origin” header 。

服务在本地主机上完美运行。是否需要在服务器端进行任何更改或配置来解决该问题。即启用跨域请求。

我正在使用 WildFly 8、JavaEE 7

最佳答案

我也想知道同样的事情,所以经过一些研究,我发现最简单的方法就是使用 JAX-RS ContainerResponseFilter 来添加相关的 CORS header 。这样您就不需要用 CXF 替换整个 Web 服务堆栈(Wildfly 使用 CXF 是某种形式,但看起来它并不将其用于 JAX-RS,也许只是 JAX-WS)。

无论您是否使用此过滤器,它都会将 header 添加到每个 REST Web 服务。

package com.yourdomain.package;

import java.io.IOException;

import javax.ws.rs.container.ContainerRequestContext;
import javax.ws.rs.container.ContainerResponseContext;
import javax.ws.rs.container.ContainerResponseFilter;
import javax.ws.rs.ext.Provider;

@Provider
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");
}

}

然后,当我使用curl 进行测试时,响应具有 CORS header :

$ curl -D - "http://localhost:8080/rest/test"
HTTP/1.1 200 OK
X-Powered-By: Undertow 1
Access-Control-Allow-Headers: origin, content-type, accept, authorization
Server: Wildfly 8
Date: Tue, 13 May 2014 12:30:00 GMT
Connection: keep-alive
Access-Control-Allow-Origin: *
Access-Control-Allow-Credentials: true
Transfer-Encoding: chunked
Content-Type: application/json
Access-Control-Max-Age: 1209600
Access-Control-Allow-Methods: GET, POST, PUT, DELETE, OPTIONS, HEAD

我的理解是,它是 @Provider 注释告诉 JAX-RS 运行时使用过滤器,没有注释什么也不会发生。

我从 Jersey example 中得到了使用 ContainerResponseFilter 的想法.

关于cors - 如何在 JAX-RS Web 服务上启用跨域请求?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23450494/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com