C語(yǔ)言實(shí)現(xiàn)加密解密功能
加密主要是通過(guò)一種算法對(duì)原內(nèi)容進(jìn)行處理,使原來(lái)內(nèi)容不直觀可見(jiàn)。解密過(guò)程通常要知道加密的算法,然后對(duì)加密后的內(nèi)容進(jìn)行逆處理,從而實(shí)現(xiàn)解密功能。當(dāng)然解密也有一些暴力破解的方法。接下來(lái)以 c 語(yǔ)言 為例講解一種簡(jiǎn)單的加密解密以及暴力破解字符串的方法,帶您走進(jìn)加密解密技術(shù)的大門(mén)。
先講一下凱撒加密,凱撒密碼相傳是古羅馬凱撒大帝用來(lái)保護(hù)重要軍情的加密系統(tǒng)。它是一種置換密碼,通過(guò)將字母順序推后起到加密作用。如字母順序推后 3 位,字母 A 將被推作字母 D,字母 B 將被推作字母 E。本實(shí)例類似于凱撒加密。
加密算法:
大(?。?xiě)字母加密后還為大(?。?xiě)字母。大(?。?xiě)字母向后推 n 位,n 由用戶輸入,如果超出大(?。?xiě)字母的 ASCII 范圍,則返回至第一個(gè)大(?。?xiě)字母繼續(xù)循環(huán)。
解密算法(與加密算法正好相反):
大(?。?xiě)字母解密后還為大(小)寫(xiě)字母。大(小)寫(xiě)字母向前推 n 位,n 由用戶輸入,如果超出大(?。?xiě)字母的 ASCII 范圍,則返回至最后一個(gè)大(?。?xiě)字母繼續(xù)循環(huán)。
代碼如下:
/*字符串加密解密程序 凱撒加密*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
//函數(shù)encode()將字母順序推后n位,實(shí)現(xiàn)文件加密功能
void encode(char str[],int n){
char c;
int i;
for(i=0;i<strlen(str);++i){ //遍歷字符串
c=str[i];
if(c>='a' && c<='z'){ //c是小寫(xiě)字母
if(c+n%26<='z'){ //若加密后不超出小寫(xiě)字母范圍
str[i]=(char)(c+n%26); //加密函數(shù)
}else{ //加密后超出小寫(xiě)字母范圍,從頭開(kāi)始循環(huán)小寫(xiě)字母
str[i]=(char)(c+n%26-26);
}
}else if(c>='A' && c<='Z'){ //c為大寫(xiě)字母
if(c + n%26 <= 'Z'){ //加密后不超出大寫(xiě)字母范圍
str[i]=(char)(c+n%26);
}else{ //加密后超出大寫(xiě)字母范圍,從頭開(kāi)始循環(huán)大寫(xiě)字母
str[i]=(char)(c+n%26-26);
}
}else{ //不是字母,不加密
str[i]=c;
}
}
printf("\nAfter encode: \n");
puts(str); //輸出加密后的字符串
}
//decode()實(shí)現(xiàn)解密功能,將字母順序前移n位
void decode(char str[],int n){
char c;
int i;
//遍歷字符串
for(i=0;i<strlen(str);++i){
c=str[i];
//c為小寫(xiě)字母
if(c>='a' && c<='z'){
//解密后還為小寫(xiě)字母,直接解密
if(c-n%26>='a'){
str[i]=(char)(c-n%26);
}else{
//解密后不為小寫(xiě)字母了,通過(guò)循環(huán)小寫(xiě)字母處理為小寫(xiě)字母
str[i]=(char)(c-n%26+26);
}
}else if(c >= 'A' && c<='Z'){ //c為大寫(xiě)字母
if(c-n%26>='A'){ //解密后還為大寫(xiě)字母
str[i]=(char)(c-n%26);
}else{ //解密后不為大寫(xiě)字母了,循環(huán)大寫(xiě)字母,處理為大寫(xiě)字母
str[i]=(char)(c-n%26+26);
}
}else{ //非字母不處理
str[i]=c;
}
}
printf("\nAfter decode: \n");
puts(str); //輸出解密后的字符串
}//該函數(shù)代碼有冗余,讀者可改進(jìn)
int main()
{
char str[50];
int k=0,n=0,i=1;
printf("\nPlease input strings: ");
scanf("%s",str); //輸入加密解密字符串
//打印菜單
printf("-----------------\n");
printf("1: Encryption\n");
printf("2: Decryption\n");
printf("3: Violent Crack\n"); //暴力破解
printf("-----------------\n");
printf("\nPlease choose: ");
scanf("%d",&k);
if(k==1){ //加密
printf("\nPlease input number: ");
scanf("%d",&n);
encode(str,n);
}else if(k==2){ //解密
printf("\nPlease input number: ");
scanf("%d",&n);
decode(str,n);
}else{
for(i=1;i<=25;++i){ //嘗試所有可能的n值進(jìn)行暴力破解
printf("%d ",i);
decode(str,i);
}
}
return 0;
}
測(cè)試運(yùn)行如下:

成功實(shí)現(xiàn)加密解密功能,讀者可以稍加改造完成對(duì)文件的加密解密
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C++實(shí)現(xiàn)稀疏矩陣的壓縮存儲(chǔ)實(shí)例
本篇文章主要介紹了C++實(shí)現(xiàn)稀疏矩陣的壓縮存儲(chǔ)實(shí)例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-06-06
C語(yǔ)言SetConsoleCursorInfo函數(shù)使用方法
這篇文章介紹了C語(yǔ)言SetConsoleCursorInfo函數(shù)的使用方法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-12-12
C++中靜態(tài)成員函數(shù)訪問(wèn)非靜態(tài)成員的實(shí)例
這篇文章主要介紹了C++中靜態(tài)成員函數(shù)訪問(wèn)非靜態(tài)成員的實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-07-07
C語(yǔ)言結(jié)構(gòu)體版學(xué)生成績(jī)管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言結(jié)構(gòu)體版的學(xué)生成績(jī)管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-02-02

