springboot学习(3)springboot使用jsp完成数据的页面展示
来源:互联网 发布:mac os 壁纸 编辑:程序博客网 时间:2024/05/16 13:53
上一篇文章介绍了使用JdbcTemplate完成对数据库的增删改查,使用了postman工具测试了功能是否实现,这一篇介绍如何调用springboot的后台接口,将数据真正展示出来。这里使用jsp进行页面展示,虽然springboot强烈不推荐使用jsp,而是推荐使用Themeleaf,但是很多人习惯使用jsp(包括我),这里先使用jsp做springboot的入门介绍,也可以更好的理解。
还是继续在第二篇的基础上做,代码稍加修改即可,添加几处依赖,如下:
<dependency> <groupId>org.apache.tomcat.embed</groupId> <artifactId>tomcat-embed-jasper</artifactId> <scope>provided</scope></dependency><dependency> <groupId>javax.servlet</groupId> <artifactId>jstl</artifactId> <scope>runtime</scope> </dependency><dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> </dependency>
全部查询及展示的接口
@RequestMapping("/list")public ModelAndView itemsList() {String sql = "select * from items";List<Map<String, Object>> list = jdbcTemplate.queryForList(sql);ModelAndView mav = new ModelAndView("/WEB-INF/views/items.jsp");mav.addObject("list", list);return mav;}
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%><%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> <!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>springboot学习</title></head><body><c:forEach items="${list}" var="item" varStatus="vs"> <h1>这是标题:${item.title}</h1><p>这是作者:${item.name}</p><a>这是内容:${item.detail}</a></c:forEach></body></html>
接着,实现新增的功能,后台接口如下:
/** * @return * 跳转到新增接界面 */@RequestMapping("/toAdd")public ModelAndView toAdd() {ModelAndView mav = new ModelAndView("/WEB-INF/views/add.jsp");return mav;}/** * 新增数据 * @param items * @return */@RequestMapping("/add")public @ResponseBody boolean addItems(Items items) {String sql = "insert into items (title,name,detail) value (?,?,?)";Object args[] = {items.getTitle(),items.getName(),items.getDetail()}; int temp = jdbcTemplate.update(sql, args); if(temp > 0) {return true;}return false;}
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%><%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> <%String path = request.getContextPath();%><!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>springboot学习</title><script type="text/javascript" src="<%=path%>/js/jquery-1.8.3.js"></script></head><body> <div> <form name="addItems" > <input type="text" name="title"><br> <input type="text" name="name"><br> <input type="text" name="detail"><br> <input type="button" value="提交" onclick="return add()"/> </form> </div></body><script type="text/javascript">function add(){var title = addItems.title.value;var name = addItems.name.value;var detail = addItems.detail.value; $(document).ready(function(){$.post("<%=path%>/items/add",{"title":title,"name":name,"detail":detail},function(data){ if(data == true){ alert("新建成功"); } if(data == false){ alert("新建失败"); } });});}</script></html>
在前台输入标题,姓名及内容点击提交,会提示新建成功,数据成功被写入数据库,对于修改,删除基本和新增代码基本无差别,这里就不啰嗦了。
这里做一个解释:
在使用@RestController注解时,控制器类中的方法无法直接返回jsp页面,视图解析器InternalResourceViewResolver不起作用,返回的内容就是Return 里的内容。
比如:这里需要返回items.jsp页面,return "items.jsp"时他直接将items.jsp作为数据返回。
因为@RestController注解相当于@ResponseBody + @Controller合在一起的作用,所以如果需要返回到指定页面,则需要用 @Controller配合视图解析器InternalResourceViewResolver才行,可以利用ModelAndView返回jsp视图。
ModelAndView mav = new ModelAndView("/WEB-INF/views/items.jsp");
这样配置视图的路径可能有点麻烦,很多时候我们jsp都是放在某个文件夹下的,可以在application.properties中进行统一的配置,如下:
spring.mvc.view.prefix=/WEB-INF/views/spring.mvc.view.suffix=.jsp
这样就可以使用ModelAndView mav = new ModelAndView("items");来代替上面的写法。
- springboot学习(3)springboot使用jsp完成数据的页面展示
- springboot学习(4)springboot使用thymeleaf完成数据的页面展示
- springboot学习(5)springboot使用spring-data-jpa完成数据持久化
- springboot学习(2)springboot使用JdbcTemplate完成对数据库的增删改查
- SPringBoot 中 使用JSP页面
- springBoot 学习记录(四)- 访问jsp页面
- 一步一步学springboot (三)使用jsp页面(视图)
- springboot返回jsp页面
- springboot访问jsp页面
- springboot访问jsp页面
- springboot支持jsp页面
- SpringBoot访问JSP页面的完整代码
- SpringBoot 中使用JSP
- (5)学习SpringBoot 之 jsp
- springboot学习笔记(四)使用querydsl完成条件查询
- springboot学习(7)springboot使用AOP打印日志信息
- user_demo结果展示【springboot mybatis学习与开发(七)】
- 【SpringBoot】2小时学会SpringBoot学习笔记(第4章 Controller的使用)
- 寻迹小车开发日记
- favicon在IE和非IE浏览器上的兼容问题及其解决
- OpenStack-M版(Mitaka)搭建基于(Centos7.2)+++二、Openstack环境准备篇中
- C语言*扫雷实现
- Linux(RaspberryPi)上FTP(vsftpd)服务器的搭建
- springboot学习(3)springboot使用jsp完成数据的页面展示
- 微信小程序-Image 图片实现宽度100%,高度自适应
- 14个你可能不知道的JavaScript调试技巧
- zookeeper自我分析
- 如何将文本框里面的内容保存到txt文件中
- UniCode与非UniCode的区别
- Flume多节点的搭建
- 微信小程序-rpx尺寸介绍
- 无法打开预编译头文件: “Debug\xxx.pch”: No such file or directory