zoukankan      html  css  js  c++  java
  • 【项目实战】---用户激活

           在前面的博客中,小编主要结合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 丁国华
     *
     */
    
    @Transactional
    
    public 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网上商城,精彩未完待续~~~~~~

  • 相关阅读:
    [Redis知识体系] 一文全面总结Redis知识体系
    MySQL数据导入到ClickHouse
    docker本地搭建clickhouse
    【linux】修改宝塔默认的PHP CLI版本
    windows 10 安装go环境
    docker安装centos8
    Bootstrap 简洁、直观、强悍的前端开发框架,让web开发更迅速、简单。
    C#调用WebService
    登录时,记住用户的帐号密码
    asp.net,cookie,写cookie,取cookie
  • 原文地址:https://www.cnblogs.com/gavanwanggw/p/7275395.html
Copyright © 2011-2022 走看看