首先要添加引用
#include "winsock2.h" //header
#pragma comment (lib, "ws2_32.lib") //lib
#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);
}
{
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);
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix