復制代碼 代碼如下:
/*3389登錄日志清除軟件*/
#include <windows.h>
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
void Usage(char *progname);
void OpenKey(char *key);
void DelKey(char *key,char *value);
void QueryKey(char *key,char *value);
void ValidateArgs(int argc, char **argv);
int j=1;
int main(int argc, char** argv)
{
//解析命令行輸入:
ValidateArgs(argc, argv);
return 0;
}
//輸出幫助的典型方法:
void Usage (char *progname)
{
fprintf(stdout,"===============================================================================\n"
"\t名稱:3389登錄日志清除軟件\n"
"\t舉例: clear3389 -h\n"
"\t \"clear3389 -h\" //幫助信息\n"
"\t \"clear3389 -a\" //顯示本機3389所有登錄記錄\n"
"\t \"clear3389 -d MRU9\" //刪除指定的3389登錄記錄\n"
"===============================================================================\n");
exit(0);
}
//解析命令行輸入的典型方法:
void ValidateArgs(int argc, char **argv)
{
//打開指定的注冊表鍵:
char *Key="Software\\Microsoft\\Terminal Server Client\\Default";
char buff[100]={0};
int i,i1,length;
if(argc<2)
{
Usage(argv[0]);
}
for(i=1;i<argc;i++)
{
if ((argv[i][0] == '-') || (argv[i][0] == '/'))
{
switch (tolower(argv[i][1])) //轉換成小寫字母
{
case 'd': //刪除指定的3389登錄記錄
if (argc!=3)
Usage(argv[0]);
strcpy(buff,argv[2]);
length = strlen(argv[2]);
for (i1=0; i1<length; i1++)
{
buff[i1] = toupper(buff[i1]);
}
//printf("buff=%s\n",buff);
QueryKey(Key,buff);
exit(0);
case 'h'://打印幫助
Usage(argv[0]);
exit(0);
case 'a': //顯示本機3389所有登錄記錄
if (argc!=2)
Usage(argv[0]);
OpenKey(Key);
exit(0);
default:
Usage(argv[0]);
return;
}
}
}
printf("繼續...\n");
return;
}
//下面是列出所有鍵值:
void OpenKey(char *key)
{
HKEY hkey;//注冊表鍵值的句柄
DWORD dwIndex=0,Index=0,lpcbname=1000,ret=0,Type=0,namesize=1500;
char *T_name=(char *)malloc(1000);
unsigned char *name=(unsigned char *)malloc(1500);//保存子鍵名的字符數組
int i=0;
//下面是字符數組清0:
//ZeroMemory(Buffer,1000);
//ZeroMemory(T_name,1000);
ret=RegOpenKeyEx(HKEY_CURRENT_USER, //根鍵名或已打開項的句柄
key, //傳遞一個參數,欲打開的注冊表項
0, //未用,設為0即可
KEY_ALL_ACCESS, //描述新鍵值安全性的訪問掩碼
//它們的組合描述了允許對這個項進行哪些操作
&hkey); //裝載上面打開項的句柄
//printf("ret=%x\n",ret);
if(ret!=ERROR_SUCCESS) {
printf("RegOpenKeyEx error! %x\n",GetLastError());
return ;
}
printf("\n(%d)本機的3389登錄項目為:\n",j++);
printf("key=HKEY_CURRENT_USER\\%s\n",key);
for(i=1;ret==ERROR_SUCCESS;i++,dwIndex++)//遍歷子鍵中的每個值
{
ret=RegEnumValue(hkey,dwIndex,T_name,&lpcbname,
NULL,&Type,name,&namesize);
//dwIndex:欲獲取的子項的索引。第一個子項的索引編號為零
//T_name:用于裝載指定索引處項名的一個緩沖區
//&lpcbname:指定一個變量,用于裝載lpName緩沖區的實際長度(包括空字符)。
if(Type==REG_SZ)
{
printf("%d.數值名稱:%s\n",i,T_name);
printf(" 數值鍵值:\"%s\"\n",name);
printf(" 數據類型:REG_SZ\n\n");
}
if(Type==REG_DWORD)
{
printf("類型為REG_DWORD!\n");
}
ZeroMemory(T_name,1000);
lpcbname=1000;
ZeroMemory(name,1500);
namesize=1500;
}
RegCloseKey(hkey); //關閉注冊鍵
free(T_name);
free(name);
}
//下面是查詢指定的鍵值:
void QueryKey(char *key,char *value)
{
HKEY hkey;//注冊表鍵值的句柄
DWORD dwIndex=0,Index=0,lpcbname=1000,ret=0,Type=0,namesize=1500;
char *T_name=(char *)malloc(1000);
unsigned char *name=(unsigned char *)malloc(1500);//保存子鍵名的字符數組
int i=0,ret1=0;
//下面是字符數組清0:
//ZeroMemory(Buffer,1000);
//ZeroMemory(T_name,1000);
ret=RegOpenKeyEx(HKEY_CURRENT_USER, //根鍵名或已打開項的句柄
key, //傳遞一個參數,欲打開的注冊表項
0, //未用,設為0即可
KEY_ALL_ACCESS, //描述新鍵值安全性的訪問掩碼
//它們的組合描述了允許對這個項進行哪些操作
&hkey); //裝載上面打開項的句柄
//printf("ret=%x\n",ret);
if(ret!=ERROR_SUCCESS) {
printf("RegOpenKeyEx error! %x\n",GetLastError());
return ;
}
printf("\n(%d)本機的3389登錄項目為:\n",j++);
printf("key=HKEY_CURRENT_USER\\%s\n",key);
for(i=1;ret==ERROR_SUCCESS;i++,dwIndex++)//遍歷子鍵中的每個值
{
ret=RegEnumValue(hkey,dwIndex,T_name,&lpcbname,
NULL,&Type,name,&namesize);
//dwIndex:欲獲取的子項的索引。第一個子項的索引編號為零
//T_name:用于裝載指定索引處項名的一個緩沖區
//&lpcbname:指定一個變量,用于裝載lpName緩沖區的實際長度(包括空字符)
if(stricmp(T_name,value)==0){
if(Type==REG_SZ)
{
printf("%d.數值名稱:%s\n",i,T_name);
printf(" 數值鍵值:\"%s\"\n",name);
printf(" 數據類型:REG_SZ\n\n");
ret1=1;
DelKey(key,value);
}
if(Type==REG_DWORD)
{
printf("類型為REG_DWORD!\n");
}
}
ZeroMemory(T_name,1000);
lpcbname=1000;
ZeroMemory(name,1500);
namesize=1500;
}
if(!ret1)
{ printf("\n注意:數值名稱%s不存在,請重新輸入,注意大小寫!\n",value);
}
RegCloseKey(hkey); //關閉注冊鍵
free(T_name);
free(name);
}
//下面是刪除指定的鍵值:
void DelKey(char *key,char *value)
{
HKEY hkey;
DWORD ret;
ret=RegOpenKeyEx(HKEY_CURRENT_USER, //根鍵名或已打開項的句柄
key, //傳遞一個參數,欲打開的注冊表項
0, //未用,設為0即可
KEY_ALL_ACCESS, //描述新鍵值安全性的訪問掩碼
//它們的組合描述了允許對這個項進行哪些操作
&hkey); //裝載上面打開項的句柄
if(ret!=ERROR_SUCCESS) {
printf("RegOpenKeyEx error! %x\n",GetLastError());
return ;
}
ret=RegDeleteValue(hkey, value);
if(ret!=ERROR_SUCCESS) {
printf("RegDeleteValue %s error! %x\n",value,GetLastError());
return ;
}
printf("RegDeleteValue %s success!\n",value);
RegCloseKey(hkey);
}
//-------------------------------------------------
/*3389登錄日志清除軟件*/
#include <windows.h>
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
void Usage(char *progname);
void OpenKey(char *key);
void DelKey(char *key,char *value);
void QueryKey(char *key,char *value);
void ValidateArgs(int argc, char **argv);
int j=1;
int main(int argc, char** argv)
{
//解析命令行輸入:
ValidateArgs(argc, argv);
return 0;
}
//輸出幫助的典型方法:
void Usage (char *progname)
{
fprintf(stdout,"===============================================================================\n"
"\t名稱:3389登錄日志清除軟件\n"
"\t舉例: clear3389 -h\n"
"\t \"clear3389 -h\" //幫助信息\n"
"\t \"clear3389 -a\" //顯示本機3389所有登錄記錄\n"
"\t \"clear3389 -d MRU9\" //刪除指定的3389登錄記錄\n"
"===============================================================================\n");
exit(0);
}
//解析命令行輸入的典型方法:
void ValidateArgs(int argc, char **argv)
{
//打開指定的注冊表鍵:
char *Key="Software\\Microsoft\\Terminal Server Client\\Default";
char buff[100]={0};
int i,i1,length;
if(argc<2)
{
Usage(argv[0]);
}
for(i=1;i<argc;i++)
{
if ((argv[i][0] == '-') || (argv[i][0] == '/'))
{
switch (tolower(argv[i][1])) //轉換成小寫字母
{
case 'd': //刪除指定的3389登錄記錄
if (argc!=3)
Usage(argv[0]);
strcpy(buff,argv[2]);
length = strlen(argv[2]);
for (i1=0; i1<length; i1++)
{
buff[i1] = toupper(buff[i1]);
}
//printf("buff=%s\n",buff);
QueryKey(Key,buff);
exit(0);
case 'h'://打印幫助
Usage(argv[0]);
exit(0);
case 'a': //顯示本機3389所有登錄記錄
if (argc!=2)
Usage(argv[0]);
OpenKey(Key);
exit(0);
default:
Usage(argv[0]);
return;
}
}
}
printf("繼續...\n");
return;
}
//下面是列出所有鍵值:
void OpenKey(char *key)
{
HKEY hkey;//注冊表鍵值的句柄
DWORD dwIndex=0,Index=0,lpcbname=1000,ret=0,Type=0,namesize=1500;
char *T_name=(char *)malloc(1000);
unsigned char *name=(unsigned char *)malloc(1500);//保存子鍵名的字符數組
int i=0;
//下面是字符數組清0:
//ZeroMemory(Buffer,1000);
//ZeroMemory(T_name,1000);
ret=RegOpenKeyEx(HKEY_CURRENT_USER, //根鍵名或已打開項的句柄
key, //傳遞一個參數,欲打開的注冊表項
0, //未用,設為0即可
KEY_ALL_ACCESS, //描述新鍵值安全性的訪問掩碼
//它們的組合描述了允許對這個項進行哪些操作
&hkey); //裝載上面打開項的句柄
//printf("ret=%x\n",ret);
if(ret!=ERROR_SUCCESS) {
printf("RegOpenKeyEx error! %x\n",GetLastError());
return ;
}
printf("\n(%d)本機的3389登錄項目為:\n",j++);
printf("key=HKEY_CURRENT_USER\\%s\n",key);
for(i=1;ret==ERROR_SUCCESS;i++,dwIndex++)//遍歷子鍵中的每個值
{
ret=RegEnumValue(hkey,dwIndex,T_name,&lpcbname,
NULL,&Type,name,&namesize);
//dwIndex:欲獲取的子項的索引。第一個子項的索引編號為零
//T_name:用于裝載指定索引處項名的一個緩沖區
//&lpcbname:指定一個變量,用于裝載lpName緩沖區的實際長度(包括空字符)。
if(Type==REG_SZ)
{
printf("%d.數值名稱:%s\n",i,T_name);
printf(" 數值鍵值:\"%s\"\n",name);
printf(" 數據類型:REG_SZ\n\n");
}
if(Type==REG_DWORD)
{
printf("類型為REG_DWORD!\n");
}
ZeroMemory(T_name,1000);
lpcbname=1000;
ZeroMemory(name,1500);
namesize=1500;
}
RegCloseKey(hkey); //關閉注冊鍵
free(T_name);
free(name);
}
//下面是查詢指定的鍵值:
void QueryKey(char *key,char *value)
{
HKEY hkey;//注冊表鍵值的句柄
DWORD dwIndex=0,Index=0,lpcbname=1000,ret=0,Type=0,namesize=1500;
char *T_name=(char *)malloc(1000);
unsigned char *name=(unsigned char *)malloc(1500);//保存子鍵名的字符數組
int i=0,ret1=0;
//下面是字符數組清0:
//ZeroMemory(Buffer,1000);
//ZeroMemory(T_name,1000);
ret=RegOpenKeyEx(HKEY_CURRENT_USER, //根鍵名或已打開項的句柄
key, //傳遞一個參數,欲打開的注冊表項
0, //未用,設為0即可
KEY_ALL_ACCESS, //描述新鍵值安全性的訪問掩碼
//它們的組合描述了允許對這個項進行哪些操作
&hkey); //裝載上面打開項的句柄
//printf("ret=%x\n",ret);
if(ret!=ERROR_SUCCESS) {
printf("RegOpenKeyEx error! %x\n",GetLastError());
return ;
}
printf("\n(%d)本機的3389登錄項目為:\n",j++);
printf("key=HKEY_CURRENT_USER\\%s\n",key);
for(i=1;ret==ERROR_SUCCESS;i++,dwIndex++)//遍歷子鍵中的每個值
{
ret=RegEnumValue(hkey,dwIndex,T_name,&lpcbname,
NULL,&Type,name,&namesize);
//dwIndex:欲獲取的子項的索引。第一個子項的索引編號為零
//T_name:用于裝載指定索引處項名的一個緩沖區
//&lpcbname:指定一個變量,用于裝載lpName緩沖區的實際長度(包括空字符)
if(stricmp(T_name,value)==0){
if(Type==REG_SZ)
{
printf("%d.數值名稱:%s\n",i,T_name);
printf(" 數值鍵值:\"%s\"\n",name);
printf(" 數據類型:REG_SZ\n\n");
ret1=1;
DelKey(key,value);
}
if(Type==REG_DWORD)
{
printf("類型為REG_DWORD!\n");
}
}
ZeroMemory(T_name,1000);
lpcbname=1000;
ZeroMemory(name,1500);
namesize=1500;
}
if(!ret1)
{ printf("\n注意:數值名稱%s不存在,請重新輸入,注意大小寫!\n",value);
}
RegCloseKey(hkey); //關閉注冊鍵
free(T_name);
free(name);
}
//下面是刪除指定的鍵值:
void DelKey(char *key,char *value)
{
HKEY hkey;
DWORD ret;
ret=RegOpenKeyEx(HKEY_CURRENT_USER, //根鍵名或已打開項的句柄
key, //傳遞一個參數,欲打開的注冊表項
0, //未用,設為0即可
KEY_ALL_ACCESS, //描述新鍵值安全性的訪問掩碼
//它們的組合描述了允許對這個項進行哪些操作
&hkey); //裝載上面打開項的句柄
if(ret!=ERROR_SUCCESS) {
printf("RegOpenKeyEx error! %x\n",GetLastError());
return ;
}
ret=RegDeleteValue(hkey, value);
if(ret!=ERROR_SUCCESS) {
printf("RegDeleteValue %s error! %x\n",value,GetLastError());
return ;
}
printf("RegDeleteValue %s success!\n",value);
RegCloseKey(hkey);
}