zoukankan      html  css  js  c++  java
  • javamail实现邮箱验证功能

    javamail是基于SMTP协议和POP3协议的邮件发送与接收系统,在用户注册与登陆的过程中,常需要用到邮箱验证功能,下面是基于javamail的一个简单实现

    用户注册后通过servlet得到邮箱地址,并使用方法发送邮件

    //校验用户名
            if(dao.findUserByName(user.getUsername())!=null)
            {
                throw new RuntimeException("用户名已经存在");
            }
            //调用DAO中的方法添加用户
            user.setRole("user");
            user.setState(0);
            user.setActivecode(UUID.randomUUID().toString());
            dao.addUser(user);
            //发送激活邮件
            Properties prop = new Properties();
            prop.setProperty("mail.transport.protocol", "smtp");
            prop.setProperty("mail.smtp.host", "localhost");
            prop.setProperty("mail.smtp.auth", "true");
            prop.setProperty("mail.debug", "true");
            Session session=Session.getInstance(prop);
    
            Message msg=new MimeMessage(session);
            msg.setFrom(new InternetAddress("aa@zj.com"));
            msg.setRecipient(RecipientType.TO, new InternetAddress(user.getEmail()));
            msg.setSubject(user.getUsername()+",来自estore的激活邮件");
            msg.setText(user.getUsername()+"点击如下链接激活用户,如果不能点击请复制到浏览器地址栏访问:localhost/Estore/ActiveServlet?activecode="+user.getActivecode());
    
            Transport trans=session.getTransport();
            trans.connect("aa","123");
            trans.sendMessage(msg, msg.getAllRecipients());
    
            //conn.commit();
            }catch(Exception e)
            {
    
                e.printStackTrace();
                throw new RuntimeException(e);
    
            }
    
        }

    链接地址代码

    public void doGet(HttpServletRequest request, HttpServletResponse response)
                throws ServletException, IOException {
            UserService service=BasicFactory.getFactory().getService(UserService.class); 
                 //激活用户
            //获取激活码
            String activecode=request.getParameter("activecode");
            //调用Service中的方法激活
            User user=service.active(activecode);
            //激活成功后登陆用户
            request.getSession().setAttribute("user", user);
            //激活成功后3秒回主页
            response.getWriter().write("激活成功,3秒回主页");
            response.setHeader("Refresh", "3;url=index.jsp");
    
        }

    与数据库中的激活码进行验证

    public User active(String activecode) {
            // TODO 自动生成的方法存根
            User findU=new User();
            findU.setActivecode(activecode);
            User user=dao.findUserByActivecode(activecode);
            if(user==null)
            {
                throw new RuntimeException("激活码不存在,请检查您的激活码");
            }
            //如果用户已经激活过,不能重复激活
            if(user.getState()!=0)
            {
                throw new RuntimeException("用户已经激活,不要重复激活,请直接登陆");
            }
            //用户没有激活,但激活码已经激活
            if(System.currentTimeMillis() - user.getUpdatetime().getTime()>1000*3600*24)
            {
                dao.delete(user.getId());
                throw new RuntimeException("激活码超时,此用户作废,请重新注册");
    
            }
            dao.updateState(user.getId());
            user.setState(1);
            return user;
            }

    完成

  • 相关阅读:
    笔记:数据绑定表达式(二)
    .NET程序员应该知道些什么
    类似tom网站给系统换肤的实现方法。
    终于搞懂js中cookie的一些处理方法。
    .net页面生命周期
    巧妙的参数传递。
    ASP.NET 网站路径
    资料网站
    利用JS从父页面给IFRAME的子页面调用CSS样式文件。
    异常详细信息: System.ArgumentException: 该行已经属于此表。
  • 原文地址:https://www.cnblogs.com/jjx2013/p/6223740.html
Copyright © 2011-2022 走看看