『壹』 php如何讀取mysql時間格式
使用函式 date() 實現
<?php echo $showtime=date("Y-m-d H:i:s");?>
顯示的格式: 年-月-日 小時:分鍾:秒
相關時間參數:
a - "am" 或是 "pm"
A - "AM" 或是 "PM"
d - 幾日,二位數字,若不足二位則前面補零; 如: "01" 至 "31"
D - 星期幾,三個英文字母; 如: "Fri"
F - 月份,英文全名; 如: "January"
h - 12 小時制的小時; 如: "01" 至 "12"
H - 24 小時制的小時; 如: "00" 至 "23"
g - 12 小時制的小時,不足二位不補零; 如: "1" 至 12"
G - 24 小時制的小時,不足二位不補零; 如: "0" 至 "23"
i - 分鍾; 如: "00" 至 "59"
j - 幾日,二位數字,若不足二位不補零; 如: "1" 至 "31"
l - 星期幾,英文全名; 如: "Friday"
m - 月份,二位數字,若不足二位則在前面補零; 如: "01" 至 "12"
n - 月份,二位數字,若不足二位則不補零; 如: "1" 至 "12"
M - 月份,三個英文字母; 如: "Jan"
s - 秒; 如: "00" 至 "59"
S - 字尾加英文序數,二個英文字母; 如: "th","nd"
t - 指定月份的天數; 如: "28" 至 "31"
U - 總秒數
w - 數字型的星期幾,如: "0" (星期日) 至 "6" (星期六)
Y - 年,四位數字; 如: "1999"
y - 年,二位數字; 如: "99"
z - 一年中的第幾天; 如: "0" 至 "365"
可以自由設定顯示的內容,連接符號或是顯示位置,例如 date("m-d H") 或者date("dmY");?>等php中的日期處理
加入時間:2004-12-18 17:35:22 大小:12 KB 閱讀次數:1405PHP中的日期處理
轉野姿貼:xiaxia 日期:2004-05-26 人氣:9
我正打算用PHP編寫一種幫助處理系統。我發現我必須知道處理完最後一位客戶的問題後已經過去了多長時間?當我過去用ASP時解決這個問題相當簡單,ASP有相應的函數DateDiff可以給出兩個日期間間隔多少月、多少天和多少秒。當我搜尋完PHP手冊後我發現PHP並沒有類似的函數。
本文包含以下內容:
1、 得到目前的日期和時間-我們有多少種方式?
2、 改變日期顯示的方式-日期和時間的顯示形式
3、 轉換現在的日期為Unix的時間戳值
4、 改變日期
a. 增加時間
b. 減去時間
c. 找出兩日期之間的間隔
5、 為PHP添加DateAdd函數
6、 為PHP添加DateDiff函數
**得到目前的日期和時間
在Unix中,時間的表示方式為計算從1970年1月1日零時起所過去的秒數,這稱為UNIX 時間戳(Unix Epoch)。
如果我們有這樣一段的代碼:
?
echo time();
?
將返回值958905820
而此時的時間為2000年5月21日12時43分。
你也許會說這相當不錯。當這對我毫無幫助,或者只有一點幫助。在PHP中,對日期處理的函數都必須用到由time()返回的時間戳值。同時,由於PHP在Unix和Windows系統中均使用同樣的時間頌敬絕戳值,這就允許你不需要修改代碼即可在不同的系統間移植。另外的一個好處是time()函數返回的是一個整數,你可以將其作為整數欄位或文本欄位存入資料庫,而不必使用特別的日期/時間欄位。
你已經基本了解了Unix的時間戳值,現在讓我們來展示它的實際用途。
改變日期顯示的方式-日期和時間的顯示形式
PHP提供兩個辦法來將Unix的時間戳值轉換成為有用的數據。第一個是date()函數。這個函數有兩個參數-第一個字元串用於設定你所希望返回的格式,第二個為Unix的時間戳值。
格式化字元串通過一些簡單的特殊格式化字元來顯示你所希望看到的格式的日期和時間。假設你希望日期以這樣的格式顯示「18h01 Sunday 21 May」。
我們需要對字元串中的每一部分使用一個特殊格式化字元,你可以從PHP手冊中日期和時間函數庫中找到。這樣的特殊格式化字元數量不少,他們所表示的類似於星期幾、月的英文名、用2位或4位數表示的年份,是否是上午(AM)或下午(PM)以及其他。對於這個例子我們需要的特殊字元為:
『H』 -24 小時制的小時
『i』- 分鍾
『l』- 星期幾的稿槐英文全名
『d』- 本月的第幾日
『F』- 月份的英文全名
因此我們的格式化字元串為」Hhi l d F」, PHP代碼為:
?
echo date ("Hhi l d F" ,time());
?
當我們執行這段代碼,我們發現我們所得到的結果為:
180609 Sunday 21 May
這樣的結果看起來有些奇怪。讓我們再查一下PHP手冊,原來』h』所代表的是12 小時制的小時數。這再次證明了一句真理:「計算機只做你所告訴它該做的,而不是你想要它做的」。我們有兩個選擇。第一個是在h前使用轉義字元「」:
echo date ("Hhi l d F", time());
我們得到這樣的結果:
18h12 Sunday 21 May
這正是我們所要的。但如果我們在一個十分復雜的句子中需要包含日期和時間,我們是否需要對每個字元使用轉義字元?
答案當然是不。我們使用另一個函數strftime()。
strftime()有兩個好處。第一個好處我們並不在本文討論范圍內-如果你使用setlocale()函數,你可以通過strftime得到相應語言的月份的名稱。另外的一個好處是你可以將特別的日期和時間的格式化字元包含在你的字元串中。這同時也意味著無論你是否要學習date()函數的所有特殊格式化字元,你都必須學習一整套完全不同的格式化字元。
strftime()工作的方式和date()沒有什麼不同,除了特殊格式化字元的前面必須添加一個百分號%。如果用strftime()函數,前面例子的代碼如下:
?
echo strftime ("%Hh%M %A %d %b" ,time());
?
結果為:
18h24 Sunday 21 May
這也許看起來將簡化繁,但考慮一下如果你所需要的顯示的為"Today is Sunday 21 May 2000. The time is somewhere close to 18h24." 我想使用date()函數無疑令人感到厭煩。
在開始的時候,我提及我們有兩種方式可以從Unix時間戳值中得到有用的數據。我們剛剛了解了date()和strftime()。另一個getdate()。這個函數只需要Unix 的時間戳值作為參數,而函數的返回值為日期和時間的數組。
下面是一個例子:
?
$date_time_array = getdate (time());
echo $date_time_array[ "weekday"];
?
返回的結果為:
Sunday
除了"weekday",該數組的其他部分為:
"seconds" –秒
"minutes" –分
"hours" –小時
「mday" - 本月的第幾天
"wday" -本周的第幾天(數字)
"mon" -月(數字)
"year" –年
"yday" - r本年的第幾天(數字)
"month" -月份全名
我們現在可以得到容易辨認的日期和時間。那麼其他呢?
**轉換現在的日期為Unix的時間戳值
通常你必須處理一些日期或時間格式的數據。打開M$的一個Access資料庫,所有的日期都以YYYY/MM/DD的格式存儲,加入目前的日前即為2000/05/27。Mktime()函數可以將一個時間轉換成Unix的時間戳值。
函數的格式為:int mktime(int hour, int minute, int second, int month, int day, int year, int [is_dst] );
從左往右你必須提供小時、分、秒、月、天和年。最後一個參數用於指定你是否處於夏令時,此參數是可選的,所以我們將忽略它。
代碼如下:
?
echo mktime (0, 0,0 ,5, 27,2000 );
?
由於不知道小時、分和秒同時這些參數必須填寫,我將其設置為0。設置為0意味著時間為午夜。
?
$access_date = "2000/05/27";
//explode()函數用一個字元串作為分界來分解另一個字元串。這個例子$access_date通過字元串」/」來分解
$date_elements = explode("/" ,$access_date);
// 此時
// $date_elements[0] = 2000
// $date_elements[1] = 5
// $date_elements[2] = 27
echo mktime (0, 0,0 ,$date_elements [1], $date_elements[ 2],$date_elements [0]);
?
我們看一個比從Access資料庫單純獲得日期更復雜的情況,我們得到一個以下格式的日期和時間:2000/05/27 02:40:21 PM
?
// 來自Access的字元串
$date_time_string = "2000/05/27 02:40:21 PM";
// 將字元串分解成3部分-日期、時間和上午/下午
$dt_elements = explode(" " ,$date_time_string);
// 分解日期
$date_elements = explode("/" ,$dt_elements[ 0]);
// 分解時間
$time_elements = explode(":" ,$dt_elements[ 1]);
// 如果是下午,我們將時間增加12小時以便得到24小時制的時間
if ($dt_elements [2]== "PM") { $time_elements[ 0]+=12;}
// 輸出結果
echo mktime ($time_elements [0], $time_elements[ 1], $time_elements[ 2], $date_elements[1], $date_elements[2], $date_elements[0]);
?
**修改日期
有時我們需要知道6小時以後是什麼時間,35天前的日期或者從你最後一次玩Quake3後已過去多少秒。我們已經知道如何用mktime()函數從單獨的日期和時間中獲得Unix的時間戳值。如果我們需要的並非目前日期和時間的Unix時間戳值,我們該咋辦?下面是一些練習可以幫助說明我們後面所要做的。
正如前面所見,mktime()使用以下參數:小時、分、秒、月、天和年。想想第二節,getdate()函數可以為我們獲得這些參數。
?
// 將目前的時間戳值放入一數組內
$timestamp = time();
echo $timestamp;
echo "p";
$date_time_array = getdate( $timestamp);
// 用mktime()函數重新產生Unix時間戳值
$timestamp = mktime($date_time_array ["hours"], $date_time_array["minutes" ],$date_time_array[ "seconds"],$date_time_array ["mon"], $date_time_array["mday" ],$date_time_array[ "year"]);
echo $timestamp;
?
看起來有一些令人感到迷惑。我將用一些變數來使上面的程序看起來更容易了解。
?
// 將目前的時間戳值放入一數組內
$timestamp = time();
echo $timestamp;
echo "p";
$date_time_array = getdate( $timestamp);
$hours = $date_time_array[ "hours"];
$minutes = $date_time_array["minutes"];
$seconds = $date_time_array[ "seconds"];
$month = $date_time_array["mon"];
$day = $date_time_array["mday"];
$year = $date_time_array["year"];
// 用mktime()函數重新產生Unix時間戳值
$timestamp = mktime($hours ,$minutes, $seconds,$month ,$day,$year);
echo $timestamp;
?
現在我們將由getdate()所產生的時間戳值放入相對應的名稱變數中,所以代碼變得相對容易閱讀和理解。現在如果我們需要在目前的時間上加上19個小時,我們用$hours+19代替mktime()函數中的$hours。mktime()將自動為我們將時間轉到第二天。
?
// 將目前的時間戳值放入一數組內
$timestamp = time();
echo strftime( "%Hh%M %A %d %b",$timestamp);
echo "p";
$date_time_array = getdate($timestamp);
$hours = $date_time_array["hours"];
$minutes = $date_time_array["minutes"];
$seconds = $date_time_array["seconds"];
$month = $date_time_array["mon"];
$day = $date_time_array["mday"];
$year = $date_time_array["year"];
// 用mktime()函數重新產生Unix時間戳值
// 增加19小時
$timestamp = mktime($hours + 19, $minutes,$seconds ,$month, $day,$year);
echo strftime( "%Hh%M %A %d %b",$timestamp);
echo "br~E after adding 19 hours";
?
運行後得到:
14h58 Saturday 03 Jun
09h58 Sunday 04 Jun
~E after adding 19 hours
減少時間也是同樣的-你只需要減少相應變數的值即可。
得到兩個不同時間值的差同樣也是非常簡單。你所需要做的只是將兩個時間值轉換為Unix的時間戳值,然後兩者相減即可。兩者之差即為兩個時間所相隔的秒數。另外一些演算法可以很快地將秒轉為天、小時、分和秒。
**為PHP添加DateAdd函數
正如在文章一開始我所說的-寫本文的原因是因為我在PHP中找不到類似ASP的DateDiff函數。在介紹完PHP是如何處理日期和時間,讓我們將ASP中常用的兩個函數移植到PHP。第一個函數是DateAdd。
根據Vbscript的文檔,DateAdd(interval,number,date)函數的定義為「返回已添加指定時間間隔的日期。」
Inetrval為表示要添加的時間間隔字元串表達式,例如分或天;number為表示要添加的時間間隔的個數的數值表達式;Date表示日期。
Interval(時間間隔字元串表達式)可以是以下任意值:
yyyy year年
q Quarter季度
m Month月
y Day of year一年的數
d Day天
w Weekday一周的天數
ww Week of year周
h Hour小時
n Minute分
s Second秒
w、y和d的作用是完全一樣的,即在目前的日期上加一天,q加3個月,ww加7天。
?
function DateAdd ($interval, $number, $date) {
$date_time_array = getdate($date);
$hours = $date_time_array["hours"];
$minutes = $date_time_array["minutes"];
$seconds = $date_time_array["seconds"];
$month = $date_time_array["mon"];
$day = $date_time_array["mday"];
$year = $date_time_array["year"];
switch ($interval) {
case "yyyy": $year +=$number; break;
case "q": $month +=($number*3); break;
case "m": $month +=$number; break;
case "y":
case "d":
case "w": $day+=$number; break;
case "ww": $day+=($number*7); break;
case "h": $hours+=$number; break;
case "n": $minutes+=$number; break;
case "s": $seconds+=$number; break;
}
$timestamp = mktime($hours ,$minutes, $seconds,$month ,$day, $year);
return $timestamp;}
?
我們可以將上面的代碼保存為dateadd.inc文件,然後運行以下代碼:
?
include('dateadd.inc');
$temptime = time();
echo strftime( "%Hh%M %A %d %b",$temptime);
$temptime = DateAdd("n" ,50,$temptime);
echo "p";
echo strftime( "%Hh%M %A %d %b",$temptime);
?
我們將得到:
15h41 Saturday 03 Jun
16h31 Saturday 03 Jun
為PHP添加DateDiff函數
現在DateAdd已經完成,那麼DateDiff呢?
根據文檔,DateDiff(interval,date1,date2)函數的定義為「返回兩個日期之間的時間間隔」。
Intervals參數的用法與DateAdd函數中的相同。出於避免過於復雜的考慮,我們決定忽略Vbscript中DateDiff函數中其它復雜的參數,即其兩個可選的參數變數[firstdayofweek[, firstweekofyear]](它們用於決定星期中第一天是星期天還是星期一和一年中第一周的常數。而且我們只允許intervals有以下五個值:"w"(周)、"d"(天)、"h"(小時)、"n"(分鍾) 和"s"(秒)。
Let's see what we can come up with: 下面的代碼是我們所需要的:
?
Function DateDiff ($interval, $date1,$date2) {
// 得到兩日期之間間隔的秒數
$timedifference = $date2 - $date1;
switch ($interval) {
case "w": $retval = bcdiv($timedifference ,604800); break;
case "d": $retval = bcdiv( $timedifference,86400); break;
case "h": $retval = bcdiv ($timedifference,3600); break;
case "n": $retval = bcdiv( $timedifference,60); break;
case "s": $retval = $timedifference; break;
}
return $retval;}
?
將上面的代碼存為datediff.inc文件,然後運行下面的代碼:
?
include('datediff.inc');
include('dateadd.inc');
$currenttime = time();
echo "Current time: ". strftime("%Hh%M %A %d %b" ,$currenttime)."br";
$newtime = DateAdd ("n",50 ,$currenttime);
echo "Time plus 50 minutes: ". strftime("%Hh%M %A %d %b" ,$newtime)."br";
$temptime = DateDiff ("n",$currenttime ,$newtime);
echo "Interval between two times: ".$temptime;
?
如果一切順利,你可以看到以下結果:
Current time: 16h23 Saturday 03 Jun
Time plus 50 minutes: 17h13 Saturday 03 Jun
Interval between two times: 50
如果你在Unix機器上運行PHP,你必須編譯PHP支持BC高精度函數。你必須從以下地址http://www.php.net/extra/number4.tar.gz下載BC庫,然後將其解壓到PHP4的根目錄下,重新編譯PHP,編譯時要加上--enable-bcmath的選項。(詳細說明見PHP4中README.BCMATH)。PHP4的Windows版本則不需要做任何修補即可直接使用BC高精度函數。
現在你已經得到處理日期和時間的函數,剩下的就是如何將其運用到你的PHP程序中。
php時間顯示例
加入時間:2004-12-18 17:22:53 大小:1 KB 閱讀次數:1564
第一種:簡單(供學慣用)
<?PHP
$today=date("Y-m-d G:i:s");
echo "<center>$today</center>";
?>
第二種:
/*
Format Time
*/
Function formatTime($time,$type="1"){
switch($type){
case 1;#2002-06-0418:58 Tuesday
return date("Y.m.d H:i",$time)."<font color=blue>".date(" l",$time)."</font>";
case 2;#June 2002
return date("M Y",$time);
case 3;#2002-06-04 18:58
return date("Y.m.d H:i",$time);
case 4;#06-04 AM
return date("m-d A",$time);
case 5;#06-04 18:58
return date("m.d H:i",$time);
}
}不知道對於兩個以字元串格式存儲的日期得比較會有什麼結果,例如 『2007-07-12′ 『2007-06-27′ ,這種日期最好用什麼方法來比較呢?就大小而論
leehao July 17th, 2006 1:33 am
/*日期比較*/
$Date_1="2007-07-12";
$Date_2="2007-06-27";
/*
首先用explode這個函數來拆分字元串
explode("這引號裡面是條件來的哦,改成:就會用:來拆分字元串的,可以應用到很多方面去的",後面要拆分的字元串)
*/
$Date_explode_1=explode("-",$Date_1);
$Date_explode_2=explode("-",$Date_2);
/*
拆分後的字元串,我們通過使用mktime函數來計算時間,
必須說明一下的是mktime計算出來的時間是用秒來算的哦,
後面就簡單啦,具體可以看手冊,裡面詳細得很
*/
$Day_1=mktime(0,0,0,$Date_explode_1[1],$Date_explode_1[2],$Date_explode_1[0]);
$Day_2=mktime(0,0,0,$Date_explode_2[1],$Date_explode_2[2],$Date_explode_2[0]);
$Days=round(($Day_1-$Day_2)/3600/24);
echo "您要的結果是 $Days 天哦";
?>
請問如何得到90天以後的日期
加入時間:2004-12-18 18:09:53 大小:1 KB 閱讀次數:158
//獲取今天的時間信息
$Y=date(Y);
$m=date(m);
$d=date(d);
//$m為月,$d為天,$Y為年,"+"號表示之後,用"-"號可以得到多少天前的日期,"Y年m月d日",只是顯示的格式,你可以改成"Y-m-d",
$out_date1=date( "Y年m月d日", mktime(0,0,0,$m,$d+7,$Y) );//一周後
$out_date2=date( "Y年m月d日", mktime(0,0,0,$m,$d+14,$Y) );//二周後
$out_date3=date( "Y年m月d日", mktime(0,0,0,$m+1,$d,$Y) );//一個月後
$out_date4=date( "Y年m月d日", mktime(0,0,0,$m+2,$d,$Y) );//二個月後
$out_date5=date( "Y年m月d日", mktime(0,0,0,$m+3,$d,$Y) );//三個月後
$out_date6=date( "Y年m月d日", mktime(0,0,0,$m+6,$d,$Y) );//六個月後
$out_date7=date( "Y年m月d日", mktime(0,0,0,$m,$d,$Y+1) );//一年後
echo date("Ymd", time() + 90*86400);
echo date("Y-m-d",strtotime("2004-10-26 +90day"));
date("Y-m-d",strtotime("+90 day"));
『貳』 誰懂計算機的凱撒碼 我想知道怎麼代換
這里有方法,自己看吧,比較多,呵呵
[凱撒介紹]
凱撒密碼(kaiser)是羅馬擴張時期朱利斯"凱撒(Julius Caesar)創造的,用於加密通過信使傳遞的作戰命令。它將字母表中的字母移動一定位置而實現加密。
[加密原理]
凱撒密碼的加密演算法極其簡單。其加密過程如下:
在這里,我們做此約定:明文記為m,密文記為c,加密變換記為E(k1,m)(其中k1為密鑰),解行喚密變換記為D(k2,m)(k2為解密密鑰)(在這里k1=k2,不妨記為k)。凱撒密碼的加密過程可記為如下一個變換:
c≡m+k mod n (其中n為基本字元個數)
同樣,解密過程可表示為:
m≡c+k mod n (其中n為基本字元個數)
對於計算機而言,n可取256或128,m、k、c均為一個8bit的二進制數。困襪顯然,這種加密演算法極不安全,即使採用窮舉法,最多也只要255次即可破譯。當然,究其本身而言,仍然是一個單表置換,因此,頻率分析法對其仍是有效的。
[加密演算法]
我們預定義基本字元個數為 #define MAX 128
凱撒加密函數可以表示為
[Copy to clipboard]
CODE:
char cipher(char plain_char, int key)
{
return (plain_char + key) % MAX;
};
凱撒解密函數:
[Copy to clipboard]
CODE:
char decipher(char cipher_char, int key)
{
return (cipher_char - key + MAX) % MAX;
};
加密後,原所有的ASCII碼偏移key位,解密則移回key位。
如果要對一個文本文件進行加密,則只要依次逐個字元逐個字元地讀取文本文件,進行加密後,逐個字元逐個字元寫入密文文本文檔尺凱件中,即可:
[Copy to clipboard]
CODE:
FILE *fp_plaintext;
FILE *fp_ciphertext;
char plain_char;
... ...
while((plain_char=fgetc(fp_plaintext))!=EOF)
{
fputc(cipher(plain_char,key),fp_ciphertext);
}
對文件的解密也同樣方法。
[破解原理]
一篇包含字元的英文文章,其各ASCII碼字元出現,都有一定的頻率,下面是對Google上隨意搜索到的英文文章進行分析的結果,見表:
QUOTE:
=================================================
FileName : 01.txt
[1] 32: times:204
[2] 101:e times:134
[3] 116:t times:91
[4] 105:i times:87
[5] 111:o times:77
[6] 108:l times:75
[7] 97:a times:75
[8] 110:n times:69
[9] 10:
times:67
[10] 115:s times:63
=================================================
FileName : php.si.source.txt
[1] 32: times:576
[2] 101:e times:162
[3] 115:s times:153
[4] 110:n times:141
[5] 114:r times:138
[6] 105:i times:135
[7] 10:
times:134
[8] 116:t times:129
[9] 42:* times:116
[10] 111:o times:103
=================================================
FileName : work.txt
[1] 32: times:51322
[2] 101:e times:30657
[3] 116:t times:23685
[4] 97:a times:19038
[5] 111:o times:17886
[6] 105:i times:16156
[7] 110:n times:15633
[8] 114:r times:15317
[9] 115:s times:15226
[10] 104:h times:12191
=================================================
FileName : 02.txt
[1] 32: times:299
[2] 101:e times:217
[3] 110:n times:136
[4] 105:i times:133
[5] 111:o times:124
[6] 116:t times:116
[7] 97:a times:110
[8] 115:s times:98
[9] 114:r times:92
[10] 108:l times:82
=================================================
FileName : 03.txt
[1] 45:- times:404
[2] 32: times:394
[3] 101:e times:237
[4] 116:t times:196
[5] 114:r times:173
[6] 97:a times:163
[7] 105:i times:161
[8] 110:n times:153
[9] 111:o times:142
[10] 115:s times:129
=================================================
FileName : 04.txt
[1] 32: times:326
[2] 101:e times:179
[3] 116:t times:106
[4] 105:i times:101
[5] 111:o times:96
[6] 110:n times:94
[7] 97:a times:92
[8] 115:s times:78
[9] 100:d times:61
[10] 114:r times:60
=================================================
FileName : 05.txt
[1] 32: times:441
[2] 101:e times:191
[3] 111:o times:151
[4] 116:t times:120
[5] 97:a times:112
[6] 110:n times:108
[7] 105:i times:91
[8] 114:r times:84
[9] 117:u times:79
[10] 115:s times:79
有此分析可知,一篇英文文章中,出現較高頻率的兩個字元是 ' ' (空格) 和 'e',而且它們的ASCII碼分別是32和101,差值是69。
既然凱撒密碼利用的是單表替換的一種簡單加密演算法,所以,我們的主角, ' ' 和 'e' ,在解密後,依然會保持相同的ASCII碼差值,69。
|c1 - c2| = |'e' - ' '| = |101 - 32| = 69
|m1 - m2| = | ((c1 + k) mod 256)-((c2 + k) mod 256)| = |c1 - c2| = |'e' - ' '| = 69
現在可以得到破解凱撒密碼的原理了,我們統計一片經過凱撒加密的密文字元信息,在出現頻率較高的字元裡面尋找差值是69的2個字元,這兩個必定是 ' ' 和 'e' 字元的加密字元,計算偏移量(既密鑰key),通過解密運算,還原出明文。
[破解演算法]
任何一片英文加密後的密文,我們統計出所有字元的個數:
[Copy to clipboard]
CODE:
#define MAX 128
... ...
FILE *fp_ciphertext;
char cipher_char;
int i; //密文文件長度,包含多少字元
unsigned int size_file=0; //申明num數組,存儲各個ASCII字元在密文中出現的個數
num[MAX];
... ...
for(i = 0;i < MAX; i++) //初始化num數組中的值
num[i] = 0;
... ...
while((cipher_char=fgetc(fp_ciphertext))!=EOF)
{
num[cipher_char]++;
size_file++;
}
統計出現最多次數的字元,定義#define GETTOP 10,統計最多的前10位字元:
[Copy to clipboard]
CODE:
//統計前10位
#define GETTOP 10
... ...
int temp,i,j;
int maxascii[GETNUM]; //申明maxascii數組,存儲統計出的概率前10位的字元ascii碼
int maxtimes[GETNUM]; //申明maxtimes數組,存儲統計出的概率前10位的字元的出現次數
... ...
for(i=0;i<GETTOP;i++)
{
temp=0; //臨時變數temp裡面來存儲出現最多次數的字元的ascii碼
for(j=1;j<MAX;j++) //依次比較所有的字元次數,獲得最多字元的ascii碼
{
if(num[j]>=num[temp])
temp=j;
}
maxascii[i]=temp; //把出現最多次數字元的ascii存儲到相應的maxascii數組中
maxtimes[i]=num[temp]; //把最多次數字元的出現次數存儲到相應的maxtimes數組中
num[temp]=0; //把最多次數字元的次數賦值成0,
//進行循環運算,同樣的演算法,第二次循環得到的值,肯定是出現第二多的字元
//避免了對256或128個字元進行排序的復雜運算
//當年我用匯編編寫成績排序的程序時,也用這套排序演算法:-)
}
找出出現最多字元中,ASCII碼差別是69的兩個字元,計算出密鑰key的長度:
[Copy to clipboard]
CODE:
for(i=0;i<GETTOP;i++)
{
for(j=0;j<GETTOP;j++)
{
if((max[i]-max[j])==69)
{
key=(max[j] - 32 + MAX ) % MAX;
printf("Key : %d\n",key);
break;
}
}
}
既然得到了密鑰長度,算完成了對凱撒密碼的破解了,那就進行解密吧,大功告成!