文件查找

Struct Lnode{

Char table[256];         //保存文件夹名

Struct Lnode*next;

}

加文件夹入链表

Lnode *newList;

Void AddList(char *list)          //list为文件夹名

{

NewList=new Lnode;

Strcpy(NewList->table,list);

newList->next=NULL;

if(h->next==NULL)

h->next=newList;       //h为头结点

else

{

r->next=newList;        //r始终指向尾节点

r=newList;

}

}

FindFirstFile和FindNextFile

HANDLE   FindFirstFile{

LPCTSTR  IpFileName; //指向要查找的文件名(包含路径)

LPWIN32_FIND_DATA IpFindFileData;   //输出参数,指向一个结构。此结构可以描述找到的文件或文件夹的属性。

}

函数调用成功则返回可供函数FindNextFile和函数FindClose使用的查找句柄,否则返回INVALID_HANDLE_VALUE;

Typedef struct _WIN32_FIND_DATA{

DWORD dwFileAttributes;     //文件属性

FILETIME ftCreationTime;     //创建文件的时间

FILETIME ftLastAccessTime;    //最近一次访问文件的时间

FILETIME ftLastWriteTime;    //最近一次修改文件的时间

DWORD nFileSizeHigh        //文件大小的高位字

DWORD nFileSizeLow;        //文件大小的地位字

DWORD dwReserved0;       //保留,未使用

DWORD dwReserved1;       //保留,未使用

TCHAR cFileName[MAX_PATH];    //文件的名称

TCHAR cAlternateFileName[14];    //文件的替换名称,用文件名.后缀名表示

} WIN32_FIND_DATA,*p WIN32_FIND_DATA;

BOOL  FindNextFile   {

HANDLE  hFindFile;      //此参数指向了函数FindFirstFile返回的查找句柄

LPWIN32_FIND_DATA IpFindFileData;

}

函数调用成功则返回可供函数FindNextFile和函数FindClose使用的查找句柄,否则返回INVALID_HANDLE_VALUE;

查找文件一般使用的结构

hFindFile=FindFirstFile(IpFileName,&IpFindData);

if(hFindFile!=INVALID_HANDLE_VALUE)

{

Do

{

}while(FindNextFile(hFindFile,&findData))

}

遍历目录

Void FindFile(char *pRoad,char *pFile)

//pRoad为要查找的路径,pFile为要查找的文件

{

Char FileRoad[256]={0};//要查找文件的路径

Char DirRoad[256]={0};//存放要查找的路径

Char FindedFile[256]={0};

Char FindedDir[256]={0};//存放找到的是文件夹的路径

Strcpy(FileRoad,pRoad);

Strcpy(DirRoad,pRoad);

Strcat(DirRoad,”\\*.*”);

//查找文件,把找到的放入文件夹链表

WIN32_FIND_DATA findData;

HANDLE hFindFile;

hFindFile=FindFirstFile(DirRoad,&findData);

if(hFindFile!=INVALID_HANDLE_VALUE)

{

Do

{

If(findData.cFileName[0]==’.’)

Continue;

If(findData.dwFileAttributes&FILE_ATTRIBUTE_DIRECTORY)

{

Strcpy(FindedDir,pRoad);

Strcat(FindedDir,”\\”);

Strcat(FindDir,findData.cFileName);

AddList(FindDir);

Memset(FindDir,0x00,256);

}

}while(FindNextFile(hFindFile,&findData));

}

Strcat(FileRoad,”\\”);

Strcat(FileRoad,pFile);

//查找要查找的文件

hFindFile=FindFirstFile(FileRoad,&findData);

if(hFindFile!=INVALID_HANDLE_VALUE)

{

Do{

Strcpy(FindedFile,pRoad);

Strcat(FindedFile,”\\”);

Strcat(FindedFile,findData.cFileName);

Printf(“%s\n”,FindedFile);

Memset(FindedFile,0x00,256);

}while(FindNextFile(hFindFile,&findData));

}

}

Int searchFile(char * Directory,char *SeachFile)

{

Lnode newList;

Strcpy(newList->table,Directory);

newList->next=NULL;

while(true)

{

Lnode *Find;

If(r->next!=NULL)

{

Find=r->next;

r->next=r->next->next;

FindFile(Find->table,searchFile);

}

Else

{

Printf(“文件搜索完毕\n”);

Return 0;

}

}

Return 0;

}

函数FindFirstFile的更多相关文章

  1. [php代码审计] Window api函数 FindFirstFile 在php中的问题

    include文件夹中文件: 内容: <?php echo __FILE__; ?> index.php: 演示如下: “<<”替换多个任意字符: “>”替换单个字符:

  2. c#调用api(FindFirstFile,FindNextFile)高效遍历目录文件【转载】

    在c#下遍历目录,应用最多的应该就是 System.IO.DirectoryInfo.GetDirectories或GetFiles了,但是当目录特别大,文件特别多时,效率不尽人意,此时我们很容易想到 ...

  3. windows中操作文件和目录的函数

    1.文件操作函数       CreateFile();//创建或打开文件      ReadFile();//从文件读      WriteFile();//向文件写      SetFilePoi ...

  4. Windows FindFirstFile利用

    目前大多数程序都会对上传的文件名加入时间戳等字符再进行MD5,然后下载文件的时候通过保存在数据库里的文件ID读取文件路径,一样也实现了文件下载,这样我们就无法直接得到我们上传的webshell文件路径 ...

  5. C/C++ 中判断某一文件或目录是否存在

    方法一:C++中比较简单的一种办法(使用文件流打开文件) #include <iostream> #include <fstream> using namespace std; ...

  6. php黑魔法之解析问题

    code如下: <?php $a=$_GET[a]; $b=is_file($a); var_dump($b); ?> 可以看到1.ph< 返回了true 这样不就可以绕过这个的过滤 ...

  7. Deformity PHP Webshell、Webshell Hidden Learning

    目录 . 引言 . webshell原理介绍 . webshell的常见类型以及变种方法 . webshell的检测原理以及检测工具 . webshell隐藏反检测对抗手段 0. 引言 本文旨在研究W ...

  8. 在windows 、linux下读取目录下所有文件名

    Windows要引入的头文件是<Windows.h> 主要是两个函数FindFirstFile.FindNextFile MSDN里是这么说的: FindFirstFile functio ...

  9. SIFT算法的应用--目标识别之Bag-of-words模型

    原文:http://blog.csdn.net/v_JULY_v/article/details/6555899 SIFT算法的应用 -目标识别之用Bag-of-words模型表示一幅图像 作者:wa ...

随机推荐

  1. digitalocean开通德国法兰克福机房,40Gb带宽,支持IPv6

    2015年4月15日,vps服务商digitalocean宣布正式开通德国法兰克福机房.5个月前digitalocean宣布筹备Germany机房中心,经过近1个月部署,总算与用户见面了.Frankf ...

  2. vc中主线程等待子线程退出的方法

    VC线程同步,在子线程中等待另一子线程结束,通过WaitForSingleObject可以实现,但是如果在主线程中等待子线程结束,这个函数是无法完成要求的,因为它会造成主线程挂起,导致程序死掉.我们可 ...

  3. SharePoint 2013 InfoPath 无法保存下列表单

    转载自:http://www.cnblogs.com/jianyus/p/3470121.html 在使用InfoPath发布表单,发布到SharePoint服务器报错,如下介绍: 环境:Window ...

  4. mysql高级查询

    高级查询: 1.连接查询 select * from Info,Nation #得出的结果称为笛卡尔积select * from Info,Nation where Info.Nation = Nat ...

  5. 设正整数n的十进制表示为n=ak……a1a0(0<=ai<=9,0<=i<=k,ak!=0),n的个位为起始数字的数字的正负交错之和T(n)=a0+a1+……+(-1)kak,证明:11|n的充分必要条件是11|T(n);(整除理论1.1.2))

    设正整数n的十进制表示为n=ak……a1a0(0<=ai<=9,0<=i<=k,ak!=0),n的个位为起始数字的数字的正负交错之和T(n)=a0+a1+……+(-1)kak, ...

  6. 一些常见warning的原因和解决方法

    在入职三周后,终于赶齐了接手项目落下两个月的项目,有了一些自己的空闲时间对项目进行整理.主要整理包括类目的整合,从原来一个系统文件夹下几百个文件整改为以MVC设计思想为原则的分文件夹整理类目,井然有序 ...

  7. CF/div2c/贪心

    题目链接[http://codeforces.com/contest/749/problem/C] 题意:给出一个长度为n序列包含D和R,每一轮操作的先后顺序是1-n,规则是每一轮每个人有一次机会杀掉 ...

  8. javascript中函数的call,apply及bind方法

    call 方法调用一个对象的一个方法,以另一个对象替换当前对象.call([thisObj[,arg1[, arg2[,  [,.argN]]]]])参数thisObj可选项.将被用作当前对象的对象. ...

  9. PHPExcel解决内存占用过大问题-dw 查找memoryCacheSize把1M改为2048M

    http://blog.sina.com.cn/s/blog_4ec7952d0101fcrd.html PHPExcel解决内存占用过大问题-设置单元格对象缓存 PHPExcel是一个很强大的处理E ...

  10. 嵌套表SHAPE

    SQL语法 SHAPE {<master query>} APPEND ({ <child table query> } RELATE <master column> ...