1.项目分析
2.数据库分析(对数据表进行分类)
3.项目搭建(考虑是否使用maven或者使用jar包)
通过模板来搭建
3.1导入依赖以及修改web.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0"
metadata-complete="true">
</web-app>
web.xml头文件
3.2创建java以及resources文件
4.配置tomcat
测试项目测试是否能跑起来
4.1导入需要的依赖
<dependencies>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>javax.servlet.jsp-api</artifactId>
<version>2.3.3</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.47</version>
</dependency>
</dependencies>
<!-- JSTL表达式的依赖-->
<dependency>
<groupId>javax.servlet. jsp.jstl</groupId>
<artifactId>jstl-api</artifactId>
<version>1.2</version>
</dependency>
<!-- standard标签库-->
<dependency><groupId>taglibs</groupId>
<artifactId>standard</artifactId>
<version>1.1.2</version>
</dependency>
5.创建项目包结构
6.创建实体类
实体类中的属性要与数据库中的字段一一对应
6.1其中年龄和用户名称为自己定义的字段
简单的对年龄做了一个小运算,用当前的时间 - 出生日期
用户名称和其他表对应,可以做链表查询
这就是ORM映射:表-类映射
7.编写基础公共类
7.1数据库配置文件
7.2编写公共类
7.3编写编码过滤器
7.4web容器注册过滤器
8.导入静态资源
9.登录功能实现
爆红的user和mima都是标签,不爽可以删除
9.1在web容器中设置欢迎页
9.2写连接数据库的接口与实现类
1.从数据库中得到要登陆的用户
2.通过sql把名字查出来
3.查出来的是用户,把它循环出来封装进user里
4.最后在返回这个user
10.业务层接口
连接数据库的dao已经完成,再写一个东西操作dao就行了
这个接口和dao层的接口不同,这个业务层还要判断密码,而dao不用,直接查
10.1实现类
public UserServiceImpl() {
userDao = new UserDaoImpl();
}
用多态的形式把实现类实例化,这一步以后会交给容器来做
然后调用业务层的方法进行登录验证
10.2单元测试
对登录方法进行测试
修改连接数据库的配置文件
11.控制层
前端登录页面通过 name向servlet传达
设定一个工具类用来当存放session的键来用
把登录成功的主页面导进来
完善控制层业务
11.1注册servlet
12.登录功能优化
注销功能:
思路:移除session,返回登录页面
12.1过滤器
用来过滤请求的,阻止直接用路径进入主页面
13.密码修改
for标签选择器和id标签选择器是一样的,就是跳转
blur焦点自动失去,然后经过判断后,再次确认
修改密码确认的代码之输入旧密码、输入新密码、确认新密码
13.1思考功能和架构的流程图
13.2在useDao持久层中添加修改密码的接口
13.3修改密码之业务层
这里就不需要连接数据库的connection参数了
注意:这里修改一下
密码修改只会出现成功或失败,最好不用int。
web容器注册userServlet
怎么把前端的参数传递到servlet中?用session,因为我们把信息存到里面了
实现修改密码的逻辑判断
也可以这样判断
前端隐藏
把代码优化写成方法实现复用
ajax实现旧密码的验证
导入阿里巴巴的json依赖
验证旧密码
正常情况下要写方法取去数据库调用,但也可以从session中取到旧密码
第一步先重session中拿到用户,再重用户中拿到密码
web注册 session过期需求
前端ajax中的方法名和请求的密码到哪去
前端传递密码错误的信息
ajax实现旧密码的验证之万能map,在实际开发中一个对象有上百个属性,我们只要它其中的一两个,就不能全部选出来,这时可以使用map来提取
万能map.对照表,画红线的是值,result是键
ajax实现旧密码的验证之前端ajax请求中用的是json接收,所以我们还要把map的键值对转成json,首先设置他的格式为json,其次把它只作为流的形式传过去,还要用到工具类把结果转成json
把刚才的流刷新以及关闭
-
用户管理
用户管理实现,先查取用户列表
下拉框中有角色表的内容,所以再查取角色列表
还需要查询用户的总数以及分页
用户管理实现,流程图
分页公共类
分页公共类之有了这些页面就被导出来了
分页公共类之oop的意思就是封装、继承、多态,而封装(属性私有,get和set,在set中限定一些不安全的情况,如把年龄设定在一定范围内才可以封装)
导入用户列表页面
导入用户列表页面之蓝色区域是表单的哪一部分
导入用户列表页面之蓝色区域是这一部分
用户表,表里的数据都从userList里取
分页相关
拷贝静态页面
查询总数的方法,它的返回值有哪些,要想知道返回什么就看界面需要什么