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

  1. 创建src/main/webapp/WEB-INF/jsp目录,目录结构不要改动
  2. 在src/main/resources目录下创建static目录用于存放静态资源,如image目录用于存放图片,js目录用于存放js文件
  3. 创建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就可以看到上面的示例页面了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1.学习内容 JSP技术入门和常用指令 JSP的内置对象&标签介绍 EL表达式&EL的内置对象 2.JSP技术入门...
    WendyVIV阅读 2,172评论 1 18
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,284评论 25 708
  • 本书讲了什么 本书是一本系统全面的UI入门教材,从零开始讲解UI设计的方方面面。是平面设计师、交互设计师、产品经理...
    少穻阅读 1,170评论 0 3
  • 出入平安,酸碱不沾。 器备皿全,保以永年。 回归无恙,菌种寿昌。 杂峰远遁,对照明朗。 故说波若波罗蜜多, 论文能...
    亭亭玉立胡老师阅读 387评论 0 0
  • 想要改变阶级,就必须要付出巨大的代价。如果没有先天的优势,那就必须等价交换,哪怕这个姿势不太优雅,不太道德。 这个...
    MZ小白阅读 258评论 0 0