发送激活码确认

转 自:
[url]http://qingfeng825.iteye.com/blog/373448[/url]

一、需求

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

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



二、思路

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

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

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

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



Java代码
if(searchMemberBySign(sign)==null) {

message="无效激活码"

return;

} else{

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

message="已经激活";return;

}else{

激活步骤一;

激活步骤二;

激活步骤三;

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

}

}

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

Java代码
String str = "abc";
DigestUtils.md5Hex(str);

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



2.SHA1

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

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

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

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


可逆算法

常规加密解密算法:BASE64

Java代码
//加密

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));

//加密

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 包封装的部分,非常简单。直接写代码:





Java代码
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";

}

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";

}
注释写得很清楚了,就不用细解释了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值