【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)]

posted @ 2023-12-05 19:26  Lnnau  阅读(24)  评论(0)    收藏  举报  来源