Spring framework/Spring boot

스프링부트에서 모바일에 따른 뷰 페이지(Springboot mobile view)

마샤와 곰 2022. 10. 12. 11:04

 

스프링부트에서 사용자가 접속한 브라우저를 확인하여 개발한 웹 페이지를 구분하는 기능을 제작하고 있었습니다.

일반 브라우저면 a.html을 보여주고, 모바일이면 b.html을 보여주는 기능이였습니다.

 

그래서, 어떠한 라이브러리를 쓸지 구글링을 좀 했는데...

2가지 정도 무언가 좋아보이는 라이브러리를 찾았습니다.

- 1번 : spring-mobile-device
- 2번 : spring-mobile-starter

 

메이븐(maven) 저장소에 가서 해당 스펙을 좀 확인하려했는데..

spring-mobile-starter 취약점..
spring-mobile-device 취약점...

 

2022년 10월 12일 기준으로 2개의 라이브러리 전부 취약점(CVE)이 떡하니 등록되어 있었습니다..

특히 spring-mobile-starter는 정말 쓰면 안될거 같습니다...CVE 코드가 200개가 넘었으니 이건...

아직 개선버전이 나오지 않는 것 으로 보아하니 어떠한 방식으로 구현할까 하다 결국에는 AOP로 결정 하였습니다.

일반적으로 아래처럼 고쳐서 사용하였습니다.


import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;
import javax.servlet.http.HttpServletRequest;
import java.util.Optional;
import org.aspectj.lang.ProceedingJoinPoint;

@Configuration
@Aspect
public class AopWorker {

    @Around("execution(public * 패키지.대상컨트롤러.*(..))")
    public Object browserCheck(ProceedingJoinPoint  point) throws RuntimeException {
        final ServletRequestAttributes attribute = ((ServletRequestAttributes) RequestContextHolder.currentRequestAttributes());
        final HttpServletRequest request = Optional.ofNullable(attribute).map(ServletRequestAttributes::getRequest).orElse(null);    	
        String userAgent = request.getHeader("User-Agent").toUpperCase();
        try {
            Object proceed = point.proceed();
            if(userAgent.contains("ANDROID") || userAgent.contains("TABLET") || userAgent.contains("IPAD") || userAgent.contains("MOBILE") || userAgent.contains("IPHONE")) {
                proceed = "mobile/"+proceed;   ///모바일이면 요기에 붙여 줍니다!!
            }
            return proceed;
        } catch (Throwable e) {
            e.printStackTrace();
        }
        return null;
    }
}

 

표준 http 헤더에는 User-Agent가 존재하므로 모바일, 탭 환경에서 접속하면 일반적으로 위 조건값이 있습니다.

* 이거는 정확하지 않아서 좀더 조사 후 수정하겠습니다! (ANDROID, TABLET, IPAD, MOBILE)

스프링부트에서 리턴하는 뷰 Path에 위 코드처럼 "mobile/" 이라는 뎁스를 붙여주었습니다.

만약 ModelAndView 또는 Model 같은 객체로 되어 있다면 setView 부분을 수정하여 주면 됩니다.

위 AOP가 접근하는 컨트롤러의 샘플 모습 입니다.

대상 컨트롤러는 요렇게 되어있었습니다~

 

사용자가 일반브라우저에서 http://주소/test1로 접속하면 test1에 있는 뷰 페이지를 반환하고,

모바일, 테블릿에서 http://주소/test1로 접속하면 mobile/test1에 있는 뷰 페이지를 반환하게 될 것 입니다.

라이브러리나 프레임워크를 찾지 못해서 조금 아쉽게 끝나버렸지만, 기능구현은 어렵지 않았습니다.

이상으로 스프링부트에서 모바일에 따른 뷰 페이지에 대해서 살펴보았습니다.

틀린점 또는 좋은 의견있으면 언제든 연락주세요! 👻

 

반응형