Dieser Artikel bietet Ihnen eine Einführung in die Methode zur Integration von Springboot2.0 bei gleichzeitiger Unterstützung von JSP+HTML. Er hat einen gewissen Referenzwert hilft.
Erklären Sie. Während der Integration aufgetretene Probleme,
1. Nachdem die pom.xml-Datei gleichzeitig in das Thymeleaf-Rack-Paket und die JSP-Unterstützung eingefügt wurde, springt die Rückgabevorlage von Springboot standardmäßig zu HTML,
Auch wenn dies der Fall ist: Sie haben die Attribute von Thymeleaf nicht konfiguriert
Lösung: Verwenden Sie die Methode getRequestDispatcher, um zur JSP-Seite zu springen, die sowohl HTML als auch JSP unterstützt
request.getRequestDispatcher("/WEB -INF/views /testJsp.jsp").forward(request, Response);
2. Darüber hinaus kann es bei der Verwendung von getRequestDispatcher zum Springen zur HTML-Seite zu Problemen mit dem Empfang von Parametern durch die Thymeleaf-Vorlage kommen.
Lösung 1: HTML gibt die Verwendung der Thymeleaf-Vorlage auf und fordert dann aktiv Schnittstellendaten (AJAX POST usw.) auf der Seite an
Lösung 2: HTML verwendet weiterhin die Thymeleaf-Vorlage. und verwendet die Rückgabevorlage, um zum Sprung zurückzukehren. Gehe zur Seite
代码 UserController.java
Konfigurationsdatei
package com.example.demo.controller; import com.example.demo.service.UserService; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.ResponseBody; import javax.annotation.Resource; import javax.servlet.ServletException; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.io.IOException; import java.util.HashMap; import java.util.List; import java.util.Map; /** * @author chenlin */ @Controller @RequestMapping("/usersDemo") public class UserController { private static Logger log = LoggerFactory.getLogger(UserController.class); @Resource UserService userService; @ResponseBody @RequestMapping(value = "/test", produces = "application/json;charset=UTF-8", method = {RequestMethod.POST, RequestMethod.GET}) public List<Map<String, Object>> test(){ log.info("进入了test方法!"); List<Map<String,Object>> list=userService.userQueryAll(); return list; } @RequestMapping(value = "/testHtml", produces = "application/json;charset=UTF-8", method = {RequestMethod.POST, RequestMethod.GET}) public String testHtml(HttpServletRequest request, HttpServletResponse response){ List<Map<String,Object>> list=userService.userQueryAll(); request.setAttribute("list",list); log.info("进入了testHtml方法!"); return "views/testHtml"; } @RequestMapping(value = "/testJsp", produces = "application/json;charset=UTF-8", method = {RequestMethod.POST, RequestMethod.GET}) public void testJsp( HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { List<Map<String,Object>> list=userService.userQueryAll(); request.setAttribute("list",list); log.info("进入了testJsp方法!"); request.getRequestDispatcher("/WEB-INF/views/testJsp.jsp").forward(request, response); } }
pom.xml
server: port: 8080 tomcat: uri-encoding: UTF-8 servlet: context-path: / spring: dataSource: type: com.alibaba.druid.pool.DruidDataSource url: jdbc:mysql://localhost:3306/db-test?useUnicode=true&characterEncoding=utf8&tinyInt1isBit=false&usessl=false username: root password: 123456 driverClassName: com.mysql.jdbc.Driver mvc: view: #新版本 1.3后可以使用 suffix: .jsp prefix: /WEB-INF/ view: #老版本 1.4后被抛弃 suffix: .jsp prefix: /WEB-INF/ thymeleaf: #清除缓存 cache: false mode: LEGACYHTML5 #非严格模式 prefix: /WEB-INF/ #默认 classpath:/templates/ suffix: .html servlet: content-type: text/html mybatis: mapper-locations: classpath:com/example/demo/mapper/*Mapper.xml #注意:一定要对应mapper映射xml文件的所在路径 type-aliases-package: com.example.demo.model # 注意:对应实体类的路径 configuration: call-setters-on-nulls: true # 解决使用map类型接收查询结果的时候为null的字段会没有的情况
Das oben Gesagte ist erledigt.
Zusätzlich ist eine Java-Code-Konfiguration der Rückgabevorlage beigefügt. Sie können die Priorität der Rückgabevorlage selbstverständlich nur mit getRequestDispatcher umschalten 🎜>
In der Startup-Klasse hinzugefügt, außerdem können die Parameter und der Code der Konfigurationsdatei wiederholt werden, aber der Code hat Vorrang vor der Konfigurationsdatei.<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.0.8.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>com.example</groupId> <artifactId>demo</artifactId> <version>0.0.1-SNAPSHOT</version> <name>demo</name> <description>Demo project for Spring Boot</description> <properties> <java.version>1.8</java.version> <mysql.version>5.1.47</mysql.version> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jdbc</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.0.0</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> <!-- alibaba的druid数据库连接池监控依赖 --> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid-spring-boot-starter</artifactId> <version>1.1.13</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>${mysql.version}</version> </dependency> <!--thymeleaf模版--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId> </dependency> <!--非严格模式下 规避一些html编译错误 --> <dependency> <groupId>net.sourceforge.nekohtml</groupId> <artifactId>nekohtml</artifactId> <version>1.9.22</version> </dependency> <!--tomcat支持--> <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> <scope>provided</scope> </dependency> <!--servlet依赖.--> <dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>4.0.1</version> <scope>provided</scope> </dependency> <!--jsp标签库--> <dependency> <groupId>javax.servlet</groupId> <artifactId>jstl</artifactId> </dependency> </dependencies> <build> <resources> <!--解决mybatis文件不编译问题--> <resource> <directory>src/main/java</directory> <includes> <include>**/*.xml</include> </includes> <filtering>false</filtering> </resource> <resource> <!--解决实体类启动和jar启动web页面会报404的错误--> <directory>src/main/webapp</directory> <targetPath>META-INF/resources</targetPath> <includes> <include>**/**</include> </includes> </resource> </resources> </build> </project>
Das obige ist der detaillierte Inhalt vonEinführung in die Methode zur Integration von Springboot2.0 und gleichzeitiger Unterstützung von JSP + HTML-Sprüngen (mit Code). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!