惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

Engineering at Meta
Engineering at Meta
博客园_首页
H
Help Net Security
WordPress大学
WordPress大学
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
罗磊的独立博客
博客园 - 三生石上(FineUI控件)
B
Blog
I
InfoQ
SecWiki News
SecWiki News
T
Tailwind CSS Blog
Spread Privacy
Spread Privacy
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
V
Vulnerabilities – Threatpost
N
Netflix TechBlog - Medium
P
Palo Alto Networks Blog
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
Vercel News
Vercel News
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
K
Kaspersky official blog
M
MIT News - Artificial intelligence
S
Schneier on Security
T
Threat Research - Cisco Blogs
F
Fortinet All Blogs
Cyberwarzone
Cyberwarzone
Scott Helme
Scott Helme
aimingoo的专栏
aimingoo的专栏
Martin Fowler
Martin Fowler
MyScale Blog
MyScale Blog
The Cloudflare Blog
Recent Announcements
Recent Announcements
Security Latest
Security Latest
G
GRAHAM CLULEY
IT之家
IT之家
Y
Y Combinator Blog
The Last Watchdog
The Last Watchdog
腾讯CDC
Google DeepMind News
Google DeepMind News
V
V2EX
S
Securelist
TaoSecurity Blog
TaoSecurity Blog
B
Blog RSS Feed
S
SegmentFault 最新的问题
博客园 - 叶小钗
P
Proofpoint News Feed
云风的 BLOG
云风的 BLOG
Project Zero
Project Zero
G
Google Developers Blog
Google DeepMind News
Google DeepMind News
F
Full Disclosure

博客园 - format

使用Arduino Nano驱动Lora模块 DIY一个物联网平台:想法 jQuery 批量操作checkbox 国内的maven镜像 Python Flask UnicodeDecodeError 编码错误解决 关于Python的web框架 NHibernate 3 中的 In 集合查询 在MVC 4 中使用自定义Membership [学习][Java] Struts2 与页面传值 (转) C++ Utf8字符转换Gb312编码,解决TinyXml中文乱码 Linux学习 -- Linux的可执行文件 WIN32简单的窗体代码,带函数功能注释 Win32 API 的文件操作 - format C++ 类中封装Win32API的回调函数 Win32编程 创建从资源文件定义的对话框 Oracle 数据库 用脚本建表空间 把UserControl通过代码控制输入HTML WebService调用时候的Object Moved 异常 ICTCLAS 平台调用的封装
WINSocket编程 发生HTTP GET请求,并接收服务器返回
format · 2010-06-03 · via 博客园 - format

首先要添加引用

#include "winsock2.h" //header
#pragma comment (lib, "ws2_32.lib") //lib

调用的代码:

BOOL HttpClient(std::string& rest) //用参数接收返回的字符数据

    std::
string errMsg;//错误信息记录
    WSADATA wsaData;
    SOCKET sock;
    SOCKADDR_IN tcpaddr;
    hostent 
* remoteHost;
    
char   host[] = {"192.168.1.1"};     //主机名就直接写了 
    int   Ret,l;
    BOOL done;
    
int   port = 80;
    
int   chars = 0;
    
char buffer[1024];if( (Ret = WSAStartup(MAKEWORD(1,1), &wsaData) ) != 0 )
    {
        errMsg
+="WSAStartup failed with error "+Ret;
        
return 1;
    }
if( (remoteHost = gethostbyname(host)) == NULL )       //通过主机名获取地址
    {
        errMsg
+="gethostbyname error!\n";
        
return 1;
    }

    sock 

= socket (AF_INET, SOCK_STREAM, 0);

    tcpaddr.sin_family 

= AF_INET;
    tcpaddr.sin_port 
= htons( (unsigned short)port );
    tcpaddr.sin_addr.s_addr 
= *((unsigned long *)*remoteHost->h_addr_list); //转换地址

    
if( connect(sock, (const sockaddr * )&tcpaddr, sizeof(tcpaddr)) )
    {
        errMsg
+="connect error!";
        
return 1;
    }
    
//这里是要发送的http头部
    SendString(sock,"GET / HTTP/1.1\r\n");
    SendString(sock,
"Host:192.168.1.1\r\n");
    SendString(sock,
"Accept: */*\r\n");
    SendString(sock,
"User-Agent: Mozilla/4.0");
    SendString(sock,
"(compatible; MSIE 7.00; Windows 98)\r\n");
    SendString(sock,
"Connection:Keep-Alive\r\n");
    SendString(sock,
"\r\n");
    SendString(sock,
"\r\n");//最后要加空行

    done 
= FALSE;
    
//FILE * fp;
    
//fp = fopen("1.txt","w");
    
//打印并保存http响应的头部
    std::string str;
    
while(!done)
    {
        l 
= recv(sock,buffer,1,0);//一个字节一个字节的接受HTTP头
        str+=*buffer;
        
if(l<0)
            done
=TRUE;
        
switch(*buffer)
        {
        
case '\r':
            
break;
        
case '\n'://判断HTTP头是否接受完毕
            if(chars==0)
                done 
= TRUE;
            chars
=0;
            
break;
        
default:
            chars
++;
            
break;
        }
        printf(
"%c",str);
        
//fputc(buffer[0],fp);
    }//接收正文部分
    int sum = 0;
    
do
    {
        l 
= recv(sock,buffer,1024,0);
        
if( l < 0 )
            
break;
        sum 
+= l;
        
        str.append(buffer,l);
        
        
//*(buffer + l) = 0;
        
//fputs(buffer,fp);
        
    } 
while( l > 0 );//这里输出正文部分大小,发现其实和响应消息头部的Content-length大小是一样的
    
//这样就可以检查是否接受完毕
    printf("sum = %d\n",sum);

    closesocket(sock);

if( WSACleanup() == SOCKET_ERROR )
    {
        errMsg
+="WSACleanup failed with error "+WSAGetLastError();
    }
    rest
=str;return 1;
}
void SendString(SOCKET sock,LPCSTR str)
{
    send(sock,str,strlen(str),
0);
}