本文共 3023 字,大约阅读时间需要 10 分钟。
在前面的博客中,小编主要结合SSH网上商城这个项目,简单的介绍了如何实现邮件发送的这个功能,邮件发送了,接下来就是激活了,为什么呢?现在大多网站都要通过对账号进行激活,然后才能注册成功,这是防止恶性注册的措施,只要在注册账号时所填写的邮箱找到注册网站发来的邮件,并点击激活链接就可以完成激活。在上篇博客中,激活邮件已经发送完毕,接下来要做的就是点击邮箱里面的激活邮件,完成激活实现登录,那么这个功能该如何实现呢?今天这篇博客,小编就主要简单的来介绍一下如何实现用户激活这个功能,希望对有需要的小伙伴有帮助,还请各位大牛多多指教哦`(*∩_∩*)′!
首先第一步,我们在UserAction.java类里面编写一个用户激活的方法,代码如下所示:
/** * 用户激活的方法 * author 丁国华 */ public String active(){ //根据激活码查询用户: User existUser=userService.findByCode(user.getCode()); //判断 if(existUser==null){ //激活码错误 this.addActionMessage("激活失败:激活码错误!"); }else{ //激活成功 //修改用户的状态 existUser.setState(1); existUser.setCode(null); userService.update(existUser); this.addActionMessage("激活成功:请去登录!"); } return "msg"; }接着,第二步,我们来编写UserService.java类中方法,根据激活码查询用户,具体代码如下所示:
package cn.itcast.shop.user.service;import org.springframework.transaction.annotation.Transactional;import cn.itcast.shop.user.dao.UserDao;import cn.itcast.shop.user.vo.User;import cn.itcast.shop.utils.MailUitls;import cn.itcast.shop.utils.UUIDUtils;/** * 用户模块业务层代码 * @author 丁国华 * */@Transactionalpublic class UserService { //注入UserDao private UserDao userDao; public void setUserDao(UserDao userDao){ this.userDao =userDao; } //按用户名查询用户的方法 public User findByUsername (String username){ return userDao.findByUsername(username); } //业务层完成用户注册代码 public void save(User user) { //将数据存入到数据库 user.setState(0); //0代表用户激活 1代表用户已经激活 String code = UUIDUtils.getUUID()+UUIDUtils.getUUID(); user.setCode(code); userDao.save(user); //发送激活邮件 MailUitls.sendMail(user.getEmail(), code); } //业务层根据激活码查询用户 public User findByCode(String code) { return userDao.findByCode(code); } //修改用户的状态的方法 public void update(User existUser) { userDao.update(existUser); }}接着,第三步,我们来编写UserDao.java类中的方法,具体代码如下所示:
package cn.itcast.shop.user.dao;import org.springframework.orm.hibernate3.support.HibernateDaoSupport;import java.util.List;import cn.itcast.shop.user.vo.User;/** * 用户模块持久层代码 * @author 丁国华 * */public class UserDao extends HibernateDaoSupport { //按名次查询是否有该用户 public User findByUsername (String username){ String hql ="from User where username= ?"; List至此,我们的代码部分就已经编写完毕了,我们来看一下运行效果,首先我们来注册一个用户,如下图所示:list=this.getHibernateTemplate().find(hql,username); if(list !=null && list.size() > 0){ return list.get(0); } return null; } //注册用户存入数据库代码实现 public void save(User user) { // TODO Auto-generated method stub this.getHibernateTemplate().save(user); } //根据激活码查询用户 public User findByCode(String code) { String hql = "from User where code =?"; List list=this.getHibernateTemplate().find(hql,code); if(list !=null && list.size() > 0){ return list.get(0); } return null; } //修改用户状态的方法 public void update(User existUser) { this.getHibernateTemplate().update(existUser); } }
点击同意以下协议并注册,出现如下界面:
接着,来看一下小编的邮箱是否收到激活邮件,如下图所示:
点击激活链接,我们来看一下会有怎么样的奇迹nie,如下图所示:
小编寄语:该博文,小编主要简单介绍了如何激活用户,总的来说,实现的思路就是在邮箱客户端中点击激活链接,然后根据传递激活码进行用户查询,如果用户不为空,我们就修改用户的状态;如果用户为空,那就证明激活码被篡改了,SSH网上商城,精彩未完待续~~~~~~