Ⅰ 凱撒密碼
我覺得創建26個文件實在太冗雜了。其實一個就夠了,因為隨著你的選擇的改變(比如以9為加密條件,所有字母循環後移9位),目標文件裡面的內容就自動更新了。
當然你也可以使用函數 int create(char *filename , int mode) 在執行框裏手動輸入像 e:\\original.txt 這樣的地址字元,但你想像一下,這是不是很麻煩?
在實際加密中,可使用隨機函數 rand()產生循環後移位數,而且完全可以不限制在26位,擴展ASCII碼可以產生成千上萬的字元,將文件加密到那些幾乎無規律,難以識別的字元上,安全性就提高了許多。當然還有什麼多輪加密之類的。可以自己慢慢摸索,挺有趣的。祝你好運!
修改如下(已成功執行):
#include<stdio.h>
#include<stdlib.h>
char encrypt(char ch,int n)/*加密函數,把字元向右循環移位n*/
{
while(ch>='A'&&ch<='Z')
{
return ('A'+(ch-'A'+n)%26);
}
while(ch>='a'&&ch<='z')
{
return ('a'+(ch-'a'+n)%26);
}
return ch;
}
void main()
{
FILE *in,*out;
char ch1,ch2;
int i;
printf("Please input the number(1~26) you want to use for encrypt:");
scanf("%d",&i);
if((in=fopen("e:\\original.txt","r"))==NULL)/*文件名根據自己建立的位置修改,
我建在e盤的根目錄下
{
printf("Can not open this file!\n");
exit(0);
}
if((out=fopen("e:\\encrypt.txt","w"))==NULL) //同上
{
printf("Can not open this file!\n");
exit(0);
}
while(!feof(in)){
if((ch1=fgetc(in))!=EOF)
ch2=encrypt(ch1,i);
fputc(ch2,out);
}
printf("Encrypt is over!\n");
fclose(in);
fclose(out);
}
Ⅱ 請高手解釋一下,什麼叫凱撒密碼,還有什麼叫進制轉換密碼
凱撒密碼 = 英文字母序號 + 偏移量。
Ⅲ zrdlql凱撒密碼什麼意思
凱撒密碼關鍵的是密匙,密匙也就是一個數字,比如說密匙是1,那對英文單詞book這個單詞加密,結果就是相應的每個字母在字母表中的序號減去1;
比如b在英文單詞里排第二位,那加密後就是a,o加密後就是n,依此類推,book加密後就是annj,解密時每個字母的順序號加1,所對應的字母就是密文。
例如,當偏移量是3的時候,所有的字母A將被替換成D,B變成E,以此類推X將變成A,Y變成B,Z變成C。由此可見,位數就是凱撒密碼加密和解密的密鑰。
例子:
愷撒密碼的替換方法是通過排列明文和密文字母表,密文字母表示通過將明文字母表向左或向右移動一個固定數目的位置。例如,當偏移量是左移3的時候(解密時的密鑰就是3):
明文字母表:ABCDEFGHIJKLMNOPQRSTUVWXYZ ;
密文字母表:DEFGHIJKLMNOPQRSTUVWXYZABC。
使用時,加密者查找明文字母表中需要加密的消息中的每一個字母所在位置,並且寫下密文字母表中對應的字母。需要解密的人則根據事先已知的密鑰反過來操作,得到原來的明文。
以上內容參考:網路-凱撒密碼
Ⅳ 什麼是凱撒加密法
簡單的說,就是位移加密。
比如你的密碼是ABCDE
然後設置凱撒密碼的偏移量為3的話
那加密之後的密碼就是DEFGH
Ⅳ 愷撒密碼的凱撒密表
古羅馬隨筆作家修托尼厄斯在他的作品中披露,凱撒常用一種「密表」給他的朋友寫信。這里所說的密表,在密碼學上稱為「凱撒密表」。用現代的眼光看,凱撒密表是一種相當簡單的加密變換,就是把明文中的每一個字母用它在字母表上位置後面的第三個字母代替。古羅馬文字就是現在所稱的拉丁文,其字母就是我們從英語中熟知的那26個拉丁字母。因此,凱撒密表就是用D代a,用E代b,……,用z代w,(注意!)用A代x,用B代y,C代z。這些代替規則也可用一張表格來表示(所以叫「密表」)。
例如,有這樣一個拉丁文例子
OmniaGalliaest
divisainPartestres
(高盧全境分為三部分)
用凱撒密表加密後,就成為密文
RPQLDJDOOLDHVW
GLYLVDLQSDUWHVWUHV
你看,不掌握其中奧妙,不知道凱撒密表,簡直不如所雲。那麼,在公元前54年,凱撒就是用這種密碼給西塞羅寫信的嗎?有趣的是,密碼界對這—點卻持否定態度,因為密碼學歷史上還記載著凱撒使用的另一種加密方法:把明文的拉丁字母逐個代之以相應的希臘字母,這種方法看來更貼近凱撒在《高盧戰記》中的記敘。顯然,哪一個拉丁字母應該代之以哪—個希臘字母,事先都有約定,凱撒知道,西塞羅也知道,不然的話,西塞羅收到密信後,也會不知所雲。當阿里巴巴站在那四十一名大盜的山洞大門口,准備打開大門時,他必須知道一個咒語:「芝麻開門」。當我們站在密碼學的大門,准備邁入時,必須要知道的則是—些基本概念。為此,讓我們先把密碼通信的幾個要素總結如下。
在軍事通信上,必須考慮要傳送的秘密信息在傳送的途中被除發信者和收信者以外的第三者(特別是敵人)截獲的可能性使載送信息的載體(如文本、無線電被等)即使在被截獲的情況下也不會讓截獲者得知其中信息內容的通信方法或技術,稱為保密通信。密碼通信就是一種保密通信,它是把表達信息的意思明確的文字元號,用通信雙方事先所約定的變換規則,變換為另一串莫名其妙的符號,以此作為通信的文本發送給收信者,當這樣的文本傳送到收信者手中時,收信者—時也不能識別其中所代表的意思,這時就要根據事先約定的變換規則,把它恢復成原來的意思明確的文字,然後閱讀。這樣,如果這個文本在通信途中被第三者截獲,由於第三者—般不知道那變換規則,因此他就不能得知在這一串符號背後所隱藏的信息。當然,為了戰爭的目的,他會千方百計地努力弄到這個變換規則。一種努力就是對已經截獲的密文進行分析,有時結合從其他途徑獲得的有關信息,試圖找出這個變換規則。
在密碼學中,我們要傳送的以通用語言明確表達的文字內容稱為明文,由明文經變換而形成的用於密碼通信的那一串符號稱為密文,把明文按約定的變換規則變換為密文的過程稱為加密,收信者用約定的變換規則把密文恢復為明文的過程稱為解密。敵方主要圍繞所截獲密文進行分析以找出密碼變換規則的過程,稱為破譯。
如在上一部分中,
就是一段明文,凱撒密表就是—種變換規則。這段明文經凱撒密表加密後,
就變成了密文
。
收信者收到這段密文後,就要進行解密,解密也是用凱撒密表。在這個例子中,加密和解密都在用凱撒密表,但嚴格地說,加密時所用的變換與解密時所用的變換是兩個變換。這兩個變換間的關系是它們互為逆變換。也就是說,明文用其中一個變換進行加密產生密文後,若再用另一個變
換對這密文進行解密,就會得到原來的明文。這種互逆的關系就如同我們所熟知的加法和減法互為逆運算的關系一樣:加上一個數後再減去同一個數,就等於不加也不減。
下面我們總結一下:
明密對照表:
明文:ABCDEFGHIJKLMNOPQRSTUVWXYZ
密文:TUVWXYZABCDEFGHIJKLMNOPQRS
註:廣義上的凱撒是位移的。
凱撒是沒有密匙的,即使沒有密匙也能將它破解出來,因為凱撒移位密碼只有25種密匙,最多就是將這25種可能性挨個檢測一下可以了,這就是我們所說的暴力破解法。也可在用軟體破解,不過我提倡用人工的。
推理的方法:
1,對於有空格的凱撒移位,單字母A和I是突破口,這無異相當於告訴了移動的位數,這樣很容易就被破解了。所以,如果我們要用凱撒密碼的話一定要去掉空格加大破解難度。
2,差數法。
有空格時,而又沒有單字母A和I時,這種方法很,如果我們令A=1,B=2,C=3......就是每個字母是字母的第幾個,經過移位後的單詞,每兩相鄰的字母之間的差值不變的。如the的差值為12,3(在這里我是用後面的一個字母減前面的一個字母,當然你也可以用後面的一個字母減前面的一個字母),移動後兩個相鄰字母的差值也將會是12,3。
對於沒有空格的愷撒破解起來就比有空格的難一些,對於沒有空格的我們還要對密文進行分析,找出重復出現的字母串,然後對字母串進行猜測,例,如果有3個字母串,出現的次數比較高,我們就可以假設它為the因為3個字母串出現次最多的就是the,當然這不是一成不變的,這時應該就被破解了。
我們看到一個密碼怎樣判斷是凱撒密碼呢?這又要扯到頻率分析去(在這里不介紹,在後面在說),沒有經過移位的明文和移過的密文是有區別的,這樣就可以區分凱撒密碼和柵欄密碼了(柵欄密碼參照下一章)。
沒有移位的柵欄密碼母音比較多,這是語言本身的性質絕定,像英語和漢語拼音的母音出現頻率就比較高。