【Spring练习】Spring+SpringMVC+JdbcTemplate简单练习用户管理

项目地址:小南/Spring-test - 码云 - 开源中国 (gitee.com)

静态资源等素材:https://wwm.lanzout.com/ib4wJ03epzdg

1.环境搭建

  1. 创建maven项目或模块,配置好web项目文件结构

  2. 导入静态资源文件

  3. 导入pom.xml坐标

  4. 创建包结构(controller,service,dao,pojo,utils)

  5. 创建数据库文件(导入数据库脚本)

  6. 创建pojo类

  7. 创建配置文件

2.配置文件

2.1 web.xml

在这里插入图片描述

2.2 Spring-mvc.xml

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-AHwhiDtb-1650292554650)(D:\资源\学习工作\lnnau\typora笔记\笔记图片\clip_image004.gif)]

2.3 applicationContext.xml

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DcL0jBFo-1650292554651)(D:\资源\学习工作\lnnau\typora笔记\笔记图片\clip_image006.gif)]

2.4 jdbc.properties

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-n5kFjrRx-1650292554651)(D:\资源\学习工作\lnnau\typora笔记\笔记图片\clip_image008.gif)]

2.5 pom.xml

<?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> <groupId>org.example</groupId> <artifactId>spring_test</artifactId> <version>1.0-SNAPSHOT</version> <packaging>war</packaging> <properties> <maven.compiler.source>8</maven.compiler.source> <maven.compiler.target>8</maven.compiler.target> </properties> <dependencies> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.32</version> </dependency> <dependency> <groupId>c3p0</groupId> <artifactId>c3p0</artifactId> <version>0.9.1.2</version> </dependency> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>1.1.10</version> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> <scope>test</scope> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>5.0.5.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-test</artifactId> <version>5.0.5.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> <version>5.0.5.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>5.0.5.RELEASE</version> </dependency> <dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>3.0.1</version> <scope>provided</scope> </dependency> <dependency> <groupId>javax.servlet.jsp</groupId> <artifactId>javax.servlet.jsp-api</artifactId> <version>2.2.1</version> <scope>provided</scope> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-core</artifactId> <version>2.9.0</version> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <version>2.9.0</version> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-annotations</artifactId> <version>2.9.0</version> </dependency> <dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.3.1</version> </dependency> <dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> <version>2.3</version> </dependency> <dependency> <groupId>commons-logging</groupId> <artifactId>commons-logging</artifactId> <version>1.2</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> <version>1.7.7</version> </dependency> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.17</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>5.0.5.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-tx</artifactId> <version>5.0.5.RELEASE</version> </dependency> <dependency> <groupId>jstl</groupId> <artifactId>jstl</artifactId> <version>1.2</version> </dependency> </dependencies> <!--导入tomcat插件--> <build> <plugins> <plugin> <groupId>org.apache.tomcat.maven</groupId> <artifactId>tomcat7-maven-plugin</artifactId> <version>2.2</version> </plugin> </plugins> </build> </project>

3.具体操作实现

3.1角色列表的展示

步骤

① 点击角色管理菜单发送请求到服务器端(修改角色管理菜单的url地址)② 创建RoleController和showList()方法③ 创建RoleService和showList()方法④ 创建RoleDao和findAll()方法⑤ 使用JdbcTemplate完成查询操作⑥ 将查询数据存储到Model中⑦ 转发到role-list.jsp页面进行展示

3.2角色添加

① 点击列表页面新建按钮跳转到角色添加页面② 输入角色信息,点击保存按钮,表单数据提交服务器③ 编写RoleController的save()方法④ 编写RoleService的save()方法⑤ 编写RoleDao的save()方法⑥ 使用JdbcTemplate保存Role数据到sys_role⑦ 跳转回角色列表页面

3.3用户列表展示

① 点击用户管理菜单发送请求到服务器端(修改用户管理菜单的url地址)② 创建RoleController和showList()方法③ 创建RoleService和showList()方法④ 创建RoleDao和findAll()方法⑤ 使用JdbcTemplate完成查询操作⑥ 将查询数据存储到Model中⑦ 转发到user-list.jsp页面进行展示

3.4用户添加

① 点击列表页面新建按钮跳转到角色添加页面② 输入角色信息,点击保存按钮,表单数据提交服务器③ 编写RoleController的save()方法④ 编写RoleService的save()方法⑤ 编写RoleDao的save()方法⑥ 使用JdbcTemplate保存Role数据到sys_role⑦ 跳转回角色列表页面

3.5删除用户

① 点击用户列表的删除按钮,发送请求到服务器端② 编写UserController的deleteById()方法③ 编写UserService的deleteById()方法④ 编写UserDao的deleteById()方法⑤ 编写UserDao的deleteRelByUid()方法⑥ 跳回当前用户列表页面

4.用户登录权限控制

1.编写拦截器interceprtor

当用户没有登录的时候,点击后台数据时需要将界面跳转到登录界面

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JNR2BSec-1650292554652)(D:\资源\学习工作\lnnau\typora笔记\笔记图片\clip_image010.gif)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JehhfFMs-1650292554652)(D:\资源\学习工作\lnnau\typora笔记\笔记图片\clip_image012.gif)]

2.业务层controller

对于业务层的转发,用redirect和forward都可以实现

虽然配置了视图解析器前后缀,但是在这里重定向或者转发的时候还是要加上后缀,我认为的原因是,视图解析器里面的前缀是在pages下的页面文件,但这里转发到的文件不是pages文件下的,自然就不能用视图解析器里面的前后缀了,这点可以通过return时的文件是否可以用crtl+b找到测试一下。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-T43B16mg-1650292554653)(D:\资源\学习工作\lnnau\typora笔记\笔记图片\clip_image014.gif)]

3.服务层service

用户输错信息的异常处理

在这里插入图片描述
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-huP8rf9K-1650292554653)(D:\资源\学习工作\lnnau\typora笔记\笔记图片\clip_image016.gif)]

4.持久层dao

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-PWEj7WE7-1650292554654)(D:\资源\学习工作\lnnau\typora笔记\笔记图片\clip_image018.gif)]


__EOF__

本文作者lnnau
本文链接https://www.cnblogs.com/wlunan/p/18538043.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   Lnnau  阅读(10)  评论(0编辑  收藏  举报  
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
历史上的今天:
2022-12-05 Windows下安装hadoop2.7.4
点击右上角即可分享
微信分享提示