学会在Linux下使用getopt函数来获取传入的参数

嵌入式技术

1376人已加入

描述

    之前写代码,要向程序中传参数,程序中使用argv[1]、argv[2]……

实际linux中的命令使用-r -l -i 等等,比如tcpdump,守护进程dhcp,顿时感觉自己脸好红,low到家了。

在linux下有一个函数叫getopt就可以写成-r -l -i 的形式,下面是一个使用openssl通信的程序,需要4个参数服务器ip -i、服务器端口-p、证书地址-c、私匙地址-s

代码如下,重点看while循环:

#include

#include  

#include  

#include  

#include

//#include

//openssl头文件  

#include  

#include

//getopt()

#include     

int main (int argc, char **argv)

{

//服务器套接字

struct sockaddr_in server_addr;  

bzero(&server_addr, sizeof(server_addr));

SSL_CTX *ctx=NULL;    /* SSL会话环境 */  

//使用SSL_CTX_new()创建会话环境,建立连接时要使用协议由TLS_server_method()来定。 

if( NULL==(ctx=SSL_CTX_new(TLS_server_method())) )     

{  

ERR_print_errors_fp(stdout); 

return -1;

}   

int oc;   /*选项字符 */

printf("optid=%d. ", optind);

while( -1!=(oc=getopt(argc, argv, "i:p:c:s:")) )

{

switch(oc)

{

case 'i':

printf("i is %s. ", optarg);

printf("optid=%d. ", optind);

server_addr.sin_addr.s_addr = inet_addr(optarg);

break;

case 'p':

printf("p is %s. ", optarg);

printf("optid=%d. ", optind);

server_addr.sin_port = htons(atoi(optarg));

break;

case 'c':

printf("c is %s ", optarg);

printf("optid=%d. ", optind);

if( 0>=SSL_CTX_use_certificate_file(ctx, "./cacert.pem", SSL_FILETYPE_PEM) ) /* 为SSL会话加载用户证书 */  

{  

ERR_print_errors_fp(stdout);  

}     

break;

case 's':

printf("s is %s ", optarg);

printf("optid=%d. ", optind);

if( 0>=SSL_CTX_use_PrivateKey_file(ctx, "./privkey.pem", SSL_FILETYPE_PEM) ) /* 为SSL会话加载用户私钥 */  

{  

ERR_print_errors_fp(stdout); 

}   

break;

}

}

if( NULL!=ctx )  

{  

SSL_CTX_free(ctx);  

ctx=NULL;  

}  

return 0;

}

通过while循环检索程序启动时的参数,完成程序初始化工作。注意在给参数时-i、-p、-c、-s这4个的顺序是没有要求的。是不是很方便。




 

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分