我想在服务器端使用Grails进行跨源通信。我发现的唯一文档就是这个
https://grails.org/plugin/cors
但这是Grails的旧版本。我找到的其他文件是春天:
https://spring.io/guides/gs/rest-service-cors/
所以我将文件SimpleCorsFilter.groovy
添加到init/myproject/
文件夹,但我不知道如何将此组件连接到resources.groovy
答案 0 :(得分:18)
所以,如果你到这里使用grails 3.2。+ ,你可以使用默认方式。
转到application.yml
并添加:
grails:
cors:
enabled: true
它会添加Access-Control-Allow-Origin '*'
。
如果您想要不同的内容,look this page
答案 1 :(得分:12)
我们使用一个普通的servlet过滤器和resources.groovy中的条目来解决这个问题:
public class CorsFilter extends OncePerRequestFilter {
@Override
protected void doFilterInternal(HttpServletRequest req, HttpServletResponse resp, FilterChain chain)
throws ServletException, IOException {
String origin = req.getHeader("Origin");
boolean options = "OPTIONS".equals(req.getMethod());
if (options) {
if (origin == null) return;
resp.addHeader("Access-Control-Allow-Headers", "origin, authorization, accept, content-type, x-requested-with");
resp.addHeader("Access-Control-Allow-Methods", "GET, HEAD, POST, PUT, DELETE, TRACE, OPTIONS");
resp.addHeader("Access-Control-Max-Age", "3600");
}
resp.addHeader("Access-Control-Allow-Origin", origin == null ? "*" : origin);
resp.addHeader("Access-Control-Allow-Credentials", "true");
if (!options) chain.doFilter(req, resp);
}
}
resources.groovy:
beans = {
corsFilter(CorsFilter)
}
这适用于使用基本身份验证的CORS请求。我编写了Grails 2.x插件,这似乎比使用Grails 3更容易。
答案 2 :(得分:8)
具体来说,这里有一些有用的代码。请注意,拦截器名称必须与您的控制器名称匹配(此处为workRequest),域名必须是您要调用的任何内容(此处为localhost:8081),并且它是您想要的before()方法:
package rest
class WorkRequestInterceptor {
boolean before() {
header( "Access-Control-Allow-Origin", "http://localhost:8081" )
header( "Access-Control-Allow-Credentials", "true" )
header( "Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE" )
header( "Access-Control-Max-Age", "3600" )
true
}
boolean after() { true }
}
答案 3 :(得分:5)
当我遇到CORS问题时,我正在使用emberjs框架和Grails 3.0休息应用程序。按照本文中的步骤http://www.greggbolinger.com/rendering-json-in-grails-for-ember-js/帮助我进一步了解。
本文展示了如何使用新的Interceptor创建一个CorsInterceptor类来设置正确的标头。
class CorsInterceptor {
CorsInterceptor() {
matchAll()
}
boolean before() {
header( "Access-Control-Allow-Origin", "http://localhost:4200" )
header( "Access-Control-Allow-Credentials", "true" )
header( "Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE")
header( "Access-Control-Max-Age", "3600" )
true
}
boolean after() { true }
}
这对于GET请求按预期工作,但POST和PUT请求失败。原因是OPTIONS预检请求首先发送到http://localhost:8080/mycontroller/1234,在我的情况下导致返回 404 not 。
在这个答案https://stackoverflow.com/a/31834551的帮助下,我将CorsInterceptor类修改为:
class CorsInterceptor {
CorsInterceptor() {
matchAll()
}
boolean before() {
header( "Access-Control-Allow-Origin", "http://localhost:4200" )
boolean options = ("OPTIONS" == request.method)
if (options) {
header( "Access-Control-Allow-Origin", "http://localhost:4200" )
header( "Access-Control-Allow-Credentials", "true" )
header( "Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE")
header( "Access-Control-Max-Age", "3600" )
response.status = 200
}
true
}
boolean after() { true }
}
现在POST和PUT请求正在运行。
答案 4 :(得分:3)
你应该使用grails 3的新Interceptor API。 (https://grails.github.io/grails-doc/3.0.x/guide/single.html#interceptors)
您可以使用grails create-interceptor
命令创建拦截器。对于CORS拦截器,我会使用此拦截器的after()
方法,并将其设置为匹配所有请求(或只是您需要的请求)。您可以在此方法中使用response
对象,因此设置标题应类似于Spring文档中描述的情况。
答案 5 :(得分:2)
我发现的最干净,最简单的grails 3.1.x解决方案是添加Apache默认的CorsFilter:
import org.apache.catalina.filters.CorsFilter
// Place your Spring DSL code here
beans = {
corsFilter(CorsFilter) //Custom CorsFilter under src/main/java/ works as well. I prefer Apache though...
}
来自#user215556的答案也可以,但Apache Cors过滤器的默认设置也可以
答案 6 :(得分:0)
如果您需要为Spring Security核心/其余插件提供的端点启用CORS,则必须添加以下内容:
Bootstrap.groovy:
SpringSecurityUtils.clientRegisterFilter("corsFilter",
SecurityFilterPosition.SECURITY_CONTEXT_FILTER.order - 1)
resources.groovy:
beans = {
corsFilter(CorsFilter)
}