1. 在c語言中修改文件許可權,C語言高手來!
刪掉jj.c
設置umask, open時指定許可權:
#include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <stdio.h>
int main(int argc,char* argv[]){
int r = open(argv[1],O_RDWR );
printf("open %s success!r = %d\n",argv[1],r);
char buf[1000000]={0};
int readlen = read(r,buf,sizeof(buf)-1);
umask(0);
int w = open(argv[2],O_RDWR | O_CREAT | O_TRUNC, S_IRWXO|S_IRWXG|S_IRWXU);
printf("create %s success!,r=%d\n",argv[2],r);
int writelen = write(w, buf,readlen);
close(r);
close(w);
}
2. 用C語言編寫對應許可權登陸和重新登陸或退出
/*登陸*/
void log_in()
{
FILE *fp = NULL;
char user_name[21] = {0};
char password[21] = {0};
int is_default_pass = -1;
char in_user[21] = {0};
char in_pass[21] = {0};
char ch;
fp = fopen("code", "rb");
if(fp)
{
fscanf(fp, "%s\n%s", user_name, password);
if(strcmp("admin", user_name) == 0
&&strcmp("123456", password) == 0)
{
is_default_pass = 1;
}
else
{
is_default_pass = -1;
}
}
if(!fp || is_default_pass == 1)
{
if(!fp)
{
strcpy(user_name, "admin");
strcpy(password, "123456");
fp = fopen("code", "wb");
fprintf(fp, "%s\n%s", user_name, password);
fclose(fp);
fp = fopen("code", "rb");
}
printf("系統中只有默認用戶,請輸入用戶名:admin, 密碼:123456\n");
}
log_in_window:
printf("***********************************************\n");
printf("*請輸入用戶名(最大不超過20字元或者十個漢字) \n");
printf("***********************************************\n用戶名: ");
gets(in_user);
printf("***********************************************\n");
printf("*請輸入密碼(最大不超過20字元或者十個漢字) \n");
printf("***********************************************\n密碼: ");
gets(in_pass);
if(strcmp(in_user, user_name) == 0
&&strcmp(in_pass, password) == 0)
{
ptr_instance->is_authorization = 1;
}
else
{
printf("用戶名或密碼錯誤,請重新輸入!\n");
goto log_in_window;
}
fclose(fp);
}
/*修改密碼*/
void modify_pass()
{
FILE *fp = NULL;
char in_user[21] = {0};
char in_pass[21] = {0};
char in_pass2[21] = {0};
char user[21] = {0};
char pass[21] = {0};
int i = 0;
fp = fopen("code", "rb+");
if(!fp)
{
printf("can't modify the pass, no code file!\n");
return;
}
log_in_check_window:
fscanf(fp, "%s\n%s", user, pass);
fseek(fp, 0, SEEK_SET);
printf("***********************************************\n");
printf("*請確認用戶名 \n");
printf("***********************************************\n用戶名: ");
gets(in_user);
printf("***********************************************\n");
printf("*請確認密碼 \n");
printf("***********************************************\n密碼: ");
gets(in_pass);
if(strcmp(user, in_user) != 0 || strcmp(pass, in_pass) != 0)
{
if(i < 3)
{
i++;
printf("密碼或用戶名出錯, 請重新輸入!\n");
goto log_in_check_window;
}
else
{
return;
}
}
log_in_window:
printf("***********************************************\n");
printf("*請輸入新用戶名(最大不超過20字元或者十個漢字) \n");
printf("***********************************************\n用戶名: ");
gets(in_user);
log_in_pass_again_window:
printf("***********************************************\n");
printf("*請輸入新密碼(最大不超過20字元或者十個漢字) \n");
printf("***********************************************\n密碼: ");
gets(in_pass);
printf("***********************************************\n");
printf("*請確認新密碼(最大不超過20字元或者十個漢字) \n");
printf("***********************************************\n密碼: ");
gets(in_pass2);
if(strcmp(in_pass, in_pass2) != 0)
{
printf("密碼兩遍輸入不同, 請重新輸入!\n");
goto log_in_pass_again_window;
}
if(in_user[0] == 0)
{
printf("用戶名不能為空, 請重新輸入!\n");
goto log_in_window;
}
fprintf(fp, "%s\n%s\n", in_user, in_pass);
fputc(EOF, fp);
printf("密碼成功修改!\n");
fclose(fp);
}
/*登陸主函數*/
void log()
{
char get_buf[10] = {0};
unsigned options = 0;
log_main_window:
if(ptr_instance->is_authorization == 1)
{
printf("\t 已登錄\n");
}
else
{
printf("\t 請登錄\n");
}
printf("\t*************************\n");
printf("\t| 1 登陸 |\n");
if(ptr_instance->is_authorization == 1)
{
printf("\t-------------------------\n");
printf("\t| 2 登出 |\n");
printf("\t-------------------------\n");
printf("\t| 3 修改用戶/密碼 |\n");
}
printf("\t-------------------------\n");
printf("\t| 4 清屏 |\n");
printf("\t-------------------------\n");
printf("\t| 5 退出 |\n");
printf("\t*************************\n");
printf("\t-------------------------\n");
printf("\t請輸入選項:");
gets(get_buf);
options = char2int(get_buf);
if(ptr_instance->is_authorization == -1 && (options == 2 || options == 3))
{
system("cls");
printf("輸入錯誤, 請重新選擇!\n");
goto log_main_window;
}
switch(options)
{
case 1:
system("cls");
if(ptr_instance->is_authorization == -1)
{
log_in();
system("cls");
goto log_main_window;
}
else
{
printf("本系統同一時間只能一人登陸,請重新選擇!\n");
goto log_main_window;
}
break;
case 2:
memset(get_buf, 0, 10);
printf("你確定登出嗎?<y/n>:");
gets(get_buf);
if(get_buf[0] == 'y')
{
ptr_instance->is_authorization = -1;
system("cls");
goto log_main_window;
}
else
{
goto log_main_window;
}
case 3:
system("cls");
modify_pass();
system("cls");
goto log_main_window;
case 4:
system("cls");
goto log_main_window;
case 5:
memset(get_buf, 0, 10);
printf("你確定退出嗎?<y/n>:");
gets(get_buf);
if(get_buf[0] == 'y')
{
system("cls");
break;
}
else
{
goto log_main_window;
}
default:
printf("輸入錯誤, 請重新選擇!\n");
goto log_main_window;
break;
}
}
void main()
{
log();
}
3. c語言文件的許可權怎麼設置
0666:
第一個 0 表示這個數是 八進制
第一個 6 表示文件擁有者有讀寫許可權,但沒有執行許可權
第二個 6 表示文件擁有者同組用戶有讀寫許可權,但沒有執行許可權
第三個 6 表示其它用戶有讀寫許可權,但沒有執行許可權
6 的 二進制就是 0110
第 1 位在許可權中總是為 0
第 2 位為 0 表示文件不可以被讀, 為 1 表示可以被讀
第 3 位為 0 表示文件不可以被寫, 為 1 表示可以被寫
第 4 位為 0 表示文件不可以被執行, 為 1 表示可以被執行
4. 怎樣用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;
}
5. 急!!!怎麼用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; //偉建內容對應的塊數量
};
可以通過上面提供的函數,返回一個結構體,保存著文件的信息。
6. 什麼是c語言許可權,高手賜教
c語言,create() 函數??
這個函數是哪個單位的? 以後出來掛個牌牌,小心走失了
7. C語言的命令行程序的許可權
這就看你編譯器的許可權了,編譯器有管理員許可權,對應的控制台程序也就具有管理員許可權~
8. c語言為什麼用8進制代表文件許可權
因為文件的讀、寫、創建、刪除、隱藏等許可權都用一個二進制位表示,0表示禁止、1表示允許。因此用二進制、八進制、十六進製表示文件的許可權比較直觀易讀,但二進制位數長,十六進制高位用不著,一位八進制和十進制相同,八進制就顯得比較合適。這也是約定俗成。