发送激活码确认

    一、需求

         最近做某项目的用户管理(权限)模块,有一种情况,是管理员从后台导入一批用户到DB中,导入后需要通知用户,已经为他分配了用户名和密码,通过Email发送邮件,并让他激活,激活的过程要更新用户信息,当然,一般激活都有分一、二、三步了,再此不细说,主要是讲一下发送激活码、以及对方从EMAIL中的激的思路。

        数据库中需要接增加的字段“激活码” “激活码是否发送标志” “是否激活标志”

 

    二、思路

   总体来说,有以下几步组成.

   (1)生成激活码,存入库中,可以通过MD5加密生成。

   (2)发送EMAIL 给用户,将激活码发过去。(当然,每个用户的激活码是唯一的)

   (3)用户从EMAIL中点击链接登录action,在action 中通过激活码(sign)来读取用户信息。

 

  if(searchMemberBySign(sign)==null)  {

        message="无效激活码"

       return;

   } else{  

       if(是否已经激活==是){

              message="已经激活";return;

         }else{

               激活步骤一;

               激活步骤二;

                激活步骤三; 

                激活成员则置激活标志为true(防止重复激活)

          }

   }

 

三、技术

 

   MD5加密我是用的apache公司commons系列的codec包,最近超迷apache家的东东,确实很不错,封装了SHA1、MD5、BASE64的加蜜算法,而且特别好用,一句话搞定。

 

使用commons-codec包加密字符串(MD5,SHA1,BASE64)

 commons-codec包可以从apache下载,最新版是1.3

不可逆算法

1.MD5

String str = "abc";
DigestUtils.md5Hex(str);

 

 

2.SHA1

String str = "abc";
DigestUtils.shaHex(str);
附.net生成SHA1的方式,生成内容跟java一致:

String str = "abc";
FormsAuthentication.HashPasswordForStoringInConfigFile(str, "SHA1");
 

 

可逆算法

常规加密解密算法:BASE64

//加密

String str= "abc"; // abc为要加密的字符串
byte[] b = Base64.encodeBase64(str.getBytes(), true);
System.out.println(new String(b));
//解密

String str = "YWJj"; // YWJj为要解密的字符串
byte[] b = Base64.decodeBase64(str.getBytes());
System.out.println(new String(b));

 

 发送EMAIL,我也选用了apache 的commons.mail 包封装的部分,非常简单。直接写代码:

 

 

package com.smartdot.cbice.member.util;

import org.apache.commons.mail.EmailException;
import org.apache.commons.mail.HtmlEmail;
import org.apache.commons.mail.SimpleEmail;

import com.smartdot.cbice.member.bean.MemberBean;

/*@author:duanqf*/
public class MemberUtils {
	public static void sendEmail(MemberBean memberBean, String path)
			throws EmailException {
		HtmlEmail email = new HtmlEmail(); // 发送HTML形式的邮件
		// SimpleEmail email = new SimpleEmail();
		email.setHostName(SMTP);// 邮件服务器
		email.setAuthentication(HOST_MAIL_NAME, HOST_MAIL_PASSWORD);// smtp认证的用户名和密码
		email.addTo(memberBean.getEmail(), memberBean.getMemberName());// 收信者
		email.setFrom(sender, "国际版权交易中心");// 发信者
		email.setSubject("国际版权交易中心激活邮件");// 标题
		email.setCharset("GBK");// 编码格式
		// 邮件内容
		email.setHtmlMsg("你好:<br> 国际版权中心会员激活邮件,请你点击<a href='" 
				+ path
				+ "'>版权交易中心激活</a>进行激活!<br><div align='right'>国际版权交易中心</div> ");
		// email.setMsg("<a href='www.baidu.com'>");// 内容
		email.send();// 发送
	}

	/**
	 * 发送邮件的用户名
	 */
	public static String HOST_MAIL_NAME = "qingfeng_825";

	/**
	 * 发送邮件的密码
	 */
	public static String HOST_MAIL_PASSWORD = "XXXXX";

	/**
	 * 邮件发送协议
	 */
	public static String SMTP = "smtp.163.com";

	/**
	 * 发送人
	 */
	public static String sender = "qingfeng_825@163.com";

}

 注释写得很清楚了,就不用细解释了。

 

最后附上我上面提到的包

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值