这其实是湖大一个同学的作业,前几天我这个隔壁学校的被求助,然后翘了一节课帮她写出来的,若不是妹纸我才没那么积极呢[偷笑]。 所以,湖大的同学若果想要用这份代码交作业请慎重,以免老师追究。
现已知一份密文: hdqtrnyoenahauiniorpaiduaubidofdaletcndnnoertenteavcfhacukeatpv.
fcyynatyneucusanedthrepetoctnhukrlhnadiywieosrsifooueeoitaanevui
osjtosvtmfnflfnunnamentntemfoehmtiouttrgpnyrihaaceerleihvohhhasrc,
svtnttnszycteetieelhoifiehde9tshtpturolrhlaveatrei'8aoahcensfliiy,
inmysmss5nroeheiitapsrcnto.iinpfdlypuavthnpteacmuitnorociuanneyedl
onpeistiiworoueradr,poiroi,lciesijpnkytntssinniwtilesstnerseuyuhii
ctgcnasenoarccitlasnettthxaelhntnfyltorireipyuueildcoaeefou2ruaecvr
.arwalcinrnoifd1icnrreeateenyitoinflee1ttdeersbessgatyraitiddayips
tsic
已知它是使用二维易位方法加密 但现在密钥未知(不超过25),明文中的空格在加密时去除,所有字符全小写 加密时若最后一行不全,则用a到z按顺序填充, 解密后把填充在末尾的a-z去掉得到明文。
例如: 明文为:today is friday
去掉空格后:todayisfriday
密钥为3:
today
isfri
dayab
在明文后填充了ab
密文为:tidosadfyarayib
解密后得:todayisfridayab [img]
手动断句后去掉填充的ab,可得明文。
所以,对明文进行加密的思路是:
1、将明文中的空格去掉;
2、将明文的字符数根据密钥(key)进行补齐(补以abc....);
3、将明文按照先行后列的顺序把字符放入二维数组矩阵中;
4、将二维数组中的字符按照先列后行的顺序取出并串成密文。
以下是几个关键方法的代码实现
/**
* 加密算法
* @param key 密钥
* @param foremsg 明文
* @return
*/
public String encrypt(int key,String foremsg) {
int len = foremsg.length() / key;
int low = key;//行
int col = len; //列
String newString = "";
array = new String[low][col];//数组矩阵
System.out.println("正序数组:");
for (int i = 0; i < low; i++) {//循环依次放入数组中 先行后列
for (int j = 0; j < col; j++) {
if(count<foremsg.length()){//避免数组越界
array[i][j] = foremsg.substring(count,count+1);//返回指定索引处的 char 值
System.out.print(array[i][j]+" ");
}
count ++;
}
}
System.out.println();
System.out.println("逆序数组:");
for (int j = 0; j < col; j++) {//循环输出(按矩阵反序)PPT第6页 先列后行
for (int i = 0; i < low; i++) {
newString = array[i][j];
jiami_msg += newString;//连接成串
System.out.print(newString+" ");
}
}
System.out.println();
return jiami_msg;
}
/**
* 删除空格
*/
private void deteleSpace() {
String stringNoSpace = "";
while (foremsg.indexOf(" ") != -1) {
stringNoSpace += foremsg.substring(0, foremsg.indexOf(" "));//存空格前
foremsg = foremsg.substring(foremsg.indexOf(" ") + 1);//存空格后
}
stringNoSpace += foremsg;//连接
aftermsg= stringNoSpace;//赋值
}
/**
* 整理字符串
* @return 整理之后的字符串
*/
private String addDivide() {// 后面补充ab....
int len = aftermsg.length();
String str1 = aftermsg;
if (len % key != 0) {
for (int i = 0; i < key - len % key; i++) {
str1 += String.valueOf((char) (97 + i));//将char变量转换为字符串 i = 0 时为a
}
foremsg = str1;//此时的foremsg为去空格且补齐的串
}
return foremsg;
}
有了加密算法,解密的过程就显得容易多了,无非是将加密过程倒过来。
1、将密文的字符按照先列后行的顺序放入二维数组;
2、将二维数组中的字符按照先行后列的顺序取出数组并串成明文。
由于计算机只负责计算,所以需要手动断句并将补齐的字符去掉。
解密代码如下:
/**
* 解密的方法
* @param key 密钥
* @param minwen_msg 密文
* @return mingwen_msg 明文
*/
public String decrypt(int key,String miwen_msg) {
int len = miwen_msg.length() / key;
int low = key;
int col = len;
String newString = "";
array = new String[low][col];//数组矩阵
System.out.println("密文正序数组:");
for (int j = 0; j < col; j++) {//循环依次放入数组中 先列后行
for (int i = 0; i < low; i++) {
if(count <miwen_msg.length()){//避免数组越界
array[i][j] = miwen_msg.substring(count,count+1);//返回指定索引处的 char 值
System.out.print(array[i][j]+" ");
}
count ++;
}
}
System.out.println();
System.out.println("密文解密后数组:");
for (int i = 0; i < low; i++) {//循环输出(按矩阵正序)PPT第6页 先行后列
for (int j = 0; j < col; j++) {
newString = array[i][j];
mingwen_msg += newString;
System.out.print(newString+" ");
}
}
System.out.println();
return mingwen_msg;
}
解密之后并断句可得明文:
/**
* 密钥为23,明文如下。
* hunan university,situated at the foot of the picturesque yuelu hilland on the west bank of the
* rippling xiang river in the historically and culturally renowned city of changsha,capital city of hunan province,
* is honored as an ancient millenarian academy,famous centennial university.it is one of the key universities affiliated
* with the ministry of education and is now included in the state's project 211 and project 985 for priority investment and construction.
* professor liu keli and professor zhao yueyu are respectively the party secretary of the cpchunan university committee and the president
* of the university.
*/
其实有了加解密算法,这个程序可以通过IO实现对文件的加密解密,再用SWing界面加以可视化操作,简直上了一个档次,无奈近来事儿多,暂且搁置吧。
附件中有程序源代码。
- 大小: 10.8 KB
分享到:
相关推荐
MFC做的易位加密算法,能实现非定长密钥的加密解密,以及查看详细过程的功能
这个是几年前《密码学》课程设计时做的东西了, 给各位参考。
针对对称加密算法和非对称加密算法,其加密效率低下、不具有在商业通信背景下的普遍适用性,文中基于矩阵易位变换原理提出了一个加密强度很高、发生碰撞概率极孝且加密效率较高的对称加密算法。本加密算法适用于对安全...
timopheevii Zhuk.)渐渗系的区分及易位断点的判定1,纪剑辉,曹爱忠,研究采用小麦2B染色体上的63对SSR标记、STS标记对从瑞士引进的含抗白粉病基因Pm6的八份渐渗系进行了分析,通过分子标记标图来确定8份�
关于野生生物易位和对疾病传播的潜在风险的评估,在保守项目中已经取得了一些进展。 然而,其他因素,例如从筛查中心从不同地点接收到的大量物种,被车辆撞倒后被救出,由公众带走或被当局没收非法贸易等,增加了人...
石墨烯纳米孔DNA易位时间分子动力学研究,熊珊珊,沙菁㛃,近年来,基于纳米孔的单分子检测技术一直是广大学者们关注的焦点,其最具前景的应用即是通过DNA易位引起的离子电流阻塞程度实现DNA
通过对黑麦的研究,更加清晰的看出黑麦1RS易位系对小麦不同生育期的影响
22)染色体易位,这是CML患者的一种特定的染色体异常。 该系统的功能基于深度学习算法,我使用ResNet创建了一个分类系统。 该模型可以根据9号和22号染色体的图像有效检测t(9; 22)易位。该模型在验证集上的准确率...
辐射诱变大白菜-结球甘蓝1号单体异附加系获得易位系研究,商少川,王彦华,为创建大白菜-结球甘蓝易位系,本研究采用60Co-γ射线对大白菜-结球甘蓝1号单体异附加系(AA+C1)进行花粉辐射,用辐射后成熟花粉与二
携带簇毛麦HMW-GS基因小片段易位系的创制,张瑞奇,,簇毛麦高分子量麦谷蛋白亚基(HMW-GS)已被证实对面包品质改良具有显著正效应,但将簇毛麦HMW-GS亚基通过小片段易位系方式转入小麦背
该方法基于通过在横向金电极上以纳米线或纳米带的形式制作的纳米间隙进行的隧道电流研究。 DNA在水溶液中的运动受施加到参比电极的电势调节。 施加在侧面金属电极上的电势有助于形成分子结。 它们由穿过孔的核苷...
【方法】以豫麦49/周麦16杂交后代的176个F5重组自交系为材料,于2008-2010年连续2年对籽粒性状进行分析,并结合SSR和STS标记对1BL.1RS染色体进行籽粒性状的QTL检测。【结果】小麦籽粒性状中粒长和密度因子主要受基因型...
比较了两种向日葵幼苗的发芽能力和金属转运能力,以确定在幼年期对金属污染的品种差异。 重金属处理包括:将0、50、100、150和200 mM的Ni,Cd和Pb应用于装满沙子的花盆中,用于Hysun-33和FH-533向日葵。 未经重金属...
荧光原位杂交分析染色体易位估算辐射生物剂量技术方法.pdf
电信设备-使用移动床气相反应器的易位方法.zip
针对采用二进制编码的进化算法在函数优化过程中会因为维度之间的相互干扰,导致部分低阶模式出现无法进行有效重组的现象,提出一种新的结合细胞学研究成果的进化算法――染色体易位的动态进化算法(CTDEA)。算法通过...
金纳米棒通过固态纳米Kong易位