springboot伪静态urlrewrite

第一步,引入依赖

<dependency>

<groupId>org.tuckey</groupId>

<artifactId>urlrewritefilter</artifactId>

<version>4.0.4</version>

</dependency>

第二步,配置过滤器

@Configuration
public class CustomerFilter {
    @Bean
    public FilterRegistrationBean urlRewrite(){
        UrlRewriteFilter rewriteFilter=new UrlRewriteFilter();
        FilterRegistrationBean registration = new FilterRegistrationBean(rewriteFilter);
        registration.setUrlPatterns(Arrays.asList("/*"));
        Map initParam=new HashMap();
        initParam.put("confPath","urlrewirte.xml");
        initParam.put("infoLevel","INFO");
        registration.setInitParameters(initParam);
        return  registration;
    }
}注意看上面的代码.

registration.setUrlPatterns(Arrays.asList("/*"));
这一行的作用是配置拦截器拦截所有的请求.

Map initParam=new HashMap();
initParam.put("confPath","urlrewirte.xml");
initParam.put("modRewriteConfText","RewriteRule ^/(\\w+)/_([\\w\\d])+\\.html$ /$1.html?param=$2 [F]");
initParam.put("logLevel","DEBUG");
registration.setInitParameters(initParam);上面设置了三个初始化参数.

特别需要注意的是:
confPath的作用是,指定URLRewrite配置文件的位置,默认在WEB-INF下,但是我使用的内嵌式的服务器,所以是没有这个目录的,为了解决这个问题,
我可是翻了不少的地方,直接写配置文件名称,表示该文件在类加载路径下.如果你是maven构建的项目,那就是resource下.
这个也比较好理解的.
但是有一点需要注意的是,如果打的不是war包而是jar包的话,那么指定confPath参数是没有作用的,因为它读取不到你的配置文件.
这时候有两种方式解决这个问题,第一个就是
initParam.put("modRewriteConfText","RewriteRule ^/(\\w+)/_([\\w\\d])+\\.html$ /$1.html?param=$2 [F]");
指定modRewriteConfText参数,后面跟表达式,来指定规则,关于表达式,这里给出介绍戳这儿~
如果指定了modRewriteConfText参数,那么就可以不指定confPath参数了.
第二种方式,可以选择重写UrlRewriteFilter的loadUrlRewriterLocal方法,改变他加载配置文件的方式.
这里值得一提的是,我最初没有考虑到jar包读取配置文件的状况,发到测试环境上之后,用了半天的时间,定位这个问题,也是挺傻的...
到这儿的时候,不妨打个断点看看这个过滤器有没有被加载,然后再进行下面的操作.
其实到这儿,基本的配置就搞定了..虾米?是不是简单的过分了...
这时候只需要搞定最后一步就可以了,就是编写配置文件.
他重写url的方式还是挺多的,但是这儿,我只是需要很简单的地方.

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE urlrewrite PUBLIC "-//tuckey.org//DTD UrlRewrite 3.2//EN"
        "http://tuckey.org/res/dtds/urlrewrite3.2.dtd">
<urlrewrite>
    <rule>
        <!--拦截页面以/_开头的数据,作为转发给前端使用-->
        <from>^/(\w+)/_([\w\d])+\.html$</from>
        <!-- to: 真实的URL -->
        <to type="forward">/$1.html?param=$2</to>
    </rule>
    
</urlrewrite>
这里可以添加多条拦截规则,每一条拦截规则使用rule标签包裹.
这里没有特别需要注意的地方.
如果只是简单的使用的话,记住下面这一点就足够了.
首先,如果你会用正则表达式的话,可以通过正则表达式来处理,如果不会,可以使用通配符.
这里给出的例子是使用正则表达式的方式.
<from>^/(\w+)/_([\w\d])+\.html$</from>
<!-- to: 真实的URL -->
<to type="forward">/$1.html?param=$2</to>
 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值