Ⅰ 急!!!怎么用C语言查看文件的权限
表头文件: #include <sys/stat.h> #include <unistd.h>定义函数: int stat(const char *file_name, struct stat *buf);函数说明: 通过文件名filename获取文件信息,并保存在buf所指的结构体stat中返回值: 执行成功则返回0,失败返回-1,错误代码存于errno错误代码: ENOENT 参数file_name指定的文件不存在 ENOTDIR 路径中的目录存在但却非真正的目录 ELOOP 欲打开的文件有过多符号连接问题,上限为16符号连接 EFAULT 参数buf为无效指针,指向无法存在的内存空间 EACCESS 存取文件时被拒绝 ENOMEM 核心内存不足 ENAMETOOLONG 参数file_name的路径名称太长#include <sys/stat.h>#include <unistd.h>#include <stdio.h>int main() { struct stat buf; stat("/etc/hosts", &buf); printf("/etc/hosts file size = %d\n", buf.st_size);}—————————————————–struct stat { dev_t st_dev; //文件的设备编号 ino_t st_ino; //节点 mode_t st_mode; //文件的类型和存取的权限 nlink_t st_nlink; //连到该文件的硬连接数目,刚建立的文件值为1 uid_t st_uid; //用户ID gid_t st_gid; //组ID dev_t st_rdev; //(设备类型)若此文件为设备文件,则为其设备编号 off_t st_size; //文件字节数(文件大小) unsigned long st_blksize; //块大小(文件系统的I/O 缓冲区大小) unsigned long st_blocks; //块数 time_t st_atime; //最后一次访问时间 time_t st_mtime; //最后一次修改时间 time_t st_ctime; //最后一次改变时间(指属性)};先前所描述的st_mode 则定义了下列数种情况: S_IFMT 0170000 文件类型的位遮罩 S_IFSOCK 0140000 scoket S_IFLNK 0120000 符号连接 S_IFREG 0100000 一般文件 S_IFBLK 0060000 区块装置 S_IFDIR 0040000 目录 S_IFCHR 0020000 字符装置 S_IFIFO 0010000 先进先出 S_ISUID 04000 文件的(set user-id on execution)位 S_ISGID 02000 文件的(set group-id on execution)位 S_ISVTX 01000 文件的sticky位 S_IRUSR(S_IREAD) 00400 文件所有者具可读取权限 S_IWUSR(S_IWRITE)00200 文件所有者具可写入权限 S_IXUSR(S_IEXEC) 00100 文件所有者具可执行权限 S_IRGRP 00040 用户组具可读取权限 S_IWGRP 00020 用户组具可写入权限 S_IXGRP 00010 用户组具可执行权限 S_IROTH 00004 其他用户具可读取权限 S_IWOTH 00002 其他用户具可写入权限 S_IXOTH 00001 其他用户具可执行权限 上述的文件类型在POSIX中定义了检查这些类型的宏定义: S_ISLNK (st_mode) 判断是否为符号连接 S_ISREG (st_mode) 是否为一般文件 S_ISDIR (st_mode) 是否为目录 S_ISCHR (st_mode) 是否为字符装置文件 S_ISBLK (s3e) 是否为先进先出 S_ISSOCK (st_mode) 是否为socket若一目录具有sticky位(S_ISVTX),则表示在此目录下的文件只能被该文件所有者、此目录所有者或root来删除或改名。—————————————————–struct statfs { long f_type; //文件系统类型 long f_bsize; //块大小 long f_blocks; //块多少 long f_bfree; //空闲的块 long f_bavail; //可用块 long f_files; //总文件节点 long f_ffree; //空闲文件节点 fsid_t f_fsid; //文件系统id long f_namelen; //文件名的最大长度 long f_spare[6]; //spare for later};stat、fstat和lstat函数(UNIX)#include<sys/types.h>#include<sys/stat.h>int stat(const char *restrict pathname, struct stat *restrict buf);提供文件名字,获取文件对应属性。感觉一般是文件没有打开的时候这样操作。int fstat(int filedes, struct stat *buf);通过文件描述符获取文件对应的属性。文件打开后这样操作int lstat(const char *restrict pathname, struct stat *restrict buf);连接文件三个函数的返回:若成功则为0,若出错则为-1给定一个pathname,stat函数返回一个与此命名文件有关的信息结构,fstat函数获得已在描述符filedes上打开的文件的有关信息。lstat函数类似于stat,但是当命名的文件是一个符号连接时,lstat返回该符号连接的有关信息,而不是由该符号连接引用的文件的信息。第二个参数是个指针,它指向一个我们应提供的结构。这些函数填写由buf指向的结构。该结构的实际定义可能随实现而有所不同,但其基本形式是:struct stat{mode_t st_mode; /*file tpye &mode (permissions)*/ino_t st_ino; /*i=node number (serial number)*/dev_t st_rdev; /*device number for special files*/nlink_t st_nlink; /*number of links*/uid_t st_uid; /*user id of owner*/gid_t st_gid; /*group ID of owner*/off_t st_size; /*size in bytes for regular files*/time_t st_atime; /*time of last access*/time_t st_mtime; /*time of last modification*/time_t st_ctime; /*time of last file status change*/long st_blksize; /*best I/O block size */long st_blocks; /*number of 512-byte blocks allocated*/}; 注意,除最后两个以外,其他各成员都为基本系统数据类型。我们将说明此结构的每个成员以了解文件属性。 使用stat函数最多的可能是ls-l命令,用其可以获得有关一个文件的所有信息。1 函数都是获取文件(普通文件,目录,管道,socket,字符,块()的属性。函数原型#include <sys/stat.h>int stat(const char *restrict pathname, struct stat *restrict buf);提供文件名字,获取文件对应属性。int fstat(int filedes, struct stat *buf);通过文件描述符获取文件对应的属性。int lstat(const char *restrict pathname, struct stat *restrict buf);连接文件描述命,获取文件属性。2 文件对应的属性struct stat { mode_t st_mode; //文件对应的模式,文件,目录等 ino_t st_ino; //inode节点号 dev_t st_dev; //设备号码 dev_t st_rdev; //特殊设备号码 nlink_t st_nlink; //文件的连接数 uid_t st_uid; //文件所有者 gid_t st_gid; //文件所有者对应的组 off_t st_size; //普通文件,对应的文件字节数 time_t st_atime; //文件最后被访问的时间 time_t st_mtime; //文件内容最后被修改的时间 time_t st_ctime; //文件状态改变时间 blksize_t st_blksize; //文件内容对应的块大小 blkcnt_t st_blocks; //伟建内容对应的块数量 };可以通过上面提供的函数,返回一个结构体,保存着文件的信息。
Ⅱ C语言创建文件夹的问题~
可以使用mkdir函数解决问题。使用权限:于目前目录有适当权限的所有使用者使用方式:mkdir [-p] dirName说明:建立名称为 dirName 的子目录。参数:-p 确保目录名称存在,如果目录不存在的就新创建一个。语法:mkdir [选项] dir-name说明:该命令创建由dir-name命名的目录。要求创建目录的用户在当前目录中(dir-name的父目录中)具有写权限,并且dirname不能是当前目录中已有的目录或文件名称。命令中各选项的含义为:- m 对新建目录设置存取权限。也可以用chmod命令设置。- p 可以是一个路径名称。此时若路径中的某些目录尚不存在,加上此选项后,系统将自动建立好那些尚不存在的目录,即一次可以建立多个目录。给一个mkdir函数的实例:#include <direct.h>#include <stdlib.h>#include <stdio.h>int main( void ){ if( _mkdir( "\\testtmp" ) == 0 ) { printf( "Directory '\\testtmp' was successfully created\n" ); system( "dir \\testtmp" ); if( _rmdir( "\\testtmp" ) == 0 ) printf( "Directory '\\testtmp' was successfully removed\n" ); else printf( "Problem removing directory '\\testtmp'\n" ); } else printf( "Problem creating directory '\\testtmp'\n" );}
Ⅲ linux C语言如何得到一个文件的权限并输出
/*-楼主可以参考一下我写的这段程序———*//*—–用stat函数得到文件信息,并用函数转化为文本输出,就跟ls命令一样—–*//*———-注释我写得很详细,望采纳———–*/#include <sys/types.h> /*—–这三个头文件一定要有-*/#include <sys/stat.h>#include <unistd.h>#include <stdio.h>#include <stdlib.h>#include <string.h>void mode_to_letter(int mode,char *str){ /*——-这个函数用来把模式值转化为字符串——*/ str[0]='-'; /*——这里的S_*****都是宏定义,用来判断模式属性-*/ if(S_ISDIR(mode)) str[0]='d';/*-文件夹-*/ if(S_ISCHR(mode)) str[0]='c';/*-字符设备-*/ if(S_ISBLK(mode)) str[0]='b';/*-块设备-*/ if(mode & S_IRUSR) str[1]='r';/*–用户的三个属性-*/ else str[1]='-'; if(mode & S_IWUSR) str[2]='w'; else str[2]='-'; if(mode & S_IXUSR) str[3]='x'; else str[3]='-'; if(mode & S_IRGRP) str[4]='r';/*–组的三个属性-*/ else str[4]='-'; if(mode & S_IWGRP) str[5]='w'; else str[5]='-'; if(mode & S_IXGRP) str[6]='x'; else str[6]='-'; if(mode & S_IROTH) str[7]='r';/*-其他人的三个属性-*/ else str[7]='-'; if(mode & S_IWOTH) str[8]='w'; else str[8]='-'; if(mode & S_IXOTH) str[9]='x'; else str[9]='-'; str[10]='\0';}int main(int argc,char *argv[]){ struct stat sb;/*- 定义stat结构–*/ char str[12]; if(argc!=2){ fprintf(stderr,"Usage: %s <pathname>\n",argv[0]); exit(EXIT_FAILURE); } if(stat(argv[1],&sb)==-1){/*-stat函数,详情请 man 2 stat 查看 -*/ perror("stat"); exit(EXIT_FAILURE); } printf("Mode:%lo(octal)\n",(unsigned long)sb.st_mode); mode_to_letter(sb.st_mode,str); printf("Mode:%s\n",str); return 0;}
Ⅳ 怎样用c语言编一个程序,使其只要运行即获得管理员权限。(win7及以上系统)
如果不使用系统级漏洞,这个是不可能操作。所谓栈内存溢出攻击是使用了系统漏洞,而且在不同电脑上效果也大相径庭,所谓管理员权限地址是不存在的,没有这个说法,只有虚拟地址和实地址就算你获得了管理员权限,也无法随便删除系统文件,要删除系统文件需要做很多工作,没有一个高权限驱动或服务也是没办法的
Ⅳ 在linux中(用c语言),如何输出文件的权限,所有者,日期等内容
可以通过新建一个进程,然后使用exec()函数(记得好像是这函数)实现的~~~
Ⅵ 怎样用c语言编一个程序,使其只要运行即获得管理员权限。(在win7系统下)
emmm,我记得microsoft三件套就有这个特性给一个从CSDN找到的代码#include windows.h//这里自己加上括号VOID ManagerRun(LPCSTR exe,LPCSTR param,INT nShow=SW_SHOW) { //注意:会跳出提示。 SHELLEXECUTEINFO ShExecInfo; ShExecInfo.cbSize = sizeof(SHELLEXECUTEINFO); ShExecInfo.fMask = SEE_MASK_NOCLOSEPROCESS ; ShExecInfo.hwnd = NULL; ShExecInfo.lpVerb = "runas"; ShExecInfo.lpFile = exe; ShExecInfo.lpParameters = param; ShExecInfo.lpDirectory = NULL; ShExecInfo.nShow = nShow; ShExecInfo.hInstApp = NULL; BOOL ret = ShellExecuteEx(&ShExecInfo); //等不及了,不等了。 CloseHandle(ShExecInfo.hProcess); return;}int main(int argc,char *argv[]){ if(argc == 1) //初次运行,即双击EXE { ShowWindow(GetConsoleWindow(),SW_HIDE); ManagerRun(argv[0],"2"); return 1; }else if(argc == 2) //再次运行,即上面那个ManagerRun { /*你的程序主代码在此*/ } return 0;}
Ⅶ c语言文件的权限怎么设置
0666:第一个 0 表示这个数是 八进制第一个 6 表示文件拥有者有读写权限,但没有执行权限第二个 6 表示文件拥有者同组用户有读写权限,但没有执行权限第三个 6 表示其它用户有读写权限,但没有执行权限6 的 二进制就是 0110第 1 位在权限中总是为 0第 2 位为 0 表示文件不可以被读, 为 1 表示可以被读第 3 位为 0 表示文件不可以被写, 为 1 表示可以被写第 4 位为 0 表示文件不可以被执行, 为 1 表示可以被执行