古典古典密码算法实现-替换密码-转换密码 15
我是个刚刚学密码学的请教一下这两个古典密码算法用c,java,VC,VB实现谢谢了...不好意思我是菜鸟..有点麻烦!!看一下下面这个PDF文件.大家就明白我想问的是什么...
我是个刚刚学密码学的
请教一下这两个古典密码算法用c,java,VC,VB实现
谢谢了...
不好意思我是菜鸟..有点麻烦!!
看一下下面这个PDF文件.大家就明白我想问的是什么了...
http://www.sie.bupt.cn/tmc/pdf/%E5%AE%9E%E9%AA%8C1%EF%BC%8D1%20%E5%8F%A4%E5%85%B8%E5%AF%86%E7%A0%81%E7%AE%97%E6%B3%95.pdf#search=%22%E5%8F%A4%E5%85%B8%E5%AF%86%E7%A0%81%E7%AE%97%E6%B3%95%E5%AE%9E%E7%8E%B0%22
如果不能链接..就用"古典古典密码算法实现"搜索一下...有个PDF文件就是这个.
这是个pdf文件..绝无病毒啊..
谢谢了 展开
请教一下这两个古典密码算法用c,java,VC,VB实现
谢谢了...
不好意思我是菜鸟..有点麻烦!!
看一下下面这个PDF文件.大家就明白我想问的是什么了...
http://www.sie.bupt.cn/tmc/pdf/%E5%AE%9E%E9%AA%8C1%EF%BC%8D1%20%E5%8F%A4%E5%85%B8%E5%AF%86%E7%A0%81%E7%AE%97%E6%B3%95.pdf#search=%22%E5%8F%A4%E5%85%B8%E5%AF%86%E7%A0%81%E7%AE%97%E6%B3%95%E5%AE%9E%E7%8E%B0%22
如果不能链接..就用"古典古典密码算法实现"搜索一下...有个PDF文件就是这个.
这是个pdf文件..绝无病毒啊..
谢谢了 展开
2个回答
展开全部
package cn.hdu.edu.encrypt;
/*
* 古典密码算法之 替代算法
*
*/
public class Replace {
//当加密或者解密成功时返回CRYPT_OK,失败时返回CRYPT_ERROR
private final static int CRYPT_OK = 1;
private final static int CRYPT_ERROR = 0;
//设定一共有26个可用字母 字母a的编码是97
private final static int totalLetter = 26;
private final static int key = 3;
/*
* @param initCode 没有加密前的字符串
* @CRYPT_OK 加密成功
* @CRYPT_ERROR 加密失败
*/
public static int encrypt(String initCode)throws Exception{
//用来输出加密后的字符
StringBuilder sb = new StringBuilder();
for(int i = 0; i < initCode.length(); i++ ){
int initCodeVal = initCode.charAt(i ) - 96;
int targetCodeVal = (initCodeVal + key ) % totalLetter;
if(targetCodeVal == 0) targetCodeVal = 26;
char targetCode = (char)(targetCodeVal +96);
sb.append(targetCode );
}
//以下就是加密后的字符
String targetCode = sb.toString();
System.out.println(targetCode);
return CRYPT_OK;
}
/*
* @param targetCode 加密前的字符串
* @CRYPT_OK 解密成功
* @CRYPT_ERROR 解密失败
*/
public static int decrypt(String targetCode)throws Exception{
//用来输出解密后的字符
StringBuilder sb = new StringBuilder();
for(int i = 0; i < targetCode.length(); i++ ){
int targetCodeVal = targetCode.charAt(i ) - 96;
//如果已经来到了字母表的开头 给他还回去
if(targetCodeVal <= key) targetCodeVal += 26;
int initCodeVal = targetCodeVal - key;
char initCode = (char)(initCodeVal + 96);
sb.append(initCode );
}
//以下就是解密后的字符
String initCode = sb.toString();
System.out.println(initCode);
return CRYPT_OK;
}
/*
* 古典密码算法之 替代算法
*
*/
public class Replace {
//当加密或者解密成功时返回CRYPT_OK,失败时返回CRYPT_ERROR
private final static int CRYPT_OK = 1;
private final static int CRYPT_ERROR = 0;
//设定一共有26个可用字母 字母a的编码是97
private final static int totalLetter = 26;
private final static int key = 3;
/*
* @param initCode 没有加密前的字符串
* @CRYPT_OK 加密成功
* @CRYPT_ERROR 加密失败
*/
public static int encrypt(String initCode)throws Exception{
//用来输出加密后的字符
StringBuilder sb = new StringBuilder();
for(int i = 0; i < initCode.length(); i++ ){
int initCodeVal = initCode.charAt(i ) - 96;
int targetCodeVal = (initCodeVal + key ) % totalLetter;
if(targetCodeVal == 0) targetCodeVal = 26;
char targetCode = (char)(targetCodeVal +96);
sb.append(targetCode );
}
//以下就是加密后的字符
String targetCode = sb.toString();
System.out.println(targetCode);
return CRYPT_OK;
}
/*
* @param targetCode 加密前的字符串
* @CRYPT_OK 解密成功
* @CRYPT_ERROR 解密失败
*/
public static int decrypt(String targetCode)throws Exception{
//用来输出解密后的字符
StringBuilder sb = new StringBuilder();
for(int i = 0; i < targetCode.length(); i++ ){
int targetCodeVal = targetCode.charAt(i ) - 96;
//如果已经来到了字母表的开头 给他还回去
if(targetCodeVal <= key) targetCodeVal += 26;
int initCodeVal = targetCodeVal - key;
char initCode = (char)(initCodeVal + 96);
sb.append(initCode );
}
//以下就是解密后的字符
String initCode = sb.toString();
System.out.println(initCode);
return CRYPT_OK;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询