文件查找

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. IOS开发—UITableView重用机制的了解

    引言 对于一个UITableView而言,可能需要显示成百上千个Cell,如果每个cell都单独创建的话,会消耗很大的内存.为了避免这种情况,重用机制就诞生了. 假设某个UITableView有100 ...

  2. 【编码问题】if,for语句与中文编码

    1. 首先先来说说中文的问题.众所周知,作死的python经常和中文过不去 每次,开头必须声明 # coding: utf-8 或者是 # -*- coding: utf-8  -*- 然而,被坑过的 ...

  3. ios中判断当前手机的网络状态

    typedef enum {    NETWORK_TYPE_NONE= 0,    NETWORK_TYPE_2G= 1,    NETWORK_TYPE_3G= 2,    NETWORK_TYP ...

  4. 使用日志记录功能查看PHP扩展的执行过程

    了解过PHP内核的同学都知道,PHP的一次请求的生命周期 1.启动Apache后,PHP解释程序也随之启动.PHP调用各个扩展的MINIT方法,从而使这些扩展切换到可用状态 2.当一个页面请求发生时, ...

  5. grub4dos新手指南-2

    Grub4dos 新手指南 一.GRUB4DOS的配置文件Grub4dos 有三个文件,grldr.grldr.mbr和menu.lst,配置文件是menu.lst,和GRUB一样.该文件一般放在和启 ...

  6. forEach用法介绍

    array.forEach(callback[, thisArg]) forEach() 方法让数组的每一项都执行一次给定的函数. callback在数组每一项上执行的函数,接收三个参数: curre ...

  7. CRC的校验原理

    一.基本原理 CRC检验原理实际上就是在一个p位二进制数据序列之后附加一个r位二进制检验码(序列),从而构成一个总长为n=p+r位的二进制序列:附加在数据序列之后的这个检验码与数据序列的内容之间存在着 ...

  8. android 进程(复习)

        前台进程 前台进程是用户当前正在使用的进程.只有一些前台进程可以在任何时候都存在.他们是最后一个被结束的,当内存低到根本连他们都不能运行的时候.一般来说, 在这种情况下,设备会进行内存调度,中 ...

  9. POJ 2516 Minimum Cost

    每个物品分开做最小费用最大流. #include<cstdio> #include<cstring> #include<cmath> #include<vec ...

  10. 入门级(python)

    1.素数,求1-100之间的素数(想在代码中写中文注释,加一句#coding=utf-8,注意等号左右没空格) def isPrime(n): if(n == 1): return False els ...