java实现仿射密码加密解密

本文实例为大家分享了java实现仿射密码加密解密的具体代码,供大家参考,具体内容如下

加密:将明文转化为对应的数字,如 ‘a'-> 0, ‘b'->1,…,'1'->26,'2'->27,…然后将数字进行仿射运算,求取出来的数字再转化为字符。即 密文=(K1*明文+K2)mod36

解密:密文转化为对应数字,然后进行仿射的逆运算,得到对应数字,然后将其转化为字符明文。解密 K3是K1的乘法逆元

import java.util.Scanner;

public class Affine{
 public static void main(String[] args) {
  char[] form = {'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N',
    'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', '0'
    , '1', '2', '3', '4', '5', '6', '7', '8', '9'};
  Scanner sc = new Scanner(System.in);
  System.out.println("请输入待加密的明文:");
  String MingWen = sc.nextLine();
  MingWen=MingWen.toUpperCase();//将输入的明文全部大写
  final int K1 = 103;
  final int K2 = 103;
  final int K3 = 31;
  int [] cipherNum=new int[MingWen.length()];//用来存储数字化的密文
  encryption(MingWen,form,K1,K2,cipherNum);
  decryption(form,MingWen,K2,K3,cipherNum);

 }
 public static void encryption(String MingWen,char[] form,int K1,int K2,int[] cipherNum){
  //第一步:将明文存入数组
  char[] pla=new char[MingWen.length()];
  for (int i = 0; i <MingWen.length() ; i++) {
   pla[i]=MingWen.charAt(i);
  }//已将明文存入字符数组pla中
  //第二步:通过脚标找到明文中每个字符对应的数,参与加密运算
  int[] MingWenNumber=new int[pla.length];
  for (int i = 0; i <pla.length ; i++) {
   for (int j = 0; j <form.length ; j++) {
    if (form[j]==pla[i]) {
     MingWenNumber[i] = j;
    }
   }
  }
  //通过脚标将明文全部转化为数字
  char[] cipher = new char[MingWen.length()];//cipher密码数组 用来存储密文
  for (int i = 0; i <MingWen.length() ; i++) {
   int a= Math.floorMod((K1*MingWenNumber[i]+K2),36);
   cipherNum[i]=a;
   cipher[i]=form[a];
   //计算密文并存入数组中
  }
  System.out.println("加密结果是:");
  System.out.println(cipher);
 }

 public static void decryption(char[] form,String Mingwen,int K2,int K3,int[] cipherNum){
  char[] JieMI=new char[Mingwen.length()];
  for (int i =0;i<Mingwen.length();i++){
   JieMI[i]=form[Math.floorMod(K3*(cipherNum[i]-K2),36)];
  }
  System.out.println("解密结果是:");
  System.out.println(JieMI);
 }
}

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

(0)

相关推荐

  • Java实现DES加密与解密,md5加密以及Java实现MD5加密解密类

    很多时候要对秘要进行持久化加密,此时的加密采用md5.采用对称加密的时候就采用DES方法了 import java.io.IOException; import java.security.MessageDigest; import java.security.SecureRandom; import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import j

  • 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实现的Base64加密、解密原理代码

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

  • 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

  • 兼容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实现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

  • 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在安全上

  • 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

  • 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

随机推荐