Linux C语言用system()调用,带参数
老师给的题目是用fork生成N个父子程序让他们连成一个环,然后环形式的发送信息,现在我把简单的client和server做出来了并且可以从client发送到server,...
老师给的题目是用fork生成N个父子程序让他们连成一个环,然后环形式的发送信息,现在我把简单的client 和server 做出来了并且可以从client 发送到server,但是很迷惑不知道怎么在父子process中完成现在我试着这样做,但是又不知道在system()中如何把参数也就是<port number>传送到 simser中
int main()
{
int i=0,pid,c=1,son=1,pp=1;
pid=fork();
if(pid==0)
{
//p=8;
printf("I am son %d\n",getpid());
system("simser","67");
//son++;
}else if(pid!=0)
{
//sleep(10);
printf("I am father %d\n",getpid());
// pp++;
}
我想用system()调用另外一个已经编译的simser.exe执行文件代码如下:
int main(int argc, char *argv[])
{
int servSock;
struct sockaddr_in echoServAdr;
int clntSock;
struct sockaddr_in echoClntAdr;
unsigned int clntLen;
unsigned short echoServPort;
/*create the socket for incomming call*/
if(argc!=2)
{
fprintf(stderr, "Usage: %s <Server Port>\n", argv[0]);
exit(1);
}
echoServPort=atoi(argv[1]);
if((servSock=socket(PF_INET, SOCK_STREAM, IPPROTO_TCP))<0)
printf("Socket create error");
/*struct a local address structure*/
memset(&echoServAdr,0,sizeof(echoServAdr));
echoServAdr.sin_family = AF_INET;
echoServAdr.sin_addr.s_addr=htonl(INADDR_ANY); //any incomming interface
echoServAdr.sin_port = htons(echoServPort); //the local port
/* Bind to the local address*/
if(bind(servSock, (struct sockaddr*)&echoServAdr, sizeof(echoServAdr))<0) //bind the specified information to the specified socket
printf("Bind is failed might be the port is bind already");
/*mark the socket so it will litsen for incoming connections*/
if(listen(servSock,MAXPENDING)<0) // the limitqueque
printf("Error to listen the port");
for(;;)
{
/*set the size of in-out parameter*/
clntLen=sizeof(echoClntAdr);
/*wait for the client to connect*/
if((clntSock=accept(servSock, (struct sockaddr*)&echoClntAdr, &clntLen))<0) // it will return a new socket that is connected to the client
printf("Error to accept");
/*Now is connect to the client*/
printf("Hanlding client %s\n",inet_ntoa(echoClntAdr.sin_addr));
HandleTCPclient(clntSock);
}
}
也就是一个简单的server code
请赐教
谢谢 展开
int main()
{
int i=0,pid,c=1,son=1,pp=1;
pid=fork();
if(pid==0)
{
//p=8;
printf("I am son %d\n",getpid());
system("simser","67");
//son++;
}else if(pid!=0)
{
//sleep(10);
printf("I am father %d\n",getpid());
// pp++;
}
我想用system()调用另外一个已经编译的simser.exe执行文件代码如下:
int main(int argc, char *argv[])
{
int servSock;
struct sockaddr_in echoServAdr;
int clntSock;
struct sockaddr_in echoClntAdr;
unsigned int clntLen;
unsigned short echoServPort;
/*create the socket for incomming call*/
if(argc!=2)
{
fprintf(stderr, "Usage: %s <Server Port>\n", argv[0]);
exit(1);
}
echoServPort=atoi(argv[1]);
if((servSock=socket(PF_INET, SOCK_STREAM, IPPROTO_TCP))<0)
printf("Socket create error");
/*struct a local address structure*/
memset(&echoServAdr,0,sizeof(echoServAdr));
echoServAdr.sin_family = AF_INET;
echoServAdr.sin_addr.s_addr=htonl(INADDR_ANY); //any incomming interface
echoServAdr.sin_port = htons(echoServPort); //the local port
/* Bind to the local address*/
if(bind(servSock, (struct sockaddr*)&echoServAdr, sizeof(echoServAdr))<0) //bind the specified information to the specified socket
printf("Bind is failed might be the port is bind already");
/*mark the socket so it will litsen for incoming connections*/
if(listen(servSock,MAXPENDING)<0) // the limitqueque
printf("Error to listen the port");
for(;;)
{
/*set the size of in-out parameter*/
clntLen=sizeof(echoClntAdr);
/*wait for the client to connect*/
if((clntSock=accept(servSock, (struct sockaddr*)&echoClntAdr, &clntLen))<0) // it will return a new socket that is connected to the client
printf("Error to accept");
/*Now is connect to the client*/
printf("Hanlding client %s\n",inet_ntoa(echoClntAdr.sin_addr));
HandleTCPclient(clntSock);
}
}
也就是一个简单的server code
请赐教
谢谢 展开
2个回答
展开全部
linux c system函数介绍:
system(执行shell 命令)
相关函数
fork,execve,waitpid,popen
表头文件
#i nclude
定义函数
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
main()
{
system("ls -al /etc/passwd /etc/shadow");
}
执行结果:
-rw-r--r-- 1 root root 705 Sep 3 13 :52 /etc/passwd
-r--------- 1 root root 572 Sep 2 15 :34 /etc/shado
例2:
char tmp[];
sprintf(tmp,"/bin/mount -t vfat %s /mnt/usb",dev);
system(tmp);
其中dev是/dev/sda1。
system函数的源码
#include <syspes.h>
#include <sys/wait.h>
#include <errno.h>
#include <unistd.h>
int system(const char * cmdstring)
{
pid_t pid;
int status;
if(cmdstring == NULL){
return (1);
}
if((pid = fork())<0){
status = -1;
}
else if(pid = 0){
execl("/bin/sh", "sh", "-c", cmdstring, (char *)0);
-exit(127); //子进程正常执行则不会执行此语句
}
else
{
while(waitpid(pid, &status, 0) < 0){
if(errno != EINTER)
{
status = -1;
break;
}
}
}
return status;
}
那么如何获得system的返回值呢??
char buf[10];
char * ps="ps -ef|grep -c root";
FILE *ptr;
int i;
if((ptr = popen(ps, "r")) != NULL)
{
fgets(buf, 10 , ptr);
i = atoi(buf);
pclose(ptr);
}
可以man下waitpid查看下如何检查status的值
int ret = system("ls -al /etc/passwd /etc/shadow");
if(WIFSIGNALED(ret))
具体的这些宏查看man waitpid
system(执行shell 命令)
相关函数
fork,execve,waitpid,popen
表头文件
#i nclude
定义函数
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
main()
{
system("ls -al /etc/passwd /etc/shadow");
}
执行结果:
-rw-r--r-- 1 root root 705 Sep 3 13 :52 /etc/passwd
-r--------- 1 root root 572 Sep 2 15 :34 /etc/shado
例2:
char tmp[];
sprintf(tmp,"/bin/mount -t vfat %s /mnt/usb",dev);
system(tmp);
其中dev是/dev/sda1。
system函数的源码
#include <syspes.h>
#include <sys/wait.h>
#include <errno.h>
#include <unistd.h>
int system(const char * cmdstring)
{
pid_t pid;
int status;
if(cmdstring == NULL){
return (1);
}
if((pid = fork())<0){
status = -1;
}
else if(pid = 0){
execl("/bin/sh", "sh", "-c", cmdstring, (char *)0);
-exit(127); //子进程正常执行则不会执行此语句
}
else
{
while(waitpid(pid, &status, 0) < 0){
if(errno != EINTER)
{
status = -1;
break;
}
}
}
return status;
}
那么如何获得system的返回值呢??
char buf[10];
char * ps="ps -ef|grep -c root";
FILE *ptr;
int i;
if((ptr = popen(ps, "r")) != NULL)
{
fgets(buf, 10 , ptr);
i = atoi(buf);
pclose(ptr);
}
可以man下waitpid查看下如何检查status的值
int ret = system("ls -al /etc/passwd /etc/shadow");
if(WIFSIGNALED(ret))
具体的这些宏查看man waitpid
展开全部
格式:
system(字符串)
例如:
char my_cmd1[]="ls -l";
char my_cmd2[]="ls -l > abc.txt";
char my_cmd3[]="simser.exe 67";
system(my_cmd1);
system(my_cmd2);
system(my_cmd3);
---------------
simser.exe 67
67 是位置参数才可以这样写。(也就是 通过 simser.exe 的
main(int argc, char *argv[]) argv 传入的)
system("simser","67"); -- wrong, system takes one parameter only.
system(字符串)
例如:
char my_cmd1[]="ls -l";
char my_cmd2[]="ls -l > abc.txt";
char my_cmd3[]="simser.exe 67";
system(my_cmd1);
system(my_cmd2);
system(my_cmd3);
---------------
simser.exe 67
67 是位置参数才可以这样写。(也就是 通过 simser.exe 的
main(int argc, char *argv[]) argv 传入的)
system("simser","67"); -- wrong, system takes one parameter only.
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询