spring boot实战之使用JSP的示例
前后端分离的架构有其优势,但具体情况具体分析,并不是任何时候使用前后端分离架构都是合适的。我最近就体会到其中的坑,因为部门属性的问题,前端项目占比较低,所以公司前端基本上都是新手,结果就是后端接口完成了一个多月,前端还在加班加点的赶。前后端人员的能力和人数与工作量是匹配的,前后端都能hold住时建议使用前后端分离架构,如果前端能力有限或人员较少,那就最好不要采用,这样才能保证项目进度可控。
spring boot并不建议使用jsp,但是可能有习惯和人员知识面的限制,还是希望使用jsp,则可以根据下面的教程来了解如何在spring boot项目内使用jsp。
1、添加maven依赖
<!-- 添加对jsp视图解析的支持 --> <dependency> <groupid>org.apache.tomcat.embed</groupid> <artifactid>tomcat-embed-jasper</artifactid> <scope>provided</scope> </dependency> <dependency> <groupid>javax.servlet</groupid> <artifactid>jstl</artifactid> </dependency>
2、添加配置
在application.properties内添加以下配置:
spring.mvc.view.prefix=/web-inf/jsp/ spring.mvc.view.suffix=.jsp
3、创建jsp
创建src/main/webapp/web-inf/jsp目录,目录结构不要改动
在src/main/resources目录下创建static目录用于存放静态资源,如image目录用于存放图片,js目录用于存放js文件
创建jsp文件,如test.jsp
<%@ page language="java" contenttype="text/html; charset=utf-8" pageencoding="utf-8"%> <%@ taglib uri="http://java.sun.com/jstl/core_rt" prefix="c"%> <%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix="fmt" %> <%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn" %> <!doctype html public "-//w3c//dtd html 4.01 transitional//en" "http://www.w3.org/tr/html4/loose.dtd"> <html> <head> <meta http-equiv="content-type" content="text/html; charset=utf-8"> <title>test</title> <script type="text/javascript" src="${pagecontext.request.contextpath }/js/jquery.min.js"></script> </head> <body> hello,welcome to you 123!test=[${test }] test2=[${test2 }] <br> ![](${pagecontext.request.contextpath }/image/1.jpg) <c:if test="${1 == 1 }"><br>this is shanghai,china!</c:if> </body> </html>
${pagecontext.request.contextpath }用于获取项目路径,即server.context-path设置的值
访问图片${pagecontext.request.contextpath }/image/1.jpg,也就是src/main/resources/static/image/1.jpg文件,注意直接访问/image/1.jpg即可
加载js路径为${pagecontext.request.contextpath }/js/jquery.min.js,同图片,加载静态资源的方式类似
4、访问jsp
创建controller
@controller public class testcontroller { @requestmapping("/test") public string myjsp(httpservletrequest request,modelmap model){ system.out.println("myjsp"); model.put("test", "test"); request.setattribute("test2", "test2"); return "test"; } }
启动项目后,访问localhost:port/test就可以看到上面的示例页面了。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: 基于多线程并发的常见问题(详解)
下一篇: 全面了解Java中的CAS机制
推荐阅读
-
spring boot实战之使用JSP的示例
-
spring boot的拦截器简单使用示例代码
-
使用Spring Boot+MyBatis框架做查询操作的示例代码
-
Spring Boot实战之发送邮件示例代码
-
Spring Boot实战之发送邮件示例代码
-
EVCache缓存在Spring Boot中的实战示例
-
Spring Boot单元测试中使用mockito框架mock掉整个RedisTemplate的示例
-
Spring Boot单元测试中使用mockito框架mock掉整个RedisTemplate的示例
-
EVCache缓存在Spring Boot中的实战示例
-
spring boot的拦截器简单使用示例代码