在前面的博客中,小编主要结合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 <User> 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<User> 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。例如以下图所看到的:
小编寄语:该博文。小编主要简介了怎样激活用户,总的来说,实现的思路就是在邮箱client中点击激活链接,然后依据传递激活码进行用户查询,假设用户不为空,我们就改动用户的状态;假设用户为空,那就证明激活码被篡改了,SSH网上商城,精彩未完待续~~~~~~