函数FindFirstFile
文件查找
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的更多相关文章
- [php代码审计] Window api函数 FindFirstFile 在php中的问题
include文件夹中文件: 内容: <?php echo __FILE__; ?> index.php: 演示如下: “<<”替换多个任意字符: “>”替换单个字符:
- c#调用api(FindFirstFile,FindNextFile)高效遍历目录文件【转载】
在c#下遍历目录,应用最多的应该就是 System.IO.DirectoryInfo.GetDirectories或GetFiles了,但是当目录特别大,文件特别多时,效率不尽人意,此时我们很容易想到 ...
- windows中操作文件和目录的函数
1.文件操作函数 CreateFile();//创建或打开文件 ReadFile();//从文件读 WriteFile();//向文件写 SetFilePoi ...
- Windows FindFirstFile利用
目前大多数程序都会对上传的文件名加入时间戳等字符再进行MD5,然后下载文件的时候通过保存在数据库里的文件ID读取文件路径,一样也实现了文件下载,这样我们就无法直接得到我们上传的webshell文件路径 ...
- C/C++ 中判断某一文件或目录是否存在
方法一:C++中比较简单的一种办法(使用文件流打开文件) #include <iostream> #include <fstream> using namespace std; ...
- php黑魔法之解析问题
code如下: <?php $a=$_GET[a]; $b=is_file($a); var_dump($b); ?> 可以看到1.ph< 返回了true 这样不就可以绕过这个的过滤 ...
- Deformity PHP Webshell、Webshell Hidden Learning
目录 . 引言 . webshell原理介绍 . webshell的常见类型以及变种方法 . webshell的检测原理以及检测工具 . webshell隐藏反检测对抗手段 0. 引言 本文旨在研究W ...
- 在windows 、linux下读取目录下所有文件名
Windows要引入的头文件是<Windows.h> 主要是两个函数FindFirstFile.FindNextFile MSDN里是这么说的: FindFirstFile functio ...
- SIFT算法的应用--目标识别之Bag-of-words模型
原文:http://blog.csdn.net/v_JULY_v/article/details/6555899 SIFT算法的应用 -目标识别之用Bag-of-words模型表示一幅图像 作者:wa ...
随机推荐
- IOS开发—UITableView重用机制的了解
引言 对于一个UITableView而言,可能需要显示成百上千个Cell,如果每个cell都单独创建的话,会消耗很大的内存.为了避免这种情况,重用机制就诞生了. 假设某个UITableView有100 ...
- 【编码问题】if,for语句与中文编码
1. 首先先来说说中文的问题.众所周知,作死的python经常和中文过不去 每次,开头必须声明 # coding: utf-8 或者是 # -*- coding: utf-8 -*- 然而,被坑过的 ...
- ios中判断当前手机的网络状态
typedef enum { NETWORK_TYPE_NONE= 0, NETWORK_TYPE_2G= 1, NETWORK_TYPE_3G= 2, NETWORK_TYP ...
- 使用日志记录功能查看PHP扩展的执行过程
了解过PHP内核的同学都知道,PHP的一次请求的生命周期 1.启动Apache后,PHP解释程序也随之启动.PHP调用各个扩展的MINIT方法,从而使这些扩展切换到可用状态 2.当一个页面请求发生时, ...
- grub4dos新手指南-2
Grub4dos 新手指南 一.GRUB4DOS的配置文件Grub4dos 有三个文件,grldr.grldr.mbr和menu.lst,配置文件是menu.lst,和GRUB一样.该文件一般放在和启 ...
- forEach用法介绍
array.forEach(callback[, thisArg]) forEach() 方法让数组的每一项都执行一次给定的函数. callback在数组每一项上执行的函数,接收三个参数: curre ...
- CRC的校验原理
一.基本原理 CRC检验原理实际上就是在一个p位二进制数据序列之后附加一个r位二进制检验码(序列),从而构成一个总长为n=p+r位的二进制序列:附加在数据序列之后的这个检验码与数据序列的内容之间存在着 ...
- android 进程(复习)
前台进程 前台进程是用户当前正在使用的进程.只有一些前台进程可以在任何时候都存在.他们是最后一个被结束的,当内存低到根本连他们都不能运行的时候.一般来说, 在这种情况下,设备会进行内存调度,中 ...
- POJ 2516 Minimum Cost
每个物品分开做最小费用最大流. #include<cstdio> #include<cstring> #include<cmath> #include<vec ...
- 入门级(python)
1.素数,求1-100之间的素数(想在代码中写中文注释,加一句#coding=utf-8,注意等号左右没空格) def isPrime(n): if(n == 1): return False els ...