古典古典密码算法实现-替换密码-转换密码

来源:百度知道 编辑:UC知道 时间:2024/05/01 01:17:17
我是个刚刚学密码学的

请教一下这两个古典密码算法用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文件..绝无病毒啊..
谢谢了

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();
Syste