JSP-файл Spring Boot 2.1.x найден, но не обработан - PullRequest
1 голос
/ 09 октября 2019

В настоящее время я занимаюсь перемещением небольшого приложения в SpringBoot. У нас есть устаревший код, и я надеюсь, что, подключив целевую страницу к SpringBoot, я смогу разрешить остальным файлы JSP / JS веб-приложения.

В настоящее время я успешно справляюсь с Spring 5 и использую SpringBoot 2.1.8.

Фрагмент POM: Приложение использует значения по умолчанию Tomcat, предоставленные Spring, и извлекло соответствующие JARS / JSTL JARS, чтобы Tomcat мог прочитать

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-activemq</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>ch.qos.logback</groupId>
                    <artifactId>logback-classic</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>ch.qos.logback</groupId>
                    <artifactId>logback-classic</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jdbc</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-tomcat</artifactId>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>org.apache.tomcat.embed</groupId>
            <artifactId>tomcat-embed-jasper</artifactId>
        </dependency>
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>jstl</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-security</artifactId>
        </dependency>

За это DZone Article Я создал небольшой контроллер для управления процессом входа в систему

@Controller
public class LoginController {

    @Resource
    private UserSessionService userSessionService;

    @GetMapping(value = "/")
    public String index() {
        Logger.getLogger(this.getClass().getName()).log(Level.SEVERE, "LoginController: Hit /, returning index.jsp");
        return "index";
    }

    @GetMapping(value = "/login")
    public String login() {
        Logger.getLogger(this.getClass().getName())
              .log(Level.SEVERE, "LoginController: Hit /login, returning login.jsp");
        return "login";
    }

    @GetMapping(value = "/loginFailed")
    public String loginError(Model model) {
        Logger.getLogger(this.getClass().getName()).log(Level.SEVERE, "LoginController: Failed to login");
        model.addAttribute("error", "true");
        return "login";
    }

    @GetMapping(value = "/logout")
    public String logout(SessionStatus session) {
        Logger.getLogger(this.getClass().getName()).log(Level.SEVERE, "LoginController: Logging out");
        SecurityContextHolder.getContext().setAuthentication(null);
        session.setComplete();
        return "redirect:/login";
    }

    @PostMapping(value = "/postLogin")
    public String postLogin(Model model, HttpSession session) {
        Logger.getLogger(this.getClass().getName()).log(Level.SEVERE, "LoginController: postLogin");
        return "redirect:/";
    }

}

login.jsp : устаревший код, измененный для вызова контроллера. Я пытаюсь сделать все возможное, чтобы Spring Security управляла процессом вызова моего AuthenticaionProvider и моей БД (для краткости я только показываю материал критической области, в любом случае страница довольно проста

<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ taglib prefix="security" uri="http://www.springframework.org/security/tags" %>
<c:set var="contextPath" value="${pageContext.request.contextPath}"/>

<!DOCTYPE html>
<html>
    <head>
        <%@page contentType="text/html" pageEncoding="UTF-8" %>
        <link type="text/css" href="${contextPath}/css/login.css" rel="stylesheet"/>
        <link rel="stylesheet" href="${contextPath}/css/font-awesome/css/font-awesome.min.css">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title></title>
    </head>

    <body class="loginBody">
          .
          .
          <div class="formdiv">
              <form name='f' action='doLogin' method='POST'>
                  <div style="width: 215px; margin: 0 auto; ">
                      <label class="loginLabel">Login</label><br>
                      <input type="text" name="username".../>
                      <label class="loginLabel">Password</label><br>
                      <input type="password" size="25" name="password".../><br>
                      <input type="submit" class="header_btn_class" value="Login" id="loginButton" style="..."/>
                    </div>
              </form>
           </div>
        .
        .
    </body>
</html>

index.jsp: устаревший код, обрабатывает основную целевую страницу

<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<c:set var="contextPath" value="${pageContext.request.contextPath}"/>
<%@include file="beforeHtml.jsp" %>

<html>
    <head>
        <%@include file="head.jsp" %>
        <script type="text/javascript" src="${contextPath}/js/home/home.js"></script>
        <title></title>
    </head>

    <body>
        <%@include file="top.jsp" %>


        <h2 style="margin-left: 60px;">Release Notes</h2>
        <div id="changeLog" style=...">
        </div>

        <jsp:include page="../html/Changelog.html"/>
    </body>
</html>

У меня есть файл, который я назвал SecurityConfig , чтобы сообщить SpringBoot об обходецелевая страница «по умолчанию»:

@Configuration
public class SecurityConfig extends WebSecurityConfigurerAdapter {

    @Override
    protected void configure(HttpSecurity http) throws Exception {
        http
                .authorizeRequests().antMatchers("/xxx").hasAnyRole("ADMIN", "USER")
                .and()
                .authorizeRequests().antMatchers("/login", "/resource/**").permitAll()
                .and()
                .formLogin().loginPage("/login").usernameParameter("username").passwordParameter("password").permitAll()
                .loginProcessingUrl("/doLogin")
                .successForwardUrl("/postLogin")
                .failureUrl("/loginFailed")
                .and()
                .logout().logoutUrl("/doLogout").logoutSuccessUrl("/logout").permitAll()
                .and()
                .csrf().disable();
    }

И у меня есть эти поля в моем application.properties файле

server.port=8888
server.servlet.context-path=/xxx
server.tomcat.additional-tld-skip-patterns=*mchange-commons-java*.jar

spring.mvc.view.prefix=/WEB-INF/view/jsp/
spring.mvc.view.suffix=.jsp
spring.mvc.servlet.load-on-startup=1

Все это вместе позволяет мнеВойдите в систему по моему запрошенному URL-адресу localhost:8888/xxx/login просто отлично, и войдите в систему, просматривая журналы. Spring находит мои настройки и регистрируется нормально. Проблема заключается в том, что происходит загрузка целевой страницы, которая представляет собой файл JSP с именем index.jsp. Согласно журналу SpringBoot / Application

Oct 09, 2019 2:44:37 PM org.springframework.core.log.LogFormatUtils traceDebug
FINE: GET "/xxx/login", parameters={}
Oct 09, 2019 2:44:37 PM org.springframework.web.servlet.handler.AbstractHandlerMapping getHandler
FINE: Mapped to public java.lang.String com.rhdjapan.xxx.controllers.LoginController.login()
Oct 09, 2019 2:44:37 PM com.xx.xxx.controllers.LoginController login
SEVERE: LoginController: Hit /login, returning login.jsp
Oct 09, 2019 2:44:37 PM org.springframework.web.servlet.view.ContentNegotiatingViewResolver getBestView
FINE: Selected 'text/html' given [text/html,...]
Oct 09, 2019 2:44:37 PM org.springframework.web.servlet.view.AbstractView render
FINE: View name 'login', model {}
Oct 09, 2019 2:44:37 PM org.springframework.web.servlet.view.InternalResourceView renderMergedOutputModel
FINE: Forwarding to [/WEB-INF/view/jsp/login.jsp]
Oct 09, 2019 2:44:38 PM org.springframework.web.servlet.FrameworkServlet logResult
FINE: Completed 200 OK
Oct 09, 2019 2:44:42 PM com.xx.xxx.services.common.security.service.UserDetailsServiceImpl loadUserByUsername
SEVERE: loadUserByUsername: looking up user [admin]
Oct 09, 2019 2:44:42 PM com.xx.xxx.services.common.security.service.UserDetailsServiceImpl loadUserByUsername
SEVERE: loadUserByUsername: userId found = [1111111]
Oct 09, 2019 2:44:42 PM org.springframework.core.log.LogFormatUtils traceDebug
FINE: "FORWARD" dispatch for POST "/xxx/postLogin", parameters={username:[admin], password:[admin]}
Oct 09, 2019 2:44:42 PM org.springframework.web.servlet.handler.AbstractHandlerMapping getHandler
FINE: Mapped to public java.lang.String com.xx.xxx.controllers.LoginController.postLogin(org.springframework.ui.Model,javax.servlet.http.HttpSession)
Oct 09, 2019 2:44:42 PM com.xx.xxx.controllers.LoginController postLogin
SEVERE: LoginController: postLogin
Oct 09, 2019 2:44:42 PM org.springframework.web.servlet.view.AbstractView render
FINE: View name 'redirect:', model {}
Oct 09, 2019 2:44:42 PM org.springframework.web.servlet.FrameworkServlet logResult
FINE: Exiting from "FORWARD" dispatch, status 302
Oct 09, 2019 2:44:42 PM org.springframework.core.log.LogFormatUtils traceDebug
FINE: GET "/xxx/", parameters={}
Oct 09, 2019 2:44:42 PM org.springframework.web.servlet.handler.AbstractHandlerMapping getHandler
FINE: Mapped to public java.lang.String com.xx.xxx.controllers.LoginController.index()
Oct 09, 2019 2:44:42 PM com.xx.xxx.controllers.LoginController index
SEVERE: LoginController: Hit /, returning index.jsp
Oct 09, 2019 2:44:42 PM org.springframework.web.servlet.view.ContentNegotiatingViewResolver getBestView
FINE: Selected 'text/html' given [text/html, ...]
Oct 09, 2019 2:44:42 PM org.springframework.web.servlet.view.AbstractView render
FINE: View name 'index', model {}
Oct 09, 2019 2:44:42 PM org.springframework.web.servlet.view.InternalResourceView renderMergedOutputModel
FINE: Forwarding to [/WEB-INF/view/jsp/index.jsp]
Oct 09, 2019 2:44:42 PM org.springframework.web.servlet.FrameworkServlet logResult
FINE: Completed 200 OK

Вот в чем проблема: при успешном поиске файла JSP страница не отображается . Мне возвращается пустой HTML-файл, а такжеИспользование веб-отладчика (Chrome) показывает только источник из 15 пустых строк. Я предполагаю, что длина моего index.jsp файла;

Мой вопрос двоякий

  1. В чем может быть причина того, что HTML / JSP не отображается на моем экране?
  2. Если есть исправление, для всех других моих старых JSP-файлов, которые мне нужно переместить для работы под SpringBoot, потребуется ли им всем аналогичная процедура?

Спасибо!

Обновление Ради краткости кто-то спросил о структуре моей созданной WAR, структура такая, когда я запускаю архив

WAR
|____css
|____dashboard_view
|____excel
|____images
|____jquery
|____js
|____jsp
|____META-INF
|____org
|____third-party
|____WEB-INF
|________classes
|________lib
|________view
|____________html
|____________jsp
|_________________index.jsp
|_________________login.jsp

С учетом логина и индексаjsp файлы, которые я предоставил, мне интересно, что-то не работает где-то во время рендеринга?

Ответы [ 2 ]

1 голос
/ 09 октября 2019

Похоже, что сервлету не удалось найти некоторые файлы, о которых идет речь, и, следовательно, он ничего не рендерил, потому что ничего не смог найти

Мне нужно проверитьв дальнейшем. Но после перемещения home.js под WEB-INF/view/js/home за index.jsp я начал получать некоторые следы стека с моей веб-страницы

Exception: org.apache.jasper.JasperException: java.lang.NullPointerException

Stack Trace
org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:516) org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:385) org.apache.jasper.servlet.JspServlet.service(JspServlet.java:329) javax.servlet.http.HttpServlet.service(HttpServlet.java:741) 
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231) 
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) 
org.apache.catalina.core.ApplicationDispatcher.invoke(ApplicationDispatcher.java:712) 
org.apache.catalina.core.ApplicationDispatcher.doInclude(ApplicationDispatcher.java:580) 
org.apache.catalina.core.ApplicationDispatcher.include(ApplicationDispatcher.java:516) 
org.springframework.security.web.header.HeaderWriterFilter$HeaderWriterRequestDispatcher.include(HeaderWriterFilter.java:149) 
org.apache.jasper.runtime.JspRuntimeLibrary.include(JspRuntimeLibrary.java:955) 
org.apache.jsp.WEB_002dINF.view.jsp.index_jsp._jspService(index_jsp.java:150)

И для моего входа в SpringBoot

SEVERE: Servlet.service() for servlet [dispatcherServlet] in context with path [/xxx] threw exception [java.lang.NullPointerException] with root cause
java.lang.NullPointerException
    at java.util.Properties$LineReader.readLine(Properties.java:434)
    at java.util.Properties.load0(Properties.java:353)
    at java.util.Properties.load(Properties.java:341)
    at com.xx.xxx.common.utils.common.GenericPropertiesUtil.loadProperties(GenericPropertiesUtil.java:16)
    at com.xx.xxx.common.utils.common.EnvPropertiesUtil.getEnvironmentProperties(EnvPropertiesUtil.java:43)
    at com.xx.xxx.common.utils.common.EnvPropertiesUtil.getParameterValue(EnvPropertiesUtil.java:23)
    at com.xx.xxx.common.utils.common.EnvPropertiesUtil.getFlagParameterValue(EnvPropertiesUtil.java:37)
    at com.xx.xxx.common.utils.Config.getFlagValue(Config.java:131)
    at com.xx.xxx.common.utils.Config.isProd(Config.java:59)
    at com.xx.xxx.common.utils.IO.debug(IO.java:514)

Кажется, это говорит о том, что сейчас на странице есть активность

Я проверю и снова открою, если потребуется. Я сохраню этот пост на тот случай, если у кого-то возникнет аналогичная проблема

0 голосов
/ 09 октября 2019

Поскольку вы используете для развертывания внешний tomcat, задайте для spring-boot-starter-tomcat значение provided scope . Попробуйте добавить приведенную ниже область видимости в jasper:

    <dependency>
        <groupId>org.apache.tomcat.embed</groupId>
        <artifactId>tomcat-embed-jasper</artifactId>
        <scope>provided</scope>
    </dependency>

Зависимость jasper не включена во встроенный tomcat, но, поскольку развертывание является внешним, у tomcat уже будет это. Таким образом, вы можете пометить его как предоставленный. Jasper-зависимость - это та, которая переносит jsp. Также гарантируется, что используется упаковка war , поскольку JSP не будет работать должным образом с jar в качестве упаковки при весенней загрузке. Read

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...