gpt4 book ai didi

spring - 403禁止Spring Boot Web套接字调用

转载 作者:行者123 更新时间:2023-12-03 18:30:47 26 4
gpt4 key购买 nike

我正在使用Spring Boot 1.3.0.RELEASE。我的代码基于使用Stomp和SocketJS的Spring Boot中的websocket入门指南。

当我从localhost:8080(Spring Server)运行客户端时,它当然可以工作。直到我尝试从其他端口调用它时,我才收到403 Forbidden。我的CorsFilter设置如下。

Getting Started Web Sockets With Spring Boot

我的客户是.... http://localhost:3000

我的Spring Boot Server是... http://localhost:8080

我设置了CorsFilter来访问我的客户端...

CorsFilter

package hello;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;

import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

@Component
public class CorsFilter implements Filter {

private final Logger log = LoggerFactory.getLogger(CorsFilter.class);

public CorsFilter() {
log.info("SimpleCORSFilter init");
}

@Override
public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException {

HttpServletRequest request = (HttpServletRequest) req;
HttpServletResponse response = (HttpServletResponse) res;
String clientOrigin = request.getHeader("origin");
response.addHeader("Access-Control-Allow-Origin", clientOrigin);
response.setHeader("Access-Control-Allow-Methods", "POST, GET, DELETE, PUT");
response.setHeader("Access-Control-Allow-Credentials", "true");
response.setHeader("Access-Control-Max-Age", "3600");
response.setHeader("Access-Control-Allow-Headers",
"Origin, Accept, X-Requested-With, Content-Type, " +
"Access-Control-Request-Method, Access-Control-Request-Headers");

if (request.getMethod().equals("OPTIONS")) {
response.setStatus(HttpServletResponse.SC_OK);
} else {
chain.doFilter(request, response);
}
}

@Override
public void init(FilterConfig filterConfig) {
}

@Override
public void destroy() {
}

}

请求标题
Accept:*/*
Accept-Encoding:gzip, deflate, sdch
Accept-Language:en-US,en;q=0.8
Connection:keep-alive
Host:localhost:8080
Origin:http://localhost:3000
Referer:http://localhost:3000/
User-Agent:Mozilla/5.0 (Macintosh; Intel Mac OS X 10_10_2) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/47.0.2526.73 Safari/537.36

响应标题
Access-Control-Allow-Credentials:true
Access-Control-Allow-Methods:POST, GET, DELETE, PUT
Access-Control-Allow-Origin:http://localhost:3000
Access-Control-Max-Age:3600
Cache-Control:no-store, no-cache, must-revalidate, max-age=0
Content-Length:0
Date:Wed, 02 Dec 2015 13:59:25 GMT
Server:Apache-Coyote/1.1

最佳答案

添加答案,以防其他人遇到此问题。如注释中所建议,您需要使用docs中描述的setAllowedOrigins方法。因此,假设this是您要学习的教程,您最终将获得一个类似于以下内容的配置类:

@Configuration
@EnableWebSocketMessageBroker
public class WebSocketConfig extends AbstractWebSocketMessageBrokerConfigurer {

@Override
public void configureMessageBroker(MessageBrokerRegistry config) {
config.enableSimpleBroker("/your/topic");
config.setApplicationDestinationPrefixes("/yourapp");
}

@Override
public void registerStompEndpoints(StompEndpointRegistry registry) {
registry.addEndpoint("/your/endpoint").setAllowedOrigins("http://localhost:3000").withSockJS();
}

}

这将允许在localhost:3000上运行的stomp客户端订阅 /your/endpoint

关于spring - 403禁止Spring Boot Web套接字调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34044648/

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