4 多表代替密码之Hill 密码_1 矩阵工具类
在说明Hill加密之前要先复习线性代数的知识,主要是关于矩阵的一些运算和概念。
一、矩阵的逆:
定义方阵M的逆矩阵应该满足M*M^-1==I,其中I是单位矩阵,比如:
但是这个地方是对英文字母进行加密,所以矩阵中的数字都是模26的值,比如:
*
=
这个地方结果就应该mod26, 最后结果就是:
那么上面两个相乘的矩阵就互为逆矩阵。
这个地方要多说一下密码学中的mod运算,数学中-5%26结果肯定是-5,但是这个地方我们取值只能在0-25之间,所以-5%26的结果应该是21。
求解一个方阵的逆矩阵的公式是: (det A)-1*(-1)i+j(Dji),其中:
1.det A 是矩阵A 的行列式,当然最后结果也要是mod26,(det A)-1的意思是取矩阵A的行列式的逆,比如:
的行列式是5*3-8*17=-121mod26=9
那么(det A)-1 = 3,因为3*8mod26=1,符合矩阵逆的定义。
2.Dji 是将A去掉第j行和dii行的子行列式的值,比如:
是个2*2的方阵,那么i和j就有4种组合:0,0:0,1:1,0:1,1, 那么分别去掉对应的列和行后,就成了4个1*1的方阵,再分别计算这四个方阵的行列式,结果就是:
Dji =
3. (-1)i+j
这个与Dji相乘的结果就是:
mod26 =
最后得到A的逆矩阵为:
mod26=
二、Java中关于矩阵计算的工具包
其中最常用的就是jama了, http://math.nist.gov/javanumerics/jama/
但是要用到我们这个对应26个英文字母的加密算法中还需要进行改造,‘主要是以下几点:
1. jama是针对double类型的,要切换到int或者short
2. jama结果不会取模, 比如手动实现取模
三、我的实现
还是直接来个工具类吧,使用jama:
package com.owner.util.matrix; import Jama.Matrix; import java.text.NumberFormat; /**
* Created by wellmax on 2015/10/8.
*/
public class MatrixUtil {
private Matrix matrix; public MatrixUtil(Matrix matrix) {
this.matrix = matrix;
} public MatrixUtil() {
} public int dimension() {
return this.getMatrix().getArray().length;
} private int mod(int number) {
int mod = number % 26;
return mod < 0 ? mod + 26 : mod;//+26 避免取模结果为负
} private int convertDouble2Int(Double d) {
return d.intValue();
} /**
* 计算构成Dji 矩阵的子矩阵矩阵
*/
private Matrix excludeRowAndColumn(int row, int column) {
double[][] subArr = new double[dimension() - 1][dimension() - 1];
double[][] arr = this.getMatrix().getArray();
int rowFlag = 0;
int columnFlag = 0;
for (int i = 0; i < arr.length; i++) {
if (i == row) {
continue;
}
for (int j = 0; j < arr.length; j++) {
if (j == column) {
continue;
}
subArr[rowFlag][columnFlag] = arr[i][j];
columnFlag++;
}
rowFlag++;
columnFlag = 0;
}
return new Matrix(subArr);
} /**
* 计算行列式
*/
public int determinant(Matrix matrix) {
double doubleDeterminant = matrix.det();
return this.mod(this.convertDouble2Int(doubleDeterminant));
} /**
* 计算行列式的逆,这个方法有点坑。。。
*/
public int negativeDeterminant(int determinant) {
int i = 1;
while (true) {
if ((determinant * i) % 26 == 1) {
return i;
}
if (i == Integer.MAX_VALUE >> 1) {
break;
}
i++;
}
throw new RuntimeException("Could not find the negative determinant");
} /**
* 计算D矩阵
*/
public Matrix getD() {
double[][] arr = this.getMatrix().getArray();
if (arr == null || arr.length == 0) {
return null;
}
double[][] arrD = new double[arr.length][arr.length];
for (int i = 0; i < arr.length; i++) {
for (int j = 0; j < arr[i].length; j++) {
arrD[i][j] = this.determinant(this.excludeRowAndColumn(j, i));
}
}
return new Matrix(arrD);
} /**
* 计算(-1)i+j 乘上 D矩阵
*/
public Matrix negative(Matrix matrix) {
double[][] arr = matrix.getArray();
for (int i = 0; i < arr.length; i++) {
for (int j = 0; j < arr.length; j++) {
if ((i + j) % 2 == 1) {
arr[i][j] = mod(-1 * new Double(arr[i][j]).intValue());
}
}
}
return new Matrix(arr);
} /**
* 最后一个求矩阵的逆矩阵
*/
public Matrix inverse() {
int negativeDeterminant = negativeDeterminant(determinant(this.getMatrix()));
Matrix D = this.negative(this.getD());
double[][] arr = D.getArray();
double[][] inverseArr = new double[arr.length][arr.length];
for (int i = 0; i < arr.length; i++) {
for (int j = 0; j < arr.length; j++) {
inverseArr[i][j] = mod(new Double(arr[i][j]).intValue() * negativeDeterminant);
}
}
return new Matrix(inverseArr);
} private int rowMultiplyEqualLengthMatrix(int[] row, double[] matrix) {
double result = 0;
for (int i = 0; i < row.length; i++) {
result += row[i] * matrix[i];
}
return this.mod(this.convertDouble2Int(result));
} public int[] rowMultiplyMatrix(int[] row, Matrix matrix) {
int length = row.length;
int matrixDimension = matrix.getColumnDimension();
int mod = length % matrixDimension;
int cycleTime = length / matrixDimension;
int[] result = new int[length];
double[] matrixArr = matrix.getColumnPackedCopy();
int element = 0;
double[] cycleMatrixArr = new double[matrixDimension];
int[] cycleRowArr = new int[matrixDimension];
for (int i = 0; i < cycleTime; i++) {
System.arraycopy(row, i * matrixDimension, cycleRowArr, 0, matrixDimension);
for (int j = 0; j < matrixDimension; j++) {
System.arraycopy(matrixArr, j * matrixDimension, cycleMatrixArr, 0, matrixDimension);
element = this.rowMultiplyEqualLengthMatrix(cycleRowArr, cycleMatrixArr);
result[i * matrixDimension + j] = element;
}
}
if (mod != 0) {
for(int i = 0 ; i < matrixDimension ; i ++){
cycleMatrixArr[i] = 0;
}
System.arraycopy(row, cycleTime * matrixDimension, cycleRowArr, 0, length - cycleTime * matrixDimension);
for (int j = 0; j < length - cycleTime * matrixDimension; j++) {
System.arraycopy(matrixArr, j * matrixDimension, cycleMatrixArr, 0, matrixDimension);
element = this.rowMultiplyEqualLengthMatrix(cycleRowArr, cycleMatrixArr);
result[cycleTime * matrixDimension + j] = element;
} }
return result;
} public Matrix getMatrix() {
return matrix;
} public void setMatrix(Matrix matrix) {
this.matrix = matrix;
} public static void main(String[] args) {
double[][] arr = new double[][]{{5, 8}, {17, 3}};
Matrix m = new Matrix(arr, 2, 2);
MatrixUtil util = new MatrixUtil(new Matrix(arr));
// System.out.println(util.determinant());
Matrix D = util.getD();
// m.print(NumberFormat.getInstance(),3);
// util.negative(D).print(NumberFormat.getInstance(), 3);
util.inverse().print(NumberFormat.getInstance(), 3);
int[] row = new int[]{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11};
int[] result = util.rowMultiplyMatrix(row, m);
for (int i : result) {
System.out.println(i);
} // double[][] det = new double[][]{{9}};
// Matrix detMatrix = new Matrix(det);
// detMatrix.inverse().print(NumberFormat.getInstance(),3);
}
}
-wellmaxwang
4 多表代替密码之Hill 密码_1 矩阵工具类的更多相关文章
- 4 多表代替密码之Hill 密码 2实现
该解密方法的KEY 不是一个数或者一段字符串,而是一个矩阵, 比如有个3*3的KEY: 那么如果我们要加密一个长度为N的字符串, 那么把N除以3,分成M个3个字母组成的小段, 对每个小段尽心加密: 1 ...
- javascript实现playfair和hill密码算法
时至期末,补习信息安全概论作业.恰巧遇古典密码学算法中的playfair算法和hill算法,用javascript语言实现起来是在有趣,边查百度边编码,顺便好好补习一下javascript基础. pl ...
- Hill密码解密过程(Java)
Hill密码是一种传统的密码体系.加密原理:选择一个二阶可逆整数矩阵A称为密码的加密矩阵,也就是这个加密体系的密钥.加密过程: 明文字母依次逐对分组,例如加密矩阵为二阶矩阵,明文就两个字母一组,如果最 ...
- 信息安全-2:python之hill密码算法[原创]
转发注明出处:http://www.cnblogs.com/0zcl/p/6106513.html 前言: hill密码算法我打算简要介绍就好,加密矩阵我用教材上的3*3矩阵,只做了加密,解密没有做, ...
- Hill密码
希尔密码(Hill Password)是运用基本矩阵论原理的替换密码,由Lester S. Hill在1929年发明.每个字母当作26进制数字:A=, B=, C=... 一串字母当成n维向量,跟一个 ...
- Oracle创建表空间、用户名、密码步骤教程
第一步,以最高级别 SYSDBA 身份登录数据库 cmd 进入命令行 登录方式一: C:\Documents and Settings\Administrator>sqlplus sys/sys ...
- ubuntu系统下mysql重置密码和修改密码操作
一.忘记密码后想重置密码 在介绍修改密码之前,先介绍一个文件/etc/mysql/debian.cnf.其主要内容如下图: 里面有一个debian-sys-maint用户,这个用户只有Debian或U ...
- ssm中通过ajax或jquer的validate验证原密码与修改密码的正确性
一.ajax 1. <script type="text/javascript"> //验证原密码1.ajax,正则 var ok1=false,ok2=false,o ...
- C#--用户密码处理------混淆密码加密
近期刚好做新框架的用户数据安全这块 密码的保护措施:混淆加密--------------------------------拙见----------贴上代码--请指教 1:生成混淆数据,---存入数据 ...
随机推荐
- vue 2.0
vue2.0 据说也出了很久了,博主终于操了一次实刀. 整体项目采用 vue + vue-router + vuex (传说中的vue 全家桶 ),构建工具使用尤大大推出的vue-cli 项目是 ...
- 反斜杠在JSP中的两种不同的含义
/ 在不同条件下的不同含义 / 代表WEB应用的根路径的情况:/ 交给 Servlet容器来处理 请求转发时: request.getRequestDispatcher("/xxxx&quo ...
- asp.net "true"的小坑
在cs文件中 写了一个 属性 protected bool IsTrue { get{ return true; } } 在页面 .aspx文件中 在js中 var flag="<%= ...
- IIS 7.5最新解析漏洞
IIS7.5解析漏洞 http://www.cnk0n9.com/fckeditor/editor/fckeditor.html, 上传图片,浏览,上传一个aspx的一句话木马,名字为:a.aspx. ...
- git push命令
git push命令用于将本地分支的更新,推送到远程主机.它的格式与git pull命令相仿. $ git push <远程主机名> <本地分支名>:<远程分支名> ...
- easyui的textbox赋值小结
使用的系统中有个后台,需要填充单号,如下图: 每次往框里面填充都是一样的数据,复制.粘贴,而且当人数颇多的时候,就是体力活. 于是就想到通过执行js代码,自动填充这些数据. chrome下F12,查看 ...
- 第一篇博客:Hello World
2016年10月10日,双十,好日子,决定开始写第一篇博客,标题想了会,就叫Hello World 吧,哈哈^_^. 首先感谢博客园的管理们能批准我的申请,记得在14年的时候申请过一次,竟然没申请通过 ...
- 对COM 组件的调用返回了错误 HRESULT E_FAIL
.net ppt转pdf时报以下错误: 对COM 组件的调用返回了错误 HRESULT E_FAIL 在服务器端打开PPT,选项--另存为--PDF,发现PowerPoint报了个错误: “无法找到打 ...
- Emoji表情符号录入MySQL数据库失败解决
让MySQL支持Emoji表情,涉及无线相关的 MySQL 数据库建议都提前采用 utf8mb4 字符集. utf8mb4和utf8到底有什么区别呢?原来以往的mysql的utf8一个字符最多3字节, ...
- (转载)jQuery 1.6 源码学习(一)——core.js[1]之基本架构
在网上下了一个jQuery 1.2.6的源码分析教程,看得似懂非懂,于是还是去github上下载源码,然后慢慢看源代码学习,首先来说说core.js这个核心文件吧. jQuery整体的基本架构说起来也 ...