实例介绍
【实例截图】
【核心代码】
#include <stdio.h> #include <iostream> #include <string.h> #include <sys/stat.h> #include <fcntl.h> #include <sys/socket.h> #include <sys/types.h> #include <unistd.h> #include <arpa/inet.h> #include <netdb.h> #include <errno.h> #include <time.h> #include <openssl/ssl.h> #include <openssl/err.h> #include <openssl/rand.h> #include <openssl/crypto.h> #include <openssl/rand.h> int https_get_request_wait_rsp(const char *ip, const char *name, int portnumber, const char *get_str, char *rsp_str, int rsp_buf_len) { int sockfd = 0; int ret; char buffer[1024*1024]; int nbytes; char host_addr[256]; char request[1024]; int send, totalsend; int i; SSL *ssl; SSL_CTX *ctx; char server_ip[16] = {0}; struct hostent *host; struct in_addr addr; struct sockaddr_in servaddr; if(ip == NULL || strlen(ip) < 7) { if((host = gethostbyname(name)) == NULL ) { return -1; } memcpy(&addr.s_addr,host->h_addr_list[0],sizeof(addr.s_addr)); strcpy(server_ip,(char *)inet_ntoa(addr)); } else { strcpy(server_ip, ip); } /* 客户程序开始建立 sockfd描述符 */ if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == -1) { /*建立SOCKET连接 */ printf("socket fail..............\n"); return -1; } memset(&servaddr, 0, sizeof(servaddr)); servaddr.sin_family = AF_INET; servaddr.sin_port = htons(portnumber); if(inet_pton(AF_INET, server_ip, &servaddr.sin_addr) <= 0) { printf("inet_pton error for %s\n", server_ip); close(sockfd); return -1; } /* 客户程序发起连接请求 */ if (connect(sockfd, (struct sockaddr *) (&servaddr), sizeof(struct sockaddr)) == -1) { printf( "Connect Error:%s\a\n", strerror(errno)); close(sockfd); return -1; } /*ssl init*/ SSL_library_init(); SSL_load_error_strings(); ctx = SSL_CTX_new(SSLv23_client_method()); if(ctx == NULL) { close(sockfd); return -1; } ssl = SSL_new(ctx); if(ssl == NULL) { close(sockfd); return -1; } /*把socket和SSL关联*/ ret = SSL_set_fd(ssl, sockfd); if(ret == 0) { close(sockfd); return -1; } ret = SSL_connect(ssl); if(ret != 1) { close(sockfd); return -1; } sprintf(request, "GET /%s HTTP/1.1\r\nAccept: */*\r\nAccept-Language: zh-cn\r\nUser-Agent: Mozilla/4.0 (compatible; MSIE 5.01; Windows NT 5.0)\r\nHost: %s:%d\r\nConnection: Keep-alive\r\n\r\n", get_str, server_ip, portnumber); printf("%s", request); send = 0; totalsend = 0; nbytes = strlen(request); while(totalsend < nbytes) { send = SSL_write(ssl, request totalsend, nbytes - totalsend); if(send == -1) { close(sockfd); return -1; } totalsend = send; } printf("44444444:%d\n", totalsend); i = 0; /* while((nbytes = SSL_read(ssl, buffer, 1)) == 1) { printf("buffer:%s\n", buffer); if(i < 4) { if(buffer[0] == 'r' || buffer[0] == '\n') { i ; if(i>=4) { break; } } else { i = 0; } } }*/ printf("5555555\n"); memset(rsp_str, 0, rsp_buf_len); ret = SSL_read(ssl, rsp_str, rsp_buf_len); if(ret < 0) { printf("response ret =%d ======\n", ret); close(sockfd); return -1; } printf("response ret =%d=====>\t\t[%s]\n\n", ret , rsp_str); /*end ssl*/ SSL_shutdown(ssl); close(sockfd); SSL_free(ssl); SSL_CTX_free(ctx); ERR_free_strings(); return 0; } int main(void) { //char *hostname, *portnum, *weburl; char rsp_buf[40960] = {0}; https_get_request_wait_rsp(NULL, "www.baidu.com", 443, "", rsp_buf, sizeof(rsp_buf)); printf("=======>\n"); return 0; }
标签:
小贴士
感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。
- 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
- 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
- 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
- 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。
关于好例子网
本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明
网友评论
我要评论