欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java最簡(jiǎn)單的DES加密算法實(shí)現(xiàn)案例

 更新時(shí)間:2017年06月12日 08:57:26   投稿:jingxian  
下面小編就為大家?guī)?lái)一篇Java最簡(jiǎn)單的DES加密算法實(shí)現(xiàn)案例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

Base64.java

package com.mstf.des;
 
import java.io.UnsupportedEncodingException;
 
/**
 * base64編碼/解碼
 * @author ceet
 *
 */
public class Base64 {
 
  public static String encode(String data) {
    return new String(encode(data.getBytes()));
  }
 
  public static String decode(String data) {
    try {
      return new String(decode(data.toCharArray()),"utf-8");
    } catch (UnsupportedEncodingException e) {
      e.printStackTrace();
      return null;
    } 
  }
 
  private static char[] alphabet = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/="
      .toCharArray();
 
  private static byte[] codes = new byte[256];
 
  static {
    for (int i = 0; i < 256; i++) {
      codes[i] = -1;
    }
    for (int i = 'A'; i <= 'Z'; i++) {
      codes[i] = (byte) (i - 'A');
    }
 
    for (int i = 'a'; i <= 'z'; i++) {
      codes[i] = (byte) (26 + i - 'a');
    }
    for (int i = '0'; i <= '9'; i++) {
      codes[i] = (byte) (52 + i - '0');
    }
    codes['+'] = 62;
    codes['/'] = 63;
  }
 
  public static char[] encode(byte[] data) {
    char[] out = new char[((data.length + 2) / 3) * 4];
    for (int i = 0, index = 0; i < data.length; i += 3, index += 4) {
      boolean quad = false;
      boolean trip = false;
 
      int val = (0xFF & (int) data[i]);
      val <<= 8;
      if ((i + 1) < data.length) {
        val |= (0xFF & (int) data[i + 1]);
        trip = true;
      }
      val <<= 8;
      if ((i + 2) < data.length) {
        val |= (0xFF & (int) data[i + 2]);
        quad = true;
      }
      out[index + 3] = alphabet[(quad ? (val & 0x3F) : 64)];
      val >>= 6;
      out[index + 2] = alphabet[(trip ? (val & 0x3F) : 64)];
      val >>= 6;
      out[index + 1] = alphabet[val & 0x3F];
      val >>= 6;
      out[index + 0] = alphabet[val & 0x3F];
    }
    return out;
  }
 
  public static byte[] decode(char[] data) {
    int tempLen = data.length;
    for (int ix = 0; ix < data.length; ix++) {
      if ((data[ix] > 255) || codes[data[ix]] < 0) {
        --tempLen;
      }
    }
    int len = (tempLen / 4) * 3;
    if ((tempLen % 4) == 3) {
      len += 2;
    }
    if ((tempLen % 4) == 2) {
      len += 1;
 
    }
    byte[] out = new byte[len];
 
    int shift = 0;
    int accum = 0;
    int index = 0;
 
    for (int ix = 0; ix < data.length; ix++) {
      int value = (data[ix] > 255) ? -1 : codes[data[ix]];
 
      if (value >= 0) {
        accum <<= 6;
        shift += 6;
        accum |= value;
        if (shift >= 8) {
          shift -= 8;
          out[index++] = (byte) ((accum >> shift) & 0xff);
        }
      }
    }
 
    if (index != out.length) {
      throw new Error("Miscalculated data length (wrote " + index
          + " instead of " + out.length + ")");
    }
 
    return out;
  }
}

DESUtil.java

package com.mstf.des;
 
import java.security.Key;
import java.security.SecureRandom;
 
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
 
/**
 * DES對(duì)稱算法(加密/解密)
 *
 * @author ceet
 *
 */
public class DESUtil {
 
  private Key key;
 
  public DESUtil(String strKey) {
    setKey(strKey);
  }
 
  public void setKey(String strKey) {
    try {
      KeyGenerator generator = KeyGenerator.getInstance("DES");
      generator.init(new SecureRandom(strKey.getBytes())); // 根據(jù)參數(shù)生成key
      this.key = generator.generateKey();
    } catch (Exception e) {
      e.printStackTrace();
    }
  }
 
  public String encrypt(String source) {
    return encrypt(source, "utf-8");
  }
 
  public String decrypt(String encryptedData) {
    return decrypt(encryptedData, "utf-8");
  }
 
  public String encrypt(String source, String charSet) {
    String encrypt = null;
    try {
      byte[] ret = encrypt(source.getBytes(charSet));
      encrypt = new String(Base64.encode(ret));
    } catch (Exception e) {
      e.printStackTrace();
      encrypt = null;
    }
    return encrypt;
  }
 
  public String decrypt(String encryptedData, String charSet) {
    String descryptedData = null;
    try {
      byte[] ret = descrypt(Base64.decode(encryptedData.toCharArray()));
      descryptedData = new String(ret, charSet);
    } catch (Exception e) {
      e.printStackTrace();
      descryptedData = null;
    }
    return descryptedData;
  }
 
  private byte[] encrypt(byte[] primaryData) {
    try {
      Cipher cipher = Cipher.getInstance("DES"); // Cipher對(duì)象實(shí)際完成加密操作
      cipher.init(Cipher.ENCRYPT_MODE, this.key); // 用密鑰初始化Cipher對(duì)象(加密)
 
      return cipher.doFinal(primaryData);
    } catch (Exception e) {
      e.printStackTrace();
      return null;
    }
  }
 
  private byte[] descrypt(byte[] encryptedData) {
    try {
      Cipher cipher = Cipher.getInstance("DES"); // Cipher對(duì)象實(shí)際完成解密操作
      cipher.init(Cipher.DECRYPT_MODE, this.key); // 用密鑰初始化Cipher對(duì)象(解密)
 
      return cipher.doFinal(encryptedData);
    } catch (Exception e) {
      e.printStackTrace();
      return null;
    }
  }
 
  public static void main(String[] args) {
    String code = "ceet";
    DESUtil desUtil = new DESUtil("key");
    String encrypt = desUtil.encrypt(code);
    String decrypt = desUtil.decrypt(encrypt);
    System.out.println("原內(nèi)容:" + code);
    System.out.println("加密:" + encrypt);
    System.out.println("解密:" + decrypt);
  }
}

以上這篇Java最簡(jiǎn)單的DES加密算法實(shí)現(xiàn)案例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 詳解java中if語(yǔ)句和switch的使用

    詳解java中if語(yǔ)句和switch的使用

    這篇文章主要介紹了java中if語(yǔ)句和switch的使用,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-11-11
  • 解決@RequestBody搭配@Data的大坑

    解決@RequestBody搭配@Data的大坑

    這篇文章主要介紹了解決@RequestBody搭配@Data的大坑,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • SpringBoot中的JPA(Java?Persistence?API)詳解

    SpringBoot中的JPA(Java?Persistence?API)詳解

    這篇文章主要介紹了SpringBoot中的JPA(Java?Persistence?API)詳解,JPA用于將?Java?對(duì)象映射到關(guān)系型數(shù)據(jù)庫(kù)中,它提供了一種面向?qū)ο蟮姆绞絹?lái)操作數(shù)據(jù)庫(kù),使得開發(fā)者可以更加方便地進(jìn)行數(shù)據(jù)持久化操作,需要的朋友可以參考下
    2023-07-07
  • 簡(jiǎn)單談?wù)刯ava中匿名內(nèi)部類構(gòu)造函數(shù)

    簡(jiǎn)單談?wù)刯ava中匿名內(nèi)部類構(gòu)造函數(shù)

    這篇文章主要簡(jiǎn)單給我們介紹了java中匿名內(nèi)部類構(gòu)造函數(shù),并附上了簡(jiǎn)單的示例,有需要的小伙伴可以參考下。
    2015-11-11
  • Java利用沙箱支付實(shí)現(xiàn)電腦掃碼支付教程

    Java利用沙箱支付實(shí)現(xiàn)電腦掃碼支付教程

    當(dāng)我們制作的項(xiàng)目需要實(shí)現(xiàn)電腦掃碼支付功能時(shí),我們往往會(huì)采用沙箱支付來(lái)模擬實(shí)現(xiàn)。本文將主要介紹如何在Java中利用沙箱支付實(shí)現(xiàn)這一功能,需要的可以參考一下
    2022-01-01
  • Java數(shù)據(jù)結(jié)構(gòu)之單鏈表的實(shí)現(xiàn)與面試題匯總

    Java數(shù)據(jù)結(jié)構(gòu)之單鏈表的實(shí)現(xiàn)與面試題匯總

    由于順序表的插入刪除操作需要移動(dòng)大量的元素,影響了運(yùn)行效率,因此引入了線性表的鏈?zhǔn)酱鎯?chǔ)——單鏈表。本文為大家介紹了單鏈表的實(shí)現(xiàn)與面試題匯總,感興趣的可以了解一下
    2022-10-10
  • Spring AOP詳解面向切面編程思想

    Spring AOP詳解面向切面編程思想

    Spring是一個(gè)廣泛應(yīng)用的框架,SpringAOP則是Spring提供的一個(gè)標(biāo)準(zhǔn)易用的aop框架,依托Spring的IOC容器,提供了極強(qiáng)的AOP擴(kuò)展增強(qiáng)能力,對(duì)項(xiàng)目開發(fā)提供了極大地便利
    2022-06-06
  • Java線程等待用法實(shí)例分析

    Java線程等待用法實(shí)例分析

    這篇文章主要介紹了Java線程等待用法,結(jié)合實(shí)例形式分析了obj.wait()實(shí)現(xiàn)線程等待相關(guān)原理與操作技巧,需要的朋友可以參考下
    2018-09-09
  • JVM之內(nèi)存分配和回收機(jī)制

    JVM之內(nèi)存分配和回收機(jī)制

    本篇主要介紹JVM內(nèi)存分配和回收策略,內(nèi)容主要節(jié)選自《深入理解java虛擬機(jī)》,需要的朋友可以參考下
    2023-05-05
  • 詳解Springboot之接收json字符串的兩種方式

    詳解Springboot之接收json字符串的兩種方式

    這篇文章主要介紹了Springboot之接收json字符串的兩種方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09

最新評(píng)論