5 回答

TA貢獻1878條經驗 獲得超4個贊
Spring security 提供了一種在 http 配置器中配置 CORS 的方法,有一種更簡潔的方法可以將 CORS 過濾器添加到應用程序中 -
@Component
@Order(Ordered.HIGHEST_PRECEDENCE)
public class MyCORSFilterClass implements Filter {
@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");
chain.doFilter(req, res);
}
@Override
public void init(FilterConfig filterConfig) {
}
@Override
public void destroy() {
}
}
以最高優先級對過濾器進行排序可確保 javax.servlet.Filter 的 MyCORSFilterClassimplementation 是鏈中的第一個。

TA貢獻1851條經驗 獲得超5個贊
嘗試在本地方法中放置一個調試點
corsConfigurationSource()
并檢查它是否正在執行。如果它沒有被執行,請調查原因 - 可能通過啟用 Spring 的調試日志和/或重新檢查 Spring 配置。另外,嘗試添加選項
setAllowedMethods
configuration.setAllowedMethods(ImmutableList.of("HEAD", "GET", "POST", "PUT", "DELETE", "PATCH", "OPTIONS"));

TA貢獻1744條經驗 獲得超4個贊
響應403反映授權失敗。您的服務器可能已設置為要求對選項請求進行授權。您必須確保選項配置為發送成功響應(2xx 狀態代碼),以允許瀏覽器發送實際請求。2xx 響應通知瀏覽器服務器處理 CORS 請求。
您的請求在本地有效的原因可能是您在提出請求時已獲得授權。因此,請檢查您的身份驗證以確保其正確。因此,飛行前請求不會發送任何授權標頭,因此您不應該在服務器端進行期望。

TA貢獻1815條經驗 獲得超13個贊
Tomcat 也有自己的 cors 過濾器,如果您在 tomcat 之前使用其他服務器(例如 nodejs、apache 服務器 vs ),也請檢查其 cors 過濾器。
添加回答
舉報