- 浏览: 119504 次
- 性别:
- 来自: 深圳
文章分类
最新评论
/**
* MD5加密
*/
public class Crypt
{
@SuppressWarnings("nls")
private final static String[] hexDigits = {"0", "1", "2", "3", "4", "5",
"6", "7", "8", "9", "a", "b", "c", "d", "e", "f"};
/**
* 把inputString加密
* @param inputString
* @return String
*/
public String generatePassword(String inputString)
{
return encodeByMD5(inputString);
}
/**
* TODO 添加方法注释
* @param password
* @param inputString
* @return boolean
*/
public boolean validatePassword(String password, String inputString)
{
if (password.equals(encodeByMD5(inputString)))
{
return true;
}
else
{
return false;
}
}
/**
* TODO 添加方法注释
* @param originString
* @return String
*/
public static String returnEncodeByMde(String originString)
{
return encodeByMD5(originString);
}
/** 对字符串进行MD5加密 */
private static String encodeByMD5(String originString)
{
if (originString != null)
{
try
{
MessageDigest md = MessageDigest.getInstance("MD5"); //$NON-NLS-1$
//使用指定的字节数组对摘要进行最后更新,然后完成摘要计算
byte[] results = md.digest(originString.getBytes());
//将得到的字节数组变成字符串返回
String resultString = byteArrayToHexString(results);
String pass = resultString.toUpperCase();
return pass;
}
catch (Exception ex)
{
ex.printStackTrace();
}
}
return null;
}
private static String byteArrayToHexString(byte[] b)
{
StringBuffer resultSb = new StringBuffer();
for (int i = 0; i < b.length; i++)
{
resultSb.append(byteToHexString(b[i]));
}
return resultSb.toString();
}
/** 将一个字节转化成十六进制形式的字符串 */
private static String byteToHexString(byte b)
{
int n = b;
if (n < 0)
n = 256 + n;
int d1 = n / 16;
int d2 = n % 16;
return hexDigits[d1] + hexDigits[d2];
}
/**
* 测试
* @param args
*/
@SuppressWarnings("nls")
public static void main(String[] args)
{
String pwd1 = "123";
String pwd2 = "";
Crypt cipher = new Crypt();
System.out.println("未加密的密码:" + pwd1);
//将123加密
pwd2 = cipher.generatePassword(pwd1);
System.out.println("加密后的密码:" + pwd2);
System.out.print("验证密码是否下确:");
if (cipher.validatePassword(pwd2, pwd1))
{
System.out.println("正确");
}
else
{
System.out.println("错误");
}
}
* MD5加密
*/
public class Crypt
{
@SuppressWarnings("nls")
private final static String[] hexDigits = {"0", "1", "2", "3", "4", "5",
"6", "7", "8", "9", "a", "b", "c", "d", "e", "f"};
/**
* 把inputString加密
* @param inputString
* @return String
*/
public String generatePassword(String inputString)
{
return encodeByMD5(inputString);
}
/**
* TODO 添加方法注释
* @param password
* @param inputString
* @return boolean
*/
public boolean validatePassword(String password, String inputString)
{
if (password.equals(encodeByMD5(inputString)))
{
return true;
}
else
{
return false;
}
}
/**
* TODO 添加方法注释
* @param originString
* @return String
*/
public static String returnEncodeByMde(String originString)
{
return encodeByMD5(originString);
}
/** 对字符串进行MD5加密 */
private static String encodeByMD5(String originString)
{
if (originString != null)
{
try
{
MessageDigest md = MessageDigest.getInstance("MD5"); //$NON-NLS-1$
//使用指定的字节数组对摘要进行最后更新,然后完成摘要计算
byte[] results = md.digest(originString.getBytes());
//将得到的字节数组变成字符串返回
String resultString = byteArrayToHexString(results);
String pass = resultString.toUpperCase();
return pass;
}
catch (Exception ex)
{
ex.printStackTrace();
}
}
return null;
}
private static String byteArrayToHexString(byte[] b)
{
StringBuffer resultSb = new StringBuffer();
for (int i = 0; i < b.length; i++)
{
resultSb.append(byteToHexString(b[i]));
}
return resultSb.toString();
}
/** 将一个字节转化成十六进制形式的字符串 */
private static String byteToHexString(byte b)
{
int n = b;
if (n < 0)
n = 256 + n;
int d1 = n / 16;
int d2 = n % 16;
return hexDigits[d1] + hexDigits[d2];
}
/**
* 测试
* @param args
*/
@SuppressWarnings("nls")
public static void main(String[] args)
{
String pwd1 = "123";
String pwd2 = "";
Crypt cipher = new Crypt();
System.out.println("未加密的密码:" + pwd1);
//将123加密
pwd2 = cipher.generatePassword(pwd1);
System.out.println("加密后的密码:" + pwd2);
System.out.print("验证密码是否下确:");
if (cipher.validatePassword(pwd2, pwd1))
{
System.out.println("正确");
}
else
{
System.out.println("错误");
}
}
发表评论
文章已被作者锁定,不允许评论。
-
美邦智能
2013-03-30 14:35 0员工管理(工资,假期,) 客户管理 供应商管理 采购模块 ... -
加密解密
2011-12-03 14:59 875String a = "ABCc"; ... -
例_实_建_创_口_接_过_通
2011-08-17 09:50 513public interface IJieKou { ... -
BASE64编码
2011-08-12 16:59 630将对ABC进行BASE64编码: // 1、首先取ABC对 ... -
流_件_文_java
2011-07-20 14:10 670读取 File file = new File(" ... -
作_操_合_集
2011-07-05 15:09 748//Collections List<String> ... -
BigDecimal
2011-07-02 18:42 895double num1 = 2.36; double num2 ... -
件_文_Properties
2011-06-29 19:26 662Properties properties = new Pro ... -
Eclipse平台BPEL开发
2011-06-25 00:15 740Eclipse平台BPEL开发 -
件_文_缩_压
2011-04-11 19:46 658/****************************** ... -
素_元_组_数_除_删_加_增
2011-04-11 19:44 599private static void delIndexEle ... -
作_操_件_文_Java
2011-04-06 20:39 694/****************************** ... -
式_格_字_数
2011-04-06 20:36 675System.out.println(&quo ... -
用_引_软
2011-04-06 20:28 724/****************************** ... -
过_程_载_加_类
2011-04-06 20:27 6361.编写源代码 2.jdk变异成.class文件 3.类加 ... -
序_排_速_快_现_实_JAVA
2011-02-11 17:21 733JAVA实现一个快速排序? 排序的方法有:插入排序(直接插入排 ... -
器_时_定_java
2011-02-11 17:06 595public class aaa { //java定时执行 ... -
举_枚
2011-01-20 12:22 7621.枚举其实都是隐式的继承自java.lang.Enum。有类 ... -
类_e_l_i_F
2011-01-13 23:17 6141.File类提供了管理文件和目录的方法 delete() ... -
制_机_理_处_常_异
2011-01-13 22:29 7371.异常处理:如何表现异常情况?如何控制处理异常流程? 2. ...
相关推荐
这可能包括了大数运算的实现,如乘法、除法、模逆等,以及RSA算法的关键步骤,如模幂运算和私钥解密公式`c = m^d mod n`的应用。 6. **安全注意事项**:在实际应用中,密钥管理至关重要。私钥必须妥善保管,避免被...
文件名“ras”可能是一个包含了RAS算法源代码的文件,可能包含函数接口、实现细节和测试用例。 对于开发者来说,理解并实现RAS算法不仅需要扎实的数学基础,还需要掌握C++编程技巧,包括大整数运算、模幂运算等。在...
在压缩包"RSA算法源程序(C代码)"中,可能包含了以下文件: - `rsa.h`:头文件,定义了RSA类及其相关函数声明。 - `rsa.cpp`:源代码文件,实现了RSA类的具体功能,如密钥生成、加密和解密。 - `main.cpp`:主程序,...
5. **加密过程**:给定明文m(0<m),加密公式为c=m^e mod n,其中c是密文。 6. **解密过程**:收到密文c后,使用私钥d解密,公式为m=c^d mod n,还原出原始明文m。 在Visual C环境下开发RSA加密程序,你需要包含...
加密过程是将明文m通过指数运算c=m^e mod n得到,解密则是c^d mod n还原为m。 在Linux环境下,C语言实现RSA需要以下步骤: 1. **大数运算库**:由于RSA涉及到大整数的运算,需要使用大数库,如GMP(GNU Multiple ...
它将字母映射到一个更大的字母表上,通过两个整数参数a和b完成,公式为:C = (a * M + b) % p,其中C是密文,M是明文,a和b是密钥,p是字母表的大小。这种加密方法比凯撒变换更复杂,增加了破解的难度,但仍不适用于...
由于e和φ(n)互质,根据欧拉定理,存在一个整数d,使得e*d ≡ 1 mod φ(n),所以解密可以进行:C^d mod n = M。 在VC环境下实现RSA,你需要包含必要的数学库,如大数运算库,来处理大整数的计算。程序可能包含以下...
在第一个GroupBox 中放入3 个TextBox 控件和一个Button 按钮,分别用于输入数字、输入加密数字、显示加 密后的数字和计算加密信息;在第二个GroupBox 中放入一个TextBox 控件和一个Button 按钮,分别用于显示 解密后...
加密时,明文消息m通过^e模n运算得到密文c,解密时,密文c通过^d模n运算得到原文m。 `Barrett.js` 文件可能是一个用于快速模幂运算的库,模幂运算是RSA算法中非常关键的一部分,尤其是对于大数的模幂。Barrett除法...
"RSA加解密及公钥密生成工具"这个文件可能是包含上述功能的Delphi源码文件或者一个简单的GUI应用程序,它提供了一个用户友好的界面,使得用户能够轻松地生成RSA密钥对,并进行加密和解密操作。 通过学习和理解这段...
M-ary系统是一种数字表示法,其中数字由M个可能的符号(通常为0到M-1)组成。在M-ary乘方算法中,我们关注的是在模意义下的指数运算,即给定一个基数b,一个指数e和一个模数m,我们寻找\( b^e \)对m取模的结果。这个...
5. **解密过程**:接收到加密文件后,使用私钥(d, n)对每个密文块进行解密,公式为M = C^d mod n,还原出原始的明文块。 6. **文件重组**:将所有解密后的明文块按原顺序组合,恢复成完整的文件。 在软件实现中,...
5. **解密过程**:将密文c通过私钥d解密回原文m,即m=c^d mod n。 6. **实现流程**:设计一个类结构,包含公钥和私钥的生成、加密和解密方法。确保私钥的安全存储,通常在实际应用中,私钥应当保存在本地,而公钥...
STM32系列是意法半导体公司推出的高性能、低功耗的微控制器,广泛应用于各种嵌入式系统设计。SWD接口是一种比JTAG更为简洁、高效的调试和编程接口,它允许开发者在没有外部仿真器或调试器的情况下对芯片进行编程和...
在m法的传统应用中,计算桩基的受力状态需要确定多个系数,如A、B、C、D等,这些系数各自代表着不同的物理意义,与桩的应力分布和位移情况相关。为了找到一种更为高效、简化的计算方式,学者们提出了一个统一的...
scanf("%d%d", &a, &b); getchar(); // 抵消换行符的干扰 printf("输入str的内容\n"); gets(str); // 注意输入大写字母字符串 printf("明文:%s\n", str); encode(str, a, b, N); // 加密 printf("密文:%s\n...
5. **计算d**:d是e的模φ(n)的逆元,即d*e ≡ 1 mod φ(n)。求逆元可以通过扩展欧几里得算法来完成。d是私钥的一部分,e是公钥的一部分。 6. **构建密钥对**:公钥由(e, n)组成,私钥由(d, n)组成。公钥可以公开,...
压缩包中的"MD5算法源文件"可能包含了实现MD5哈希计算的C++代码。这些源文件可能包含一个或多个函数,用于执行MD5算法的四个步骤:初始化、更新、最终化和输出。MD5算法通常包括以下关键部分: 1. **初始化**:设置...
在这个"rsa.rar_LbBigInt_rsa_rsa delphi"的压缩包中,包含的文件可能是用Delphi实现的RSA算法源代码。LbBigInt可能是一个用于处理大整数的库,这对于RSA算法来说至关重要,因为RSA涉及到大素数的乘积以及大整数的加...
3. **解密**:收到密文\( c \)后,使用私钥\( d \)计算\( m = c^d \mod n \)以恢复原始消息。 #### 三、RSA算法的安全性分析 RSA算法的安全性基于大数分解的困难性,即对于给定的\( n \)找到\( p \)和\( q \)的...