搭建 springboot 项目,web页面用 jsp 模板
我把自己遇到的问题和解决方法罗列了一下,看看你们会不会也遇到这些问题
一、IDEA 创建 springboot 项目
二、创建 jsp 视图
三、创建控制器 controller
四、启动springboot 项目
一、IDEA 创建 springboot 项目
step1:打开IDEA,new 一个 project
data:image/s3,"s3://crabby-images/3974c/3974cdda8a726fdb50e48cc1c8112e8a56842f71" alt=""
step2:选择 Spring Initializr ,设置 jdk(本机先安装java jdk)
data:image/s3,"s3://crabby-images/a1c43/a1c43a88ab3c8813c8dec92649beb6d57358919c" alt=""
step3:设置项目 Group 和 Artifact,选择 Packaging 打包方式
Group 和 Artifact 被称为“坐标”,为了保证项目唯一性
Group分为多个段,一般可设成两段,第一段为域,例如org、com、cn,org为非营利组织,com为商业组织;第二段为公司名称
Artifact 为项目名称
data:image/s3,"s3://crabby-images/2f8c6/2f8c6458e33cd4a483cc41509c879cb7804667e8" alt=""
step4:选择 Web -> Web , 添加项目web starter
其他的可根据自己的需求选择对应的 starter 进行依赖,或者可后期在pom.xml 中配置
data:image/s3,"s3://crabby-images/c1c2f/c1c2feedc63775db7c02c5c1467d8f40087fdd46" alt=""
step5:点击 next,然后 finish,通过第一步创建出 springboot ,项目目录如下:
data:image/s3,"s3://crabby-images/48701/487014bc3ab9a5a149aed18f35a38c30d10c07ae" alt=""
问题一:在创建 springboot 后,会加载 Maven 的 jar 包,如果没有更换成本地安装的的 Maven 仓库,会加载很慢
解决方法:配置本地 maven 仓库(提前在本地安装好Maven,可参考本人整理的maven安装过程:https://www.jianshu.com/p/123892b1661d)
1)点击菜单栏 File -> Settings ,搜索 maven
2)修改 Maven home directory :为已安装的 Maven 的路径
3)修改 User setting file:选择 Maven 安装目录下的 \ conf \ settings.xml, Local repository 会自动加载
data:image/s3,"s3://crabby-images/581ba/581baee77ba95a4d7d2e5dcb01e29d0a1bd993fb" alt=""
二、创建 jsp 视图
问题二:刚开始在 templates目录下想要创建 jsp 文件,想要 new 一个 jsp ,但一直找不到 jsp 模板,原来 springboot 默认不推荐使用 jsp文件作为视图!
解决方法:引入 jsp 依赖包,创建 webapp 目录来进行创建 jsp 文件
step6: 在 main 下 新增 webapp 目录、WEB-INF 目录、 jsp 目录, 创建 jsp 文件
在 main 下新增 webapp 目录, 在 webapp 目录下新增 WEB-INF 目录和 jsp 目录,则将 jsp 文件创建在 jsp 目录下
右击 jsp 目录 -> new -> JSP/JSPX page 创建 jsp 文件,例如本文创建 index.jsp
data:image/s3,"s3://crabby-images/d5023/d50239a73f1e54f42c97f710da64ce7d45fa9f3c" alt=""
step7:在 WEB_INF 目录下新增 web.xml
首先,右击 项目 -> Open Module Settings
data:image/s3,"s3://crabby-images/8ad80/8ad80920aa12fe716522531499cf8b08d76f0be0" alt=""
选择Modules -> 选择Web -> 点击 + 号 -> 点击 web.xml
data:image/s3,"s3://crabby-images/475a7/475a73f0018101121a621a9e31cf8c298d4f02be" alt=""
选择 main\webapp\WEB-INF 目录,在后面添加上 web.xml,点击ok
data:image/s3,"s3://crabby-images/6ca3a/6ca3adc5f3814efc83439ec43146cbad6ac35af8" alt=""
web.xml 内容如下:
data:image/s3,"s3://crabby-images/80c23/80c23abf8148992936ebc11508bd4c836235752e" alt=""
data:image/s3,"s3://crabby-images/f2dbb/f2dbb54f410ca7763f213bf3f5843eca515ca647" alt=""
问题三:在根据其他人创建 webapp目录教程中,都把 jsp目录放在 WEB-INF目录下,结果我运行的时候一直报错
解决方法:将 jsp 文件夹放在 webapp 目录下,与 WEB-INF 目录平级,运行成功
data:image/s3,"s3://crabby-images/d02dd/d02dd1f5263cf87a63b384bb89589804b4ea43a1" alt=""
step8:在 pom.xml 文件中新增 JSP 和 JSTL 的 Maven 依赖配置
添加 org.apache.tomcat.embed 的 tomcat-embed-jasper 依赖包和 javax.servlet 的 jstl 依赖包
data:image/s3,"s3://crabby-images/af1f9/af1f951b2c53a26d84616228d75e04018d96040e" alt=""
问题四:添加以上两个依赖包,发现引入报错,说没有找到
解决方法:项目中还没有加载这两个依赖包,所以需要重新 import maven
1)点击菜单栏 View -> 选择 Tool Window -> 选择 Maven Project
2)点击 刷新图标,reimport maven
data:image/s3,"s3://crabby-images/5602b/5602bed772a80c1a1c94cc46c167af45a681c4b2" alt=""
step9:在 application.properties 文件中定义视图前后缀
配置tomcat端口(默认值为8080),可以选择不配置
spring.mvc.view.prefix 和 spring.mvc.view.suffix 是 Spring Boot 约定的视图前缀和后缀的配置,意思是找到 /jsp/ 目录下以 .jsp 为后缀的 JSP 文件
data:image/s3,"s3://crabby-images/20e00/20e005f6480619f82fe924b67361039069544abe" alt=""
三、创建控制器 controller
step10:在 main / java / com.spring.demo 目录下,创建 controller 类
右击 com.spring.demo 目录 -> new -> 选择 pakage,新增 controller 包
右击 controller 目录 -> new -> 选择 Java Class,创建 Controller 类 ,本人创建为 IndexController 类
引入注解 @Controller 和 @RequestMapping,返回 jsp 页面
data:image/s3,"s3://crabby-images/71b84/71b84611c6394f213caeb59f6b1279500baa7937" alt=""
问题五: @Controller 和 @ RestController 的区别
@Controller:表明该类内的所有方法默认返回页面路径,加 @ResponseBody的方法可返回数据
@ RestController :是 @ResponseBody 和 @Controller 的组合注解,返回 json 数据,;原先返回 json 数据需要 @ResponseBody 和 @Controller 配合
在本项目demo中,如果使用 @ RestController ,则页面返回的是 index() 函数返回的字符串 index,结果如下图:
data:image/s3,"s3://crabby-images/8dd21/8dd21fc962cb31dd099dd4b73da3572ba41479a8" alt=""
四、启动springboot 项目
step11:运行项目的启动类,启动项目
data:image/s3,"s3://crabby-images/51810/51810663ac14b4058b9049c770b004fee38b6bf5" alt=""
step12:在浏览中输入 http:localhost:8090/index,返回 index.jsp 页面
data:image/s3,"s3://crabby-images/10336/10336643ec2e7974927d6f66d5a572f723a6b7b8" alt=""
springboot 小 demo 搭建完毕 ^_^
网友评论