08_实现用户邮箱**
邮箱**实现
- 过程分析
- 代码实现
1)过程分析
① 邮箱的**点击链接:http://localhost:8080/store/user/active?code=xxx
② 需要在UserServlet中编写一个对/active路径的处理
- 获取**码
- 调用service层完成**
- 页面跳转,请求转发 jsp/msg.jsp
③ UserService中创建active(String code)
- 通过**码获取一个用户(用户有可能为空)
- 若不为空,则修改用户的state,将0改为1
2)代码实现
① 在UserServlet中实现对路径/user/active的处理
在servlet中处理主要有3步
1、获取**码
2、调用service完成**
3、请求转发到msg.jsp
/**
* 用户**
* @param request
* @param response
* @throws IOException
* @throws ServletException
*/
private void active(HttpServletRequest request, HttpServletResponse response) throws Exception{
//1、获取**码
String code=request.getParameter("code");
//2、调用service完成**
User user=userService.active(code);
if(user==null) {
//通过**码没有找到用户
request.setAttribute("msg", "请重新**");
}else {
//添加信息
request.setAttribute("msg", "**成功");
}
//3、页面请求转发到msg.jsp
request.getRequestDispatcher("/jsp/msg.jsp").forward(request, response);
}
② 在UserService中编写用户**方法active
1、通过**码code获取一个用户
2、判断用户是否为空
3、修改用户状态0->1
4、调用dao执行修改
UserService接口:
/**
* 用户**
* @param code
* @return
*/
User active(String code) throws Exception;
UserServiceImpl实现类:
@Override
public User active(String code) throws Exception{
//1、通过code获取一个用户
User user=userDao.getUserByCode(code);
//2、判断用户是否为空null
if(user==null) {
//2.1 用户为空--直接返回null
return null;
}
//3、修改用户状态 0->1
user.setState(1);
userDao.update(user);
return user;
}
③ 实现UserDao
1、根据code**码获取用户
2、修改用户
UserDao接口:
/**
* 根据code**码获取用户
* @param code
* @return
*/
User getUserByCode(String code) throws SQLException ;
/**
* 用户修改
* @param user
*/
void update(User user) throws SQLException ;
UserDaoImpl:
/**
* 通过**码获取一个用户
*/
@Override
public User getUserByCode(String code) throws SQLException {
String sql="select * from `user` where code=? limit 1";
return qr.query(sql, new BeanHandler<User>(User.class),code);
}
/**
* 修改用户信息
*/
@Override
public void update(User user) throws SQLException {
String sql="update `user` set username=?,password=?,name=?,email=?,birthday=?,state=?,code=? where uid=?";
qr.update(sql,user.getUsername(),user.getPassword(),user.getName(),user.getEmail(),user.getBirthday(),user.getState(),null,user.getUid());
}
④ 测试邮箱**
先把**码后面添加一些字符,测一个不存在的**码:
再使用正确的**码**测试: