• Java中对字符串进行加密和解密


    import java.io.*;
    import javax.crypto.*;
    import javax.crypto.spec.*;
    import java.security.*;
    import java.security.spec.*;
    import com.sun.crypto.provider.SunJCE;
    import java.io.Serializable;

    /**
    * 提供加密算法,可以对输入的字符串进行加密、解密操作
    */
    public class EncryptData
    {
         byte[] encryptKey;
         DESedeKeySpec spec;
         SecretKeyFactory keyFactory;
         SecretKey theKey;
         Cipher cipher;
         IvParameterSpec IvParameters;

         public   EncryptData()
         {
             try
             {
                 // 检测是否有 TripleDES 加密的供应程序
                 // 如无,明确地安装SunJCE 供应程序
                 try{ Cipher c = Cipher.getInstance("DESede"); }
                 catch (Exception e)
                 {
                     System.err.println("Installling SunJCE provider.");
                     Provider sunjce = new com.sun.crypto.provider.SunJCE();
                     Security.addProvider(sunjce);
                 }
                 // 创建一个密钥
                 encryptKey = "This is a test DESede Key".getBytes();

                 // 为上一密钥创建一个指定的 DESSede key
                 spec = new DESedeKeySpec(encryptKey);

                 // 得到 DESSede keys
                 keyFactory = SecretKeyFactory.getInstance("DESede");

                 // 生成一个 DESede 密钥对象
                 theKey = keyFactory.generateSecret(spec);

                 // 创建一个 DESede 密码
                 cipher = Cipher.getInstance("DESede/CBC/PKCS5Padding");

                 // 为 CBC 模式创建一个用于初始化的 vector 对象
                 IvParameters =
                         new IvParameterSpec(new byte[]{12,34,56,78,90,87,65,43} );
             }
             catch (Exception exc)
             {
                 // 记录加密或解密操作错误
             }
         }

         /**
          * 加密算法
          * @param password   等待加密的密码
          * @return           加密以后的密码
          * @throws Exception
          */
         public byte[] encrypt(String password)
         {
             String encrypted_password = null;
             byte[] encrypted_pwd = null;

             try
             {
                 // 以加密模式初始化密钥
                 cipher.init(Cipher.ENCRYPT_MODE,theKey,IvParameters);

                 // 加密前的密码(旧)
                 byte[] plainttext = password.getBytes();

                 // 加密密码
                 encrypted_pwd = cipher.doFinal(plainttext);

                 // 转成字符串,得到加密后的密码(新)
                 encrypted_password = new String(encrypted_pwd);
             }
             catch(Exception ex)
             {
                 // 记录加密错误
             }
             return encrypted_pwd;
         }

         /**
          * 解密算法
          * @param password   加过密的密码
          * @return           解密后的密码
          */
         public String decrypt(byte[] password)
         {
             String decrypted_password = null;
             try
             {
                 // 以解密模式初始化密钥
                 cipher.init(Cipher.DECRYPT_MODE,theKey,IvParameters);

                 // 构造解密前的密码
                 byte[] decryptedPassword = password;

                 // 解密密码
                 byte[] decrypted_pwd = cipher.doFinal(decryptedPassword);
                 // 得到结果
                 decrypted_password = new String(decrypted_pwd);
             }
             catch(Exception ex)
             {
                 // 记录解密错误
             }
             return decrypted_password;
         }
    }
  • 相关阅读:
    Java内存区域
    高并发
    集合框架
    面向对象基础概念
    java synchronized详解
    java使用DOM操作XML
    二、认识Xcode(第一个工程:Hello world)
    菜鸟手下的iOS开发笔记(swift)
    一、iOS开发环境搭建
    一个基于JRTPLIB的轻量级RTSP客户端(myRTSPClient)——实现篇:(十)使用JRTPLIB传输RTP数据
  • 原文地址:https://www.cnblogs.com/interdrp/p/1528739.html
Copyright © 2020-2023  润新知