import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.UnsupportedEncodingException;
import java.security.InvalidKeyException;
import java.security.Key;
import java.security.NoSuchAlgorithmException;
import javax.crypto.BadPaddingException;
import javax.crypto.Cipher;
import javax.crypto.IllegalBlockSizeException;
import javax.crypto.KeyGenerator;
import javax.crypto.NoSuchPaddingException;
import javax.security.auth.kerberos.KerberosKey;
import javax.security.auth.kerberos.KerberosPrincipal;
import com.sun.org.apache.xerces.internal.impl.dv.util.Base64;
public class EncryptData {
// 用于产生指定key的常量定义---开始
private static final String PRINCIPAL_NAME = "abcd@aaa.net";// 产生key的主体名称
private static final String KEY_PASSWORD = "dfddsdfs333";// key的密码
private static final String ALGORITHM_NAME = "DES";// 算法名称
// 用于产生指定的key的常量定义---结束
public static void main(String args[]) {
// String password = "administrator";
String password = "在实际工作中我们常常会遇到对数据进行加密解密的工作(如对密码数据的保护或者对网络传输的数据进行保护),因为数据加密解密需要非常复杂、高效的算法,所以通常对于一般";
try {
String str=encrypt(password);
System.out.println(decrypt(str));
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* DES加密字符串,返回加密后的字符串
*
* @param encryptString
* 要加密的字符串
* @param strings
* 不传此参数按默认生成密钥 参数数组,[0]=加密主体名称,[1]=key的密码
* @return 返回base64转码后的字符串
* @throws InvalidKeyException
* @throws NoSuchAlgorithmException
* @throws NoSuchPaddingException
* @throws UnsupportedEncodingException
* @throws IllegalBlockSizeException
* @throws BadPaddingException
*/
public static String encrypt(String encryptString, String... strings)
throws InvalidKeyException, NoSuchAlgorithmException,
NoSuchPaddingException, UnsupportedEncodingException,
IllegalBlockSizeException, BadPaddingException {
Key key = createKey(strings);
Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");
byte[] by = encryptString.getBytes("utf8");
cipher.init(Cipher.ENCRYPT_MODE, key);// 使用私鈅加密
byte[] cipherText = cipher.doFinal(by);
return Base64.encode(cipherText).replaceAll("\n", "");
}
/**
* DES解密字符串
*
* @param decryptString要解密的字符串
* @param strings生成密鑰的參數
* 不传此参数按默认生成密钥 参数数组,[0]=加密主体名称,[1]=key的密码
* @return
* @throws NoSuchAlgorithmException
* @throws NoSuchPaddingException
* @throws UnsupportedEncodingException
* @throws InvalidKeyException
* @throws IllegalBlockSizeException
* @throws BadPaddingException
*/
public static String decrypt(String decryptString, String... strings)
throws NoSuchAlgorithmException, NoSuchPaddingException,
UnsupportedEncodingException, InvalidKeyException,
IllegalBlockSizeException, BadPaddingException {
Key key = createKey(strings);
Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");
byte[] by = Base64.decode(decryptString);
cipher.init(Cipher.DECRYPT_MODE, key);// 使用私鈅加密
byte[] cipherText = cipher.doFinal(by);
return new String(cipherText, "utf-8");
}
/**
* 创建指定的key,参数数组含义: strings[0]=生成key的主体名称
* strings[1]=key的密码(参考命名格式xxx@xx.xxx其他命名格式参考Java Cryptography Architecture
* API Specification & Reference 中的附录 A) strings[2]=算法名称如果不传参数按默认值
*
* @param strings
* @return
*/
public static Key createKey(String... strings) {
String algorithm = ALGORITHM_NAME;
String name = PRINCIPAL_NAME;
String password = KEY_PASSWORD;
switch (strings.length) {
case 1:
name = strings[0];
break;
case 2:
name = strings[0];
password = strings[1];
break;
case 3:
name = strings[0];
password = strings[1];
algorithm = strings[2];
break;
}
KerberosPrincipal kerberosPrincipal = new KerberosPrincipal(name);
Key key = new KerberosKey(kerberosPrincipal, password.toCharArray(),
algorithm);
return key;
}
/**
* 产生一个随机key,并保存到文件中
*
* @param file
*/
public static void setPriveKey(String file) {
FileOutputStream fos;
try {
fos = new FileOutputStream(file);
KeyGenerator keyGen = KeyGenerator.getInstance("DES");
keyGen.init(56);
Key key = keyGen.generateKey();// 生成私钥Key
ObjectOutputStream oos = new ObjectOutputStream(fos);
oos.writeObject(key);
oos.close();
} catch (Exception e1) {
e1.printStackTrace();
}
}
/**
* 从文件中获取key
*
* @param file
* @return
* @throws Exception
*/
public static Key getPriveKey(String file) throws Exception {
FileInputStream fis = new FileInputStream(file);
ObjectInputStream ois = new ObjectInputStream(fis);
Key key = (Key) ois.readObject();
return key;
}
}
/**加密后的byte不能直接new string否则不能对形成的string解密,需要进行Base64编码*/
分享到:
- 2008-08-09 08:24
- 浏览 1132
- 评论(0)
- 论坛回复 / 浏览 (0 / 4022)
- 查看更多
相关推荐
Java 中的 3DES 加密解密示例(封装 byte 数组和 16 进制字符串互转) 在 Java 中,3DES 加密是一种常用的加密算法,它可以将明文数据转换为密文数据,以保护数据的安全性。在本示例中,我们将展示如何使用 3DES ...
VC++6.0 DES加密解密示例工程,包含两个加密解密类库,实例化后即可使用
C#DES标准ECB加密解密示例源码,根据标准的C改的源码,与网上所搜索到的完全不一样,可以支持中文为密钥的加密,也可以支持为中文字符串的加密,如,密钥为:替天行道,明文为:来自替天行道的C#DES标准ECB加密解密...
在给定的“des加密例程”中,可能包含了一个调用动态链接库(DLL)实现DES加密解密的示例代码。DLL是Windows操作系统中的一种共享库,可以被多个程序同时调用,节省内存资源并便于代码复用。这个示例可能涉及以下...
Java和JavaScript之间的DES加密解密是信息安全领域中的一个重要话题,主要涉及到数据的保护和通信的安全。DES(Data Encryption Standard)是一种古老的对称加密算法,尽管它在安全性上已不被视为最佳选择,但在某些...
下面是一个PHP的DES加密解密示例: ```php $key = '12345678'; // 8个字符的密钥 $plaintext = "Hello, World!"; // 加密 $cipher = 'des-ede3-cbc'; // 3DES (triple DES) 因为单DES已被认为不够安全 $iv = ...
以下是VB.NET中实现DES加密解密的简单示例代码: ```vbnet Imports System.IO Imports System.Security.Cryptography Public Class DESUtil Public Shared Function Encrypt(PlainText As String, Key As String)...
在VB6.0(Visual Basic 6.0)环境中实现DES加密解密是编程中常见的一种需求,主要用于保护敏感数据的安全。下面将详细阐述DES加密解密原理及其在VB6.0中的实现方法。 1. **DES加密原理**: - **初始置换**:将明文...
pb des 加密 解密 dll 示例 运行界面http://hi.csdn.net/attachment/201101/25/0_1295999881op80.gif
下面是一个简单的C# DES加密解密的示例: ```csharp using System; using System.IO; using System.Security.Cryptography; public class DESExample { public static void Main() { byte[] key = Convert....
java使用des加密解密示例,适合java语言的所有平台,与.net等平台的加密解密兼容
"DESPlus.java"源代码文件很可能会展示这些步骤的实现,提供了一个完整的DES加密解密示例,有助于学习者理解和掌握Java中如何运用DES算法。通过阅读和运行这个示例,可以加深对加密和解密过程的理解,同时也可以为...
在`cipher4j-master`这个项目中,可能包含了关于DES加密解密的Java实现,包括完整的类和示例代码,帮助开发者理解和使用DES。你可以下载并研究该项目,进一步了解如何在实际应用中集成DES加密解密功能。
在这个"VC下DES加密解密程序"中,我们将会探讨如何在Visual C++环境下实现DES算法。 首先,DES加密算法基于64位的数据块进行操作,但实际有效的密钥长度只有56位,因为有8位用于奇偶校验和设计上的特殊用途。DES...
des加密解密工具类的详细代码demo,现在的网络应用无处不存在着安全隐患,人们在使用的过程中对个人数据的保密性也越来越重视,一个简单的des加解密供大家参考,让你的程序多一层安全保障。
【ASP.NET实现DES加密解密类】的知识点详解 在ASP.NET中,有时我们需要对敏感数据进行加密处理,以确保其在传输或存储时的安全性。DES(Data Encryption Standard)是一种常用的对称加密算法,适合对小量数据进行...
在Java中实现DES加密解密,主要涉及以下知识点: 1. **Java Cryptography Architecture (JCA)**: Java提供了一套完整的加密框架JCA,允许开发者使用各种加密算法,包括DES。JCA包含了一些基本的加密接口,如`Cipher...
在这个"DES.rar"压缩包中,包含了关于DES加密解密算法的学习资料,这可能包括源代码、教程或者示例项目,供用户了解和实践DES算法。"www.pudn.com.txt"可能是提供下载链接或者介绍的文本文件,而"DES"可能是一个包含...
压缩包中的"DES加密"文件很可能包含了上述功能的实现,例如一个包含DesEncrypt和DesDecrypt函数的单元,或者是一个包含完整示例的项目文件。源码中可能会使用TDCPDES(DCPCrypt库的一部分)或其他类似组件来简化DES...
以下是关于3DES加密解密算法在Java中的实现细节: 首先,为了使用3DES,Java程序需要引入特定的JAR包,这些包通常位于`JAVA_HOME/jre/lib/`目录下,包括`jce.jar`、`US_export_policy.jar`、`local_policy.jar`以及...