之前使用system方法執行指令的時候就相當於如下相關的使用說明
system(執行shell 命令)
相關函數
fork,execve,waitpid,popen
表標頭檔
#i nclude<stdlib.h>
定義函數
int system(const char * string);
函數說明
system()會調用fork()產生子進程,由子進程來調用/bin/sh-c string來執行參數string字串所代表的命令,此命>令執行完後隨即返回原調用的進程。在調用system()期間SIGCHLD 訊號會被暫時擱置,SIGINT和SIGQUIT 訊號則會被忽略。
傳回值
=-1:出現錯誤
=0:調用成功但是沒有出現子進程
>0:成功退出的子進程的id
如果system()在調用/bin/sh時失敗則返回127,其他失敗原因返回-1。若參數string為空白指標(NULL),則返回非零值>。如果system()調用成功則最後會返回執行shell命令後的傳回值,但是此傳回值也有可能為 system()調用/bin/sh失敗所返回的127,因此最好能再檢查errno 來確認執行成功。
附加說明
在編寫具有SUID/SGID許可權的程式時請勿使用system(),system()會繼承環境變數,通過環境變數可能會造成系統安全的問題。
範例
#i nclude<stdlib.h>
main()
{
system("ls -al /etc/passwd /etc/shadow");
}
如上所示的system執行指令碼行為,所以我自己建立了一個名為 ChCallDB的指令檔
#!bin
chmod -R 755 (... 檔案名稱)
然後一樣拷貝到/usr/bin/目錄底下去,然後chmod +s (... 檔案名稱)
這樣命令ChCallDB和ls等一些指令碼調用應該就是一樣的了,但是出乎意料之外的是,當我用system(“ChCallDB”)的時候居然沒反應,還以為是不是絕對路徑的問題,所有又加上了檔案的決定路徑,還是不行。
###########################################################
後面實在找不到原因,問高手等有的說是自己的指令碼system識別不到(其實這個我倒不知道是不是真的,為什麼就自己的指令碼執行不了了,和系統的設定時一樣的了啊),後面只能改寫成一個可執行檔來chmod的檔案的屬性值
###########################################################
可執行檔如下
int main()
{
chmod("檔案名稱",0777);
return 0;
}
然後用gcc來編譯成一個可執行檔以後,用system來執行才可以。