实例介绍
【实例截图】
【核心代码】
#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小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明


网友评论
我要评论