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());
}
④ 测试邮箱**

先把**码后面添加一些字符,测一个不存在的**码:
08_实现用户邮箱**
再使用正确的**码**测试:

08_实现用户邮箱**