java实现置换密码加密解密

本文实例为大家分享了Java实现置换密码加密解密,供大家参考,具体内容如下

思路

置换密码只不过是简单的换位而已,这里写的是一个分组长度为7的置换密码因为所学知识有限,写的比较麻烦,这里先简单介绍一下思路:

1.因为置换密码首先要将其进行分组,这里分组长度为7,不足的位数补0,可以选取二维数组进行操作,定义二维数组,明文有多少个分组二维数组中就有多少个一维数组,其中一维的长度就是分组长度
2.定义一个一维数组key作为加密用的秘钥,一个一维数组trankey作为解密秘钥,这里其中的元素是自己写的
3.输入明文,现将其存入扩容好的新建的一维数组中但此时填充位是空字符'\0',再将其替换为'0',存入二维数组中
4.加密,用秘钥key中的顺序对明文进行加密并存入二维数组miwen中
5.解密,用解密秘钥trankey中的顺序对密文解密存入二维数组arr中
6.消去填充的0,算出填充了多少个0,然后用分组长度减去0的个数就是二维数组中最后一个一维数组中非填充位的个数,将其存入一维数组中,在用此一维数组替换最后一个一维数组,这样就消去了所有的填充的0

代码

import java.util.Scanner;

public class replacement {

  public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);
    System.out.println("请输入带加密的明文:");
    String plaintexts = sc.nextLine();
    int len = plaintexts.length() % 7 == 0 ? plaintexts.length() / 7 : (plaintexts.length() / 7) + 1;//定义二维数组是要用到,主要作用是确定二维数组中一维数组的个数
    char[] plaintext_char = new char[7 * len];//先将明文存入一维数组中,在后面再将其存入二维数组中
    char[][] arr = new char[len][7];//存放明文和解密后的明文的二维数组
    char[][] miwen = new char[len][7];//存放密文的二维数组
    char[] n=new char[7];//在解密过程中用来消掉多余的填充的0
    int[] key = {6, 3, 0, 4, 1, 5, 2};//加密秘钥
    int[] transkey = {2, 4, 6, 1, 3, 5, 0};//解密秘钥

    fill(plaintexts, plaintext_char, len, arr);
    encryption(len, miwen, arr, key);
    System.out.println("加密后的明文是:");
    for (int i = 0; i < len; i++) {
      for (int j = 0; j < miwen[i].length; j++) {
        System.out.print(miwen[i][j]);
      }
    }//输出密文
    System.out.println(" ");
    System.out.println("按下1解密或按其他任意键退出:");
    String a=sc.nextLine();
    if (a.equals("1")){
      decryption(n,len, miwen, arr, transkey,plaintexts);
      for (int i = 0; i < len; i++) {
        for (int j = 0; j < arr[i].length; j++) {
          System.out.print(arr[i][j]);
        }
      }
    }else {
      System.out.println("退出!");
    }//输出明文或退出
  }

  public static void fill(String plaintexts, char[] plaintext_char, int len, char[][] arr) {
    for (int i = 0; i < plaintexts.length(); i++) {
      plaintext_char[i] = plaintexts.charAt(i);
    }//将输入的字符串存入扩充好的一维数组中,此时数组长度已达到标准,但是多出来的填充为是'\0'
    for (int i = 0; i < plaintext_char.length; i++) {
      if (plaintext_char[i] == '\u0000') {
        plaintext_char[i] = '0';
      }//将字符串数组中的空字符'\0'替换为0
  for (int i = 0; i < len; i++) {
      for (int j = i * 7, k = 0; j < 7 * (i + 1) && k < 7; j++, k++) {
        arr[i][k] = plaintext_char[j];
      }
    }//将扩充后的明文存入二维数组中,每七个一个一维数组
  }

  public static void encryption(int len, char[][] miwen, char[][] arr, int[] key) {
    for (int i = 0; i < len; i++) {
      for (int j = 0; j < 7; j++) {
        miwen[i][j] = arr[i][key[j]];
      }
    }
  }//加密方法
  public static void decryption(char[] n,int len, char[][] miwen, char[][] arr, int[] trankey,String plaintexts) {
    for (int i = 0; i < len; i++) {
      for (int j = 0; j < 7; j++) {
        arr[i][j] = miwen[i][trankey[j]];
      }
    }
    for (int i = 0; i <7-(7*len-plaintexts.length()); i++) {
      n[i]=arr[arr.length-1][i];
    }//7-(7*len-plaintexts.length())是二维数组中最后一个一维数组中的非填充位的个数,将非填充位加到n中
    arr[len-1]=n;//用n取代二维数组中最后一个数组,相当于将填充的0消去
  }//解密方法
}

运行结果

请输入带加密的明文:
jdlalsdkpa1548796
加密后的明文是:
dajldsl81k5p4a0070906
按下1解密或按其他任意键退出:
1
jdlalsdkpa1548796

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • 兼容PHP和Java的des加密解密代码分享

    php代码: <?php class DES { var $key; var $iv; //偏移量 function DES($key, $iv=0) { $this->key = $key; if($iv == 0) { $this->iv = $key; } else { $this->iv = $iv; } } //加密 function encrypt($str) { $size = mcrypt_get_block_size ( MCRYPT_DES, MCRYPT_MO

  • java常用工具类之DES和Base64加密解密类

    一.DES加密和解密 package com.itjh.javaUtil; import java.io.UnsupportedEncodingException; import java.security.InvalidKeyException; import java.security.NoSuchAlgorithmException; import java.security.SecureRandom; import java.security.spec.InvalidKeySpecExc

  • Java实现的AES256加密解密功能示例

    本文实例讲述了Java实现的AES256加密解密功能.分享给大家供大家参考,具体如下: 一.代码 package com.handler; import java.io.UnsupportedEncodingException; import java.security.Key; import java.security.Security; import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import javax.cry

  • Java使用AES加密和解密的实例详解

    Java使用AES加密和解密的实例详解 前言: AES的基本要求是,采用对称分组密码体制,密钥长度的最少支持为128.192.256,分组长度128位,算法应易于各种硬件和软件实现.1998年NIST开始AES第一轮分析.测试和征集,共产生了15个候选算法.1999年3月完成了第二轮AES2的分析.测试.2000年10月2日美国政府正式宣布选中比利时密码学家Joan Daemen 和 Vincent Rijmen 提出的一种密码算法RIJNDAEL 作为 AES. 在应用方面,尽管DES在安全上

  • des加密解密JAVA与.NET互通实例

    JAVA版本 复制代码 代码如下: import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.DESKeySpec; import javax.crypto.spec.IvParameterSpec; public class Des { private byte[] desKey; //解密数据 public

  • 基于Java实现的Base64加密、解密原理代码

    一.概述 1.Base64是什么: Base64是网络上最常见的用于传输8Bit字节代码的编码方式之一,大家可以查看RFC2045-RFC2049,上面有MIME的详细规范.Base64编码可用于在HTTP环境下传递较长的标识信息.例如,在Java Persistence系统Hibernate中,就采用了Base64来将一个较长的唯一标识符(一般为128-bit的UUID)编码为一个字符串,用作HTTP表单和HTTP GET URL中的参数.在其他应用程序中,也常常需要把二进制数据编码为适合放在

  • java中常用工具类之字符串操作类和MD5加密解密类

    java中常用的工具类之String和MD5加密解密类 我们java程序员在开发项目的是常常会用到一些工具类.今天我分享一下我的两个工具类,大家可以在项目中使用. 一.String工具类 package com.itjh.javaUtil; import java.io.ByteArrayInputStream; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import

  • Java实现文件的加密解密功能示例

    本文实例讲述了Java实现文件的加密解密功能分享给大家供大家参考,具体如下: package com.copy.encrypt; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; impor

  • java使用des加密解密示例分享

    复制代码 代码如下: import java.security.Key;import java.security.SecureRandom;import java.security.spec.AlgorithmParameterSpec; import javax.crypto.Cipher;import javax.crypto.SecretKeyFactory;import javax.crypto.spec.DESKeySpec;import javax.crypto.spec.IvPar

  • Java实现MD5加密及解密的代码实例分享

    基础:MessageDigest类的使用 其实要在Java中完成MD5加密,MessageDigest类大部分都帮你实现好了,几行代码足矣: /** * 对字符串md5加密 * * @param str * @return */ import java.security.MessageDigest; public static String getMD5(String str) { try { // 生成一个MD5加密计算摘要 MessageDigest md = MessageDigest.g

随机推荐