我正在 spring boot 中开发一个 web 应用程序,我从数据库中检索数据并生成一个 Json 列表并将其发送到一个 url(Rest Web 服务)。然后我使用 getJSON 从 Javascript 中的 get 请求中获取它.
$.getJSON(
'http://localhost:8080/dataurl?i=1',
function(data) {
}
但它适用于嵌入式 tomcat 服务器,不适用于独立的 tomcat 服务器。我得到的错误是
当我在浏览器中访问 url 时,它只返回一个空的 JSON 数组。
为什么它不能在独立的 tomcat 服务器中工作。是否也可以为此添加 oauth2 安全性?感谢任何帮助。
最佳答案
如果你想启用 CORS,你应该创建过滤器。
@Component
public class CorsConfig implements Filter {
private final Logger log = LoggerFactory.getLogger(CorsConfig.class);
public CorsConfig() {
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;
response.setHeader("Access-Control-Allow-Origin", request.getHeader("Origin"));
response.setHeader("Access-Control-Allow-Credentials", "true");
response.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE");
response.setHeader("Access-Control-Max-Age", "3600");
response.setHeader("Access-Control-Allow-Headers", "Content-Type, Accept, X-Requested-With, remember-me, Authorization");
chain.doFilter(req, res);
}
@Override
public void init(FilterConfig filterConfig) {
}
@Override
public void destroy() {
}
}
这将为 CORS 添加必要的 header 。
关于javascript - CORS 不能在独立的 tomcat 中工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41343103/