自編程序偽造文件創建時間、修改時間、訪問時間
作者:Tuuzed(土仔)
版權聲明:可以任意轉載,轉載時請務必以超鏈接形式標明文章原始出處和作者信息及本聲明。
http://m.shnenglu.com/tuuzed/archive/2008/02/16/42816.html
一個文件從建立開始,就有了創建時間、修改時間和訪問時間。可是,有時為了不讓別人一眼看出文件已經給修改了,我們需要修改文件的創建時間和修改時間,網上的工具很多,評價比較好的是一款叫touchpro的軟件,據說是已經內嵌在Explorer。商業軟件嘛,要么破解,要么購買。不如自己來做一個吧。
查查VS2005自帶的MSDN Library,發現了兩個關鍵的API函數(在MSDN“查找”欄里輸入關鍵詞“file time”,一切都明白了):GetFileTime、SetFileTime,還有需要了解兩個文件時間結構:FILETIME、SYSTEMTIME。
GetFileTime:獲取文件的創建時間、修改時間和訪問時間。
SetFileTime:設置文件的創建時間、修改時間和訪問時間。
FILETIME:MSDN上說就是記錄從1601年1月1日(UTC)到目前所間隔的時間,是一個64位的值。
SYSTEMTIME:也是記錄時間,這個時間格式接近我們日常的時間格式,有年月日等。
獲取文件時間:
計算機是利用FILETIME結構來記錄文件的創建時間,如果要變為容易識別的時間格式SYSTEMTIME,則需要用到FileTimeToSystemTime函數。這個時候得到的SYSTEMTIME還不是我們當前計算機的時間,而是UTC時間。當地的時間,需要用SystemTimeToTzSpecificLocalTime函數得到。
修改文件時間:
已經知道如何獲取文件的時間了,那么接下來修改就好辦了。自己構造一個SYSTEMTIME結構的時間,然后用TzSpecificLocalTimeToSystemTime轉成UTC格式的SYSTEMTIME,最后用SystemTimeToFileTime轉成FILETIME格式。
自己的程序SFT.EXE(鼠標右鍵另存):
ShowDateTime:顯示文件的創建、修改、訪問時間。
SetDateTime:設置文件的創建、修改、訪問時間。
ParseTime:將時間格式化顯示。
FileTimeToLocalSystemTime、LocalSystemTimeToFileTime:將一些API函數直接串接在一起。
int ShowDateTime(HANDLE hFile)2


{3
if (hFile==NULL) return 0;4

5
FILETIME ftCreTime, ftAccTime, ftWriTime;6
//get file time7

8
if(GetFileTime(hFile, &ftCreTime,&ftAccTime,&ftWriTime))9

{10
SYSTEMTIME stLOCCreTime, stLOCAccTime, stLOCWriTime;11

12
FileTimeToLocalSystemTime(&ftCreTime, &stLOCCreTime);13
FileTimeToLocalSystemTime(&ftAccTime, &stLOCAccTime);14
FileTimeToLocalSystemTime(&ftWriTime, &stLOCWriTime);15

16
//Build a string to show time and date.17
char CreTime[MAX_DATETIME];18
char AccTime[MAX_DATETIME];19
char WriTime[MAX_DATETIME];20
ParseTime(&stLOCCreTime, CreTime);21
ParseTime(&stLOCAccTime, AccTime);22
ParseTime(&stLOCWriTime, WriTime);23

24
//print result25
cout << "====================================="<<endl;26
cout << "CreationTime: " << CreTime << endl;27
cout << "AccessTime: " << AccTime << endl;28
cout << "WriteTime: " << WriTime << endl;29
return 1;30
}31
else32

{33
return 0;34
}35
36
}37

38
int SetDateTime(HANDLE hFile, char *pDate, char *pTime)39


{40
int result=0;41
if (hFile==NULL || (pDate==NULL && pTime==NULL)) return result;42

43
FILETIME ftCreTime, ftAccTime, ftWriTime;44
result=GetFileTime(hFile, &ftCreTime,&ftAccTime,&ftWriTime);45
if (result==0)46
return result;47

48
SYSTEMTIME stLOCCreTime, stLOCAccTime, stLOCWriTime;49
FileTimeToLocalSystemTime(&ftCreTime, &stLOCCreTime);50
FileTimeToLocalSystemTime(&ftAccTime, &stLOCAccTime);51
FileTimeToLocalSystemTime(&ftWriTime, &stLOCWriTime);52

53
int wYear=2008, wMonth=2, wDay=11, wHour=0, wMinute=0, wSecond=0;54
if (pDate!=NULL)55

{56
sscanf(pDate, "%d-%d-%d", &wYear, &wMonth, &wDay);57
#ifdef _DEBUG58
cout<<"Year:"<<wYear<<"Month:"<<wMonth<<"Day:"<<wDay<<endl;59
#endif 60
stLOCCreTime.wYear=wYear;61
stLOCCreTime.wMonth=wMonth;62
stLOCCreTime.wDay=wDay;63
stLOCAccTime.wYear=wYear;64
stLOCAccTime.wMonth=wMonth;65
stLOCAccTime.wDay=wDay;66
stLOCWriTime.wYear=wYear;67
stLOCWriTime.wMonth=wMonth;68
stLOCWriTime.wDay=wDay;69
}70

71
if (pTime!=NULL)72

{73
sscanf(pTime, "%d:%d:%d", &wHour, &wMinute, &wSecond);74
#ifdef _DEBUG75
cout<<"Hour:"<<wHour<<"Minute:"<<wMinute<<"Second:"<<wSecond<<endl;76
#endif 77
stLOCCreTime.wHour=wHour;78
stLOCCreTime.wMinute=wMinute;79
stLOCCreTime.wSecond=wSecond;80
stLOCAccTime.wHour=wHour;81
stLOCAccTime.wMinute=wMinute;82
stLOCAccTime.wSecond=wSecond;83
stLOCWriTime.wHour=wHour;84
stLOCWriTime.wMinute=wMinute;85
stLOCWriTime.wSecond=wSecond;86
}87

88
result=LocalSystemTimeToFileTime(&stLOCCreTime, &ftCreTime);89
if (result==0) return result;90
LocalSystemTimeToFileTime(&stLOCAccTime, &ftAccTime);91
if (result==0) return result;92
LocalSystemTimeToFileTime(&stLOCWriTime, &ftWriTime);93
if (result==0) return result;94

95
result=SetFileTime(hFile, &ftCreTime, &ftAccTime, &ftWriTime);96
if (result==0) return result;97
return result;98
}99

100
void ParseTime(SYSTEMTIME *in_st, char *out_string)101


{102

char *DayOfWeek[]=
{"Sun", "Mon", "Tue","Wed","Thu","Fri","Sat"};103
wsprintf(out_string, "%d-%d-%d %s %d:%d:%d", in_st->wYear, in_st->wMonth, in_st->wDay, \104
DayOfWeek[in_st->wDayOfWeek], \105
in_st->wHour, in_st->wMinute, in_st->wSecond);106
}107

108
int FileTimeToLocalSystemTime(const FILETIME *pFileTime , SYSTEMTIME *pLocSystemTime)109


{110
int result=0;111
SYSTEMTIME tmpSystemTime;112
result=FileTimeToSystemTime(pFileTime, &tmpSystemTime);113

if (result!=0)
{114
result=SystemTimeToTzSpecificLocalTime(NULL,&tmpSystemTime, pLocSystemTime);115
return result;116
}117
else118
return result;119
}120

121
int LocalSystemTimeToFileTime(const SYSTEMTIME *pLocSystemTime, FILETIME *pFileTime)122


{123
int result=0;124
FILETIME tmpFileTime;125
result=SystemTimeToFileTime(pLocSystemTime, &tmpFileTime);126

if (result!=0)
{127
result=LocalFileTimeToFileTime(&tmpFileTime, pFileTime);128
return result;129
}130
else131
return result;132
}133

UTC:協調世界時(Universal Time Coordinated),過去曾用格林威治平均時(GMT)來表示。UTC is the high-precision atomic clock version of GMT (Greenwich Mean Time).


