spring boot 2.0 (4): 차단기 (비 로그 인 차단, 정적 자원 제거)
주: 많은 학생 들 이 정적 자원 이 차단 되 었 다 고 말 합 니 다. 처리 방법: addResource Handlers 에 정적 자원 맵 을 추가 합 니 다. 본 고 는 / static / * * 로 매 핑 한 다음 에 차단기 에 excludePathPatterns 에 / static / * 를 추가 하면 정적 자원 을 놓 을 수 있 습 니 다.
package com.nyfz.util.interceptor;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.util.ResourceUtils;
import org.springframework.web.servlet.config.annotation.DefaultServletHandlerConfigurer;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.ViewControllerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import org.springframework.web.servlet.view.InternalResourceViewResolver;
import org.springframework.web.servlet.view.JstlView;
@Configuration
public class WebConfig implements WebMvcConfigurer {
@Autowired
LoginInterceptor loginInterceptor;
/**
* url
*/
final String[] notLoginInterceptPaths = {"/static/**","/admin/login","/error/**","/login"};
@Override
public void addInterceptors(InterceptorRegistry registry) {
//
//
registry.addInterceptor(loginInterceptor).addPathPatterns("/**")
.excludePathPatterns(notLoginInterceptPaths);
}
@Override
public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) {
configurer.enable();
}
/* @Bean
public InternalResourceViewResolver viewResolver() {
InternalResourceViewResolver resolver = new InternalResourceViewResolver();
resolver.setPrefix("/templates/");
resolver.setSuffix(".html");
resolver.setViewClass(JstlView.class);
return resolver;
}*/
/**
* controller
*/
@Override
public void addViewControllers(ViewControllerRegistry registry) {
registry.addViewController("/login").setViewName("login");
}
/***
* addResourceLocations ,addResoureHandler
*/
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
// TODO Auto-generated method stub
//
registry.addResourceHandler("/static/**").addResourceLocations(ResourceUtils.CLASSPATH_URL_PREFIX+"/static/");
WebMvcConfigurer.super.addResourceHandlers(registry);
}
}
로그 인 차단기: LoginInterceptor
package com.nyfz.util.interceptor;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;
@Configuration
public class LoginInterceptor extends HandlerInterceptorAdapter{
Logger logger = LoggerFactory.getLogger(getClass());
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
logger.info(" LoginInterceptor ==============");
String basePath = request.getContextPath();
String path = request.getRequestURI();
logger.info("basePath:" + basePath);
logger.info("path:" + path);
logger.info("userkey:"+request.getSession().getAttribute("userkey"));
if(request.getSession().getAttribute("userkey") == null){
logger.info(" , ");
response.setHeader("Content-Type", "text/html;charset=UTF-8");
response.sendRedirect(request.getContextPath() + "/login");
return false;
}
logger.info(" , !");
return true;
}
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
thymeleaf로 HTML 페이지를 동적으로 만듭니다 (spring + gradle)지난번에는 에서 화면에 HTML을 표시했습니다. 이번에는 화면을 동적으로 움직여보고 싶기 때문에 입력한 문자를 화면에 표시시키고 싶습니다. 초보자의 비망록이므로 이상한 점 등 있으면 지적 받을 수 있으면 기쁩니다! ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.