Springboot整合Thymeleaf模板,配置拦截器拦截静态资源的处理方法,以及无限重定向的处理;HTML链接数据库中图片路径导致图片不显示(这个在最下面)

首先先说一下拦截器

什么是拦截器?
Spring MVC中的拦截器(Interceptor)类似于Servlet中的过滤器(Filter),它主要用于拦截用户请求并作相应的处理。例如通过拦截器可以进行权限验证、记录请求信息的日志、判断用户是否登录等。
要使用Spring MVC中的拦截器,就需要对拦截器类进行定义和配置。通常拦截器类可以通过两种方式来定义。
1.通过实现HandlerInterceptor接口,或继承HandlerInterceptor接口的实现类(如HandlerInterceptorAdapter)来定义。
2.通过实现WebRequestInterceptor接口,或继承WebRequestInterceptor接口的实现类来定义。

附上代码:其中有关于路径的问题,今天踩了好久的坑。

package com.llq.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class IndexController {

	@RequestMapping("/login")
	public String mainIndex() {
		return"user_login.html";
	}
	@RequestMapping("/register")
	public String regist() {
		return"user_register.html";
	}
}

拦截器的配置:

package com.llq.filter;

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

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

/**
 * @author 超级无敌皮皮琦
 * @date 2020/2/27 19:45
 */
@Component
public class LoginInterceptor implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
    //此处判断session会话当中是否存在localUser
        Object obj = request.getSession().getAttribute("localUser");
        if(obj!=null){
            return true;
        }else{
        **//重点:**因为整合了 thymeleaf模板所以此处要写的("/login")
        //这里指的是上述的IndexController 类中的@RequestMapping("/login"),
        //因为整合了thymeleaf,所以不可以写response.sendRedirect("/login.html")之类的等等,
        //否则会出现一直拦截所有资源,虽然可以跳转到login.html,但是会出现无限循环重定向。
            response.sendRedirect("/login");
            return false;
        }
    }
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
    }
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
    }
}

会出现如下情况,虽然重定向至user_login.html但是仍然处于被拦截状态
在这里插入图片描述

注册拦截器

package com.llq.conf;


import com.llq.filter.LoginInterceptor;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

@Configuration
public class WebConfigurer implements WebMvcConfigurer {

    @Autowired
    private LoginInterceptor loginInterceptor;
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        //此处 addPathPatterns()方法指的是拦截的规则
       // ("/**")指的是拦截所有  后续的excludePathPatterns()方法指的是排除的,
       //不触发拦截的请求或者静态资源
        registry.addInterceptor(loginInterceptor).addPathPatterns("/**")
                .excludePathPatterns("/login","/register").excludePathPatterns("/static/**");

    }
    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
    }
}

这里要是excludePathPatterns("/login","/register") 也要写成 与前面 写好的IndexController 类中的一样,不能写xxx.html。

整合thymeleaf静态资源被拦截的处理

如果静态资源被拦截在yml文件或者properties文件中配置如下:
在这里插入图片描述
在yml文件中配置
spring:
mvc:
static-path-pattern: /static/**
或者在properties中配置
spring.mvc.static-path-pattern:/static/**

配置完成后你会发现静态资源还是会被拦截,这时是因为路径映射有问题,因此你还需要在每个html文件下配置的静态文件中链接的文件路径稍作修改:在这里插入图片描述
在这里插入图片描述
在这些文件之前都加上 static/ 就ok。

HTML链接数据库中图片路径导致图片不显示
同时在这再说一个注意的点 就是如果配置了这些东西在做获取数据库中资源的路径的话,让资源显示在HTML中的话,不能获取绝对路径,要获取相对路径
绝对路径:
C:\Users\LLQ\Desktop\Test\llq_graduationdesign\src\main\resources\static\imag\ccfd3bf8-edec-4e96-87a7-c3fdff1c1f4e.ico
相对路径:
static\imag\ccfd3bf8-edec-4e96-87a7-c3fdff1c1f4e.ico
不然虽然HTML的开发者选项能获取值,但是无论如何都不会显示的,应该是因为配置这个的问题吧在这里插入图片描述

如果作者有哪里不对,请大家提出,本人虚心接受,并作出更正
----在java路上越走越远的小白

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值