`
throwException
  • 浏览: 4045 次
  • 性别: Icon_minigender_1
  • 来自: 石家庄
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

DES加密解密示例

阅读更多

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编码*/

分享到:
评论

相关推荐

    Java中3DES加密解密示例(封装byte数组16进制互转)

    Java 中的 3DES 加密解密示例(封装 byte 数组和 16 进制字符串互转) 在 Java 中,3DES 加密是一种常用的加密算法,它可以将明文数据转换为密文数据,以保护数据的安全性。在本示例中,我们将展示如何使用 3DES ...

    VC++6.0 DES加密解密示例

    VC++6.0 DES加密解密示例工程,包含两个加密解密类库,实例化后即可使用

    C#DES标准ECB加密解密示例源码

    C#DES标准ECB加密解密示例源码,根据标准的C改的源码,与网上所搜索到的完全不一样,可以支持中文为密钥的加密,也可以支持为中文字符串的加密,如,密钥为:替天行道,明文为:来自替天行道的C#DES标准ECB加密解密...

    des加密解密_Des加密解密_DES加密_

    在给定的“des加密例程”中,可能包含了一个调用动态链接库(DLL)实现DES加密解密的示例代码。DLL是Windows操作系统中的一种共享库,可以被多个程序同时调用,节省内存资源并便于代码复用。这个示例可能涉及以下...

    java和javascript之间的DES加密解密

    Java和JavaScript之间的DES加密解密是信息安全领域中的一个重要话题,主要涉及到数据的保护和通信的安全。DES(Data Encryption Standard)是一种古老的对称加密算法,尽管它在安全性上已不被视为最佳选择,但在某些...

    java php DES 加密解密

    下面是一个PHP的DES加密解密示例: ```php $key = '12345678'; // 8个字符的密钥 $plaintext = "Hello, World!"; // 加密 $cipher = 'des-ede3-cbc'; // 3DES (triple DES) 因为单DES已被认为不够安全 $iv = ...

    VB实现DES加密解密算法,vb加密和解密,VBA

    以下是VB.NET中实现DES加密解密的简单示例代码: ```vbnet Imports System.IO Imports System.Security.Cryptography Public Class DESUtil Public Shared Function Encrypt(PlainText As String, Key As String)...

    DES加密解密VB6.0源代码

    在VB6.0(Visual Basic 6.0)环境中实现DES加密解密是编程中常见的一种需求,主要用于保护敏感数据的安全。下面将详细阐述DES加密解密原理及其在VB6.0中的实现方法。 1. **DES加密原理**: - **初始置换**:将明文...

    pb des 加密 解密 dll 示例

    pb des 加密 解密 dll 示例 运行界面http://hi.csdn.net/attachment/201101/25/0_1295999881op80.gif

    C# DES加密解密

    下面是一个简单的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使用des加密解密示例,适合java语言的所有平台,与.net等平台的加密解密兼容

    DESPlus.zip_DES JAVA_Des加密解密_des

    "DESPlus.java"源代码文件很可能会展示这些步骤的实现,提供了一个完整的DES加密解密示例,有助于学习者理解和掌握Java中如何运用DES算法。通过阅读和运行这个示例,可以加深对加密和解密过程的理解,同时也可以为...

    des加密解密java实现版本

    在`cipher4j-master`这个项目中,可能包含了关于DES加密解密的Java实现,包括完整的类和示例代码,帮助开发者理解和使用DES。你可以下载并研究该项目,进一步了解如何在实际应用中集成DES加密解密功能。

    des加密解密程序(vc)

    在这个"VC下DES加密解密程序"中,我们将会探讨如何在Visual C++环境下实现DES算法。 首先,DES加密算法基于64位的数据块进行操作,但实际有效的密钥长度只有56位,因为有8位用于奇偶校验和设计上的特殊用途。DES...

    des加密解密代码示例

    des加密解密工具类的详细代码demo,现在的网络应用无处不存在着安全隐患,人们在使用的过程中对个人数据的保密性也越来越重视,一个简单的des加解密供大家参考,让你的程序多一层安全保障。

    ASP.NET实现 DES加密解密类

    【ASP.NET实现DES加密解密类】的知识点详解 在ASP.NET中,有时我们需要对敏感数据进行加密处理,以确保其在传输或存储时的安全性。DES(Data Encryption Standard)是一种常用的对称加密算法,适合对小量数据进行...

    带界面的DES加密解密java源码

    在Java中实现DES加密解密,主要涉及以下知识点: 1. **Java Cryptography Architecture (JCA)**: Java提供了一套完整的加密框架JCA,允许开发者使用各种加密算法,包括DES。JCA包含了一些基本的加密接口,如`Cipher...

    DES.rar_Des加密解密_des_des加密解密算法_visual c

    在这个"DES.rar"压缩包中,包含了关于DES加密解密算法的学习资料,这可能包括源代码、教程或者示例项目,供用户了解和实践DES算法。"www.pudn.com.txt"可能是提供下载链接或者介绍的文本文件,而"DES"可能是一个包含...

    DES加密_delphi_加解密_des_

    压缩包中的"DES加密"文件很可能包含了上述功能的实现,例如一个包含DesEncrypt和DesDecrypt函数的单元,或者是一个包含完整示例的项目文件。源码中可能会使用TDCPDES(DCPCrypt库的一部分)或其他类似组件来简化DES...

    3DES加密解密算法

    以下是关于3DES加密解密算法在Java中的实现细节: 首先,为了使用3DES,Java程序需要引入特定的JAR包,这些包通常位于`JAVA_HOME/jre/lib/`目录下,包括`jce.jar`、`US_export_policy.jar`、`local_policy.jar`以及...

Global site tag (gtag.js) - Google Analytics