Tomcat Access-Control-Allow-Origin(同源策略)实践

背景描述

使用tomcat配置cdn服务器时,css文件能正常加载,但是加载字体文件时出现了Access-Control-Allow-Origin错误:

已拦截跨源请求:同源策略禁止读取位于 http://localhost:9999/font-awesome/fonts/fontawesome-webfont.woff2?v=4.5.0 的远程资源。(原因:CORS 头缺少 'Access-Control-Allow-Origin')。(未知)
downloadable font: download failed (font-family: "FontAwesome" style:normal weight:normal stretch:normal src index:1): bad URI or cross-site access not allowed source: http://localhost:9999/font-awesome/fonts/fontawesome-webfont.woff2?v=4.5.0

原因是tomcat禁止了跨域请求。关于HTTP访问控制的详细信息可以查看:HTTP访问控制(CORS)

解决方案

war应用

对于标准的war项目包,只需要增加一个filter就能取消Access-Control-Allow-Origin(以下简称CORS)的限制。

首先新建filter类

package com.itxc.filter;

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

public class CORSFilter implements Filter {

    @Override
    public void init(FilterConfig filterConfig) throws ServletException {

    }

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        HttpServletResponse httpResponse = (HttpServletResponse) servletResponse;
        httpResponse.addHeader("Access-Control-Allow-Origin", "*");
        filterChain.doFilter(servletRequest, servletResponse);
    }

    @Override
    public void destroy() {

    }
}

然后在web.xml中使用上述filter即可

<filter>
    <filter-name>CorsFilter</filter-name>
    <filter-class>com.itxc.filter.CORSFilter</filter-class>
</filter>

<filter-mapping>
    <filter-name>CorsFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

参考:tomcat添加跨域访问功能-Access-Control-Allow-Origin:*

内嵌Tomcat(Spring boot)

对于Spring Boot开发的项目,原理一样,只需要为Spring MVC添加一个Filter即可。

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.cors.CorsConfiguration;
import org.springframework.web.cors.UrlBasedCorsConfigurationSource;
import org.springframework.web.filter.CorsFilter;

import javax.servlet.Filter;

@Configuration
public class SpringMvcConfig {

    /**
     * 解决同源策略问题的filter
     * @return
     */
    @Bean
    public Filter corsFilter(){
        UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
        CorsConfiguration config = new CorsConfiguration();
        config.addAllowedOrigin("*");
        config.addAllowedHeader("*");
        config.addAllowedMethod("OPTIONS");
        config.addAllowedMethod("HEAD");
        config.addAllowedMethod("GET");
        config.addAllowedMethod("PUT");
        config.addAllowedMethod("POST");
        config.addAllowedMethod("DELETE");
        config.addAllowedMethod("PATCH");
        source.registerCorsConfiguration("/**", config);
        return new CorsFilter(source);
    }
}

重启Application即可。

扩展阅读:apache和nginx配置

要达到同样的目标,ngnix下可以这样配置:

server {
...
# Fix @font-face cross-domain restriction in Firefox
location ~* \.(ttf|ttc|otf|eot|woff|font.css)$ {
add_header Access-Control-Allow-Origin "http://yoursite.com";  #或* 代表任何域
#add_header Access-Control-Allow-Headers X-Requested-With;
#add_header Access-Control-Allow-Methods GET,POST,OPTIONS;
}
...
}

apache(http.conf文件)配置:

<Directory "C:/htdocs">
    #Require all denied
    Header set Access-Control-Allow-Origin *
</Directory>
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Tomcat Access-Control-Allow-Origin 是一个与跨域资源共享 (Cross-Origin Resource Sharing, CORS) 相关的设置。它用于控制哪些源可以访问 Tomcat 服务器上的资源。 当在一个域名下的网页向另一个域名下的资源发起 AJAX 请求时,浏览器会执行同源策略,即默认情况下是不允许跨域请求的。为了实现跨域请求,服务器需要通过设置响应头中的 Access-Control-Allow-Origin 字段来指定允许的源。 在 Tomcat 中,你可以通过在配置文件或代码中添加以下代码来设置允许的源: ```xml <Valve className="org.apache.catalina.valves.CorsFilter" /> ``` 这将启用 Tomcat 内置的 CorsFilter 过滤器,它会自动添加 Access-Control-Allow-Origin 头部并根据需要进行其他 CORS 相关设置。你也可以使用其他 CORS 过滤器或自定义过滤器来实现类似功能。 另外,还可以通过修改 Tomcat 的 web.xml 文件来手动设置 Access-Control-Allow-Origin 头部。在 `<web-app>` 标签内添加如下内容: ```xml <filter> <filter-name>CorsFilter</filter-name> <filter-class>org.apache.catalina.filters.CorsFilter</filter-class> <init-param> <param-name>cors.allowed.origins</param-name> <param-value>*</param-value> </init-param> </filter> <filter-mapping> <filter-name>CorsFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> ``` 在这个示例中,`<param-value>` 元素的值为 `*` 表示允许任意源进行跨域请求。你也可以将它设置为具体的源,例如 `http://example.com`。 请注意,设置 Access-Control-Allow-Origin 为 `*` 可能会导致安全风险,最好仅允许特定的源进行跨域请求。此外,还可以在服务器端处理 OPTIONS 请求,以便更精细地控制 CORS 设置。 希望这个回答对你有帮助!如果还有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值