用C语言编程恺撒密码加密解密程序
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了用C语言编程恺撒密码加密解密程序相关的知识,希望对你有一定的参考价值。
恺撒密码的替换方法是通过排列明文和密文字母表,密文字母表示通过将明文字母表向左或向右移动一个固定数目的位置。例如,当偏移量是左移3的时候(解密时的密钥就是3):
明文字母表:ABCDEFGHIJKLMNOPQRSTUVWXYZ
密文字母表:DEFGHIJKLMNOPQRSTUVWXYZABC
使用时,加密者查找明文字母表中需要加密的消息中的每一个字母所在位置,并且写下密文字母表中对应的字母。需要解密的人则根据事先已知的密钥反过来操作,得到原来的明文。例如:
明文:THE QUICK BROWN FOX JUMPS OVER THE LAZY DOG
密文:WKH TXLFN EURZQ IRA MXPSV RYHU WKH ODCB GRJ
用到C语言函数
fopen(“D:\\test\\a1”,”r”) 以只读的方式打开名为a1的文件,a1文件位于D:\test\下。
fopen(“D:\\test\\a1”,”w”) 以写的方式打开名为a1的文件,a1文件位于D:\test\下。
fgets(str,n,fp) 从fp指向的文件读入一个长度为n的字符串,存放到字符数组str中
fputs(str,fp):把str所指向的字符串写到文件指针变量fp所指向的文件中
#define isletter( c ) ( ((c)>='a'&&(c)<='z') || ((c)>='A'&&(c)<='Z') )
void Enc( const char *str, char *out, int key )
int i = 0;
while( str[i] )
if ( isletter( str[i] ) )
out[i] = str[i] + key;
if ( ! isletter( out[i]) )
out[i] -= 26;
else
out[i] = str[i];
i++;
out[i] = 0;
void Denc( const char *str, char *out, int key )
int i=0;
while( str[i] )
if ( isletter( str[i] ) )
out[i] = str[i] - key;
if ( ! isletter( out[i] ) )
out[i] += 26;
else
out[i] = str[i];
i++;
out[i] = 0;
int main()
char out[100], out2[100];
Enc( "THE QUICK BROWn fox jumps over THE LAZY DOG", out, 3 );
printf( "%s\\n", out );
Denc( out, out2, 3 );
printf( "%s\\n", out2 );
追问
不好意思,运行界面怎么不是跟图的一样?
追答未加密文字:THE BUTCHER THE BAKER AND THE CANDLESTICK MAKER。(屠夫、面包师和蜡烛匠)。
关键密钥:BIG BIGBIGB IGB IGBIG BIG BIG BIGBIGBIGBI GBIGB
加密文字:UPK CCZDPKS BNF JGLMX BVJ UPK DITETKTBODS SBSKS
#include<stdio.h>
#include<string.h>
void main()
char str[99],k[10],m[99]="";
unsigned i,j=0,n;
printf("输入要加密的内容\\n");
gets(str);
printf("输入密匙\\n");
gets(k);
n=strlen(k);
for(i=0;i<strlen(str);i++)
if(str[i]==' ')m[i]=' ';
else
m[i]=str[i]+k[j]-'A';
if(m[i]>'Z')m[i]=m[i]-26;
j++;
if(j==n)j=0;
printf("加密后\\n");
puts(m);
追问
不好意思,运行界面怎么不是跟图的一样?
追答用python实现凯撒密码
在密码学中,凯撒密码(或称恺撒加密、恺撒变换、变换加密)是一种最简单且最广为人知的加密技术。它是一种替换加密的技术。这个加密方法是以恺撒的名字命名的,当年恺撒曾用此方法与其将军们进行联系。恺撒密码通常被作为其他更复杂的加密方法中的一个步骤,例如维吉尼亚密码。恺撒密码还在现代的ROT13系统中被应用。但是和所有的利用字母表进行替换的加密技术一样,恺撒密码非常容易被破解,而且在实际应用中也无法保证通信安全。
尽管是最简单的加密技术,但那该怎么在python中如何现实呢?
代码如下:
def ask():
while True:
print("Welcome to you coming!")
print("you can choose mode : encrypt(e) or decrypt(d)") #有解密和加密模式
print("If you choose encrypt ,you can lock the message!") #加密提示
print("If you choose decrypt ,you can unlock the message!") #解密提示
print("If you wanna exit , input 'q'!!") #退出提示
mode = input("choose:").lower() #将输入的模式进行变换(从大写变小写,小写部分不变)
if mode in 'encrypt e decrypt d q'.split(): #当模式是被要求的encrypt e(加密模式)decrypt d(解密模式) q(退出)时进行下一步操作
#print(mode) #打印输入的模式
return mode #将mode的值作为返回值
else:
print('Please input right option!!') #输出提示
def getKey(mode):
key = 0 #设置默认的key
while key <= 0 or key >= 26: #限制key的范围在(1-25以内的数)
try: #这里进行异常处理,将非整数类型的输入进行错误提示打印
key = int(input("Please input your key:(1-26)"))
except:
print("Please input correct number!!")
#对解密的密匙进行变换
if mode == 'd' or mode == 'decrypt':
key = -key
return key
def getMessage(key):
#输入信息
while True:
informetion = input("Please input message!!") #输入要解密或者加密的信息
if informetion.isalpha(): #判断输入的字符串是否为纯字母
break
else:
print("Please input continuous character!!!") #输错提示
message = '' #设置输出的初始值
for x in informetion: #将输入信息里的进行逐一字母加密/解密
num = ord(x) #将单一字符通过ascii表进行转换,将字母转换为数字
num += key #加上key的值进行下列运算
if x.isupper(): #判断是否是大写字母
if num > ord('Z'): #对超出ascii对应数值的范围进行处理
num -=26
print(message)
elif num < ord('A'):
num +=26
print(message)
elif x.islower(): #判断是否小写字母
if num > ord('z'):
num -=26
elif num < ord('a'):
num +=26
message += chr(num) #将单一字符通过ascii表进行转换,将数字转换为字母
return message #返回message的值
if __name__=="__main__": #主程序
mode = ask() #将ask()返回值存于mode变量中
if mode == 'q': #进行退出判断
print('welcome!!')
else:
key = getKey(mode) #将mode变量的值带入getKey函数中运行,运行后将key的值存入到key变量中
last = getMessage(key) #将key变量的值带入到getMessage函数中,运行后将message的值存入到last变量中
print(last) #打印last输出结果
以上是关于用C语言编程恺撒密码加密解密程序的主要内容,如果未能解决你的问题,请参考以下文章