springboot整合freemarker模板引擎后在页面获取basePath绝对路径

在项目中引用静态资源文件或者进行ajax请求时我们有时候会使用 ${basePath} ,其实这就是一种获取绝对路径的方式:
在这里插入图片描述
在这里插入图片描述
那么在springboot项目中要怎么配置才能使用 basePaht呢?

第一步:自定义拦截器(实现 HandlerInterceptor

在这里插入图片描述
代码:

package com.slm.tools.project.config;

import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * @author: create by slm
 * @version: v1.0
 * @description: com.slm.tools.project.config
 * @date:2019/4/9
 */
public class PathInterceptor implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o) throws Exception {
        String path = httpServletRequest.getContextPath();
        String scheme = httpServletRequest.getScheme();
        String serverName = httpServletRequest.getServerName();
        int port = httpServletRequest.getServerPort();
        String basePath = scheme + "://" + serverName + ":" + port + path;
        httpServletRequest.setAttribute("basePath", basePath);
        return true;
    }

    @Override
    public void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView) throws Exception {

    }

    @Override
    public void afterCompletion(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) throws Exception {

    }
}

第二步:注册第一步中自定义的拦截器

在这里插入图片描述
代码:

package com.slm.tools.project.config;

import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;

/**
 * @author: create by slm
 * @version: v1.0
 * @description: com.slm.tools.project.config
 * @date:2019/4/9
 */
@Configuration
public class PathInterceptorConfig extends WebMvcConfigurerAdapter {
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(new PathInterceptor()).addPathPatterns("/**");
    }
}

到这配置就算完了,接下来到前端测试使用一下

第三步:测试

我这里使用ajax进行测试:

function encrypt() {
        var txt =$("#txt").val();
        $.ajax({
                url:"${basePath}/md5/encrypt",
                dataType:"json",
                data:{
                    txt:txt
                },
                success:function (data) {
                    $("#16MD5").html(data.MD516);
                    $("#16MD5Upper").html(data.MD516Upper);
                    $("#32MD5").html(data.MD532);
                    $("#32MD5Upper").html(data.MD532Upper);
                }
            }
        )
    }

打开页面按F12键观察:
在这里插入图片描述
可以看到我们已经通过${basePaht}获取到了绝对路径。
结束

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值