C++socket网络编程(跨平台)实战HTTP服务器(三)

简介:

             封装TCP类


封装一下tcp类, 步骤还可以简化,

直接放上代码类名:XTCP


xtcp.h

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#ifndef _XTCP_H_
#define _XTCP_H_
#include <iostream>
#include <string.h>
class  XTCP
{
public :
XTCP();
virtual  ~XTCP();
public :
int  CreateSocket(); //创建socket 反悔socket
bool  Bind(unsigned  short  port); //绑定端口
XTCP Accept(); //反回一个对象
void  Close(); //关闭 主动做
int  Recv( char  *buf,  int  bufsize); //接收
int  Send( const  char  *buf,  int  sendsize); //发送
int  m_sock = 0;
unsigned  short  m_port = 0;
std::string ip;
};
#endif //_XTCP_H_

xtcp.cpp

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
#include "XTCP.h"
#ifdef WIN32
#include <Windows.h>
#define socklen_t int
#else
#include <sys/types.h>
#include <sys/socket.h>
#include <unistd.h>
#include <arpa/inet.h>
#define closesocket close
#include <string.h>
#endif
XTCP::XTCP()
{
#ifdef WIN32
static  bool  first =  true //保证只进入一次
if  (first)
{
first =  false ;
WSADATA ws;
WSAStartup(MAKEWORD(2, 2), &ws);
}
#endif
}
XTCP::~XTCP()
{
}
int  XTCP::CreateSocket()
{
m_sock = socket(AF_INET, SOCK_STREAM, 0);
if  (m_sock == -1)
{
printf ( "create socket failed!\n" );
}
return  m_sock;
}
bool   XTCP::Bind(unsigned  short  port)
{
sockaddr_in sa;
sa.sin_family = AF_INET;
sa.sin_port = htons(port);
sa.sin_addr.s_addr = htonl(0);
if  (bind(m_sock, (sockaddr*)&sa,  sizeof (sa)))
{
printf ( "bind port err\n" );
//绑定成功
return  false ;
}
//侦听
listen(m_sock, 10);
//绑定失败
return  true ;
}
void  XTCP::Close()
{
if  (m_sock <= 0)  return ;
closesocket(m_sock);
}
XTCP XTCP::Accept()
{
XTCP tcp;
sockaddr_in sadd;
socklen_t len =  sizeof (sadd);
printf ( "lsiteb ... accept ok\n" );
//这里会阻塞 只有等待有新的连接 才会执行下面的代码
int  client = accept(m_sock, (sockaddr*)&sadd, &len);
//反悔判断m_sock是否为0就行了
if  (client <= 0) return  tcp; 
printf ( "client connect ok\n" );
//输出端口号和信息
tcp.ip = inet_ntoa(sadd.sin_addr);
//网络字节序转本地字节序哦
tcp.m_port = ntohs(sadd.sin_port);
//记录socket
tcp.m_sock = client;
printf ( "IP: %s:port: %d\n" , tcp.ip.c_str(), tcp.m_port);
return  tcp;
}
int  XTCP::Recv( char  *buf,  int  bufsize)
{
return  recv(m_sock, buf, bufsize, 0);
}
int  XTCP::Send( const  char  *buf,  int  sendsize)
{
//buf 必须发送制定大小   保证发送全部成功
int  s = 0;   //以发送的  发送大小减去以及发送的
while  (s != sendsize)
{
//反回就是发送的长度
int  len = send(m_sock, buf + s, sendsize - s, 0);
if  (len <= 0)
break ;
s += len;   //加上发送的长度
}
return  s;
}

测试代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
#include "XTCP.h"
#include <thread>
class  TcpThread
{
public :
//线程入口函数 创建一个
void  Main()
{
char  buf[1024];
for  (;;)
{
memset (buf, 0,  sizeof (buf));
int  recv_len = client.Recv( buf,  sizeof (buf) - 1);
if  (recv_len <= 0) break ;
if  ( strstr (buf,  "quit" ) != NULL)
{
char  re[] =  "quit success\n" ;
int  sendlen = client.Send(re,  strlen (re) + 1);
break ;
}
char  *p_ok =  "ok\n" ;
int  sendlen = client.Send(p_ok, strlen (p_ok));
printf ( "recv %s\n" , buf);
}
client.Close();
delete  this ;
}
//用户的socket
XTCP client;
};
 
 
int  main( int  argc, char *argv[])
{
unsigned  short  port = 8016;
XTCP mytcp;
//创建
mytcp.CreateSocket();
//绑定
if  (!mytcp.Bind(port))
return  -1;
for  (;;)
{
XTCP client = mytcp.Accept();
//创建线程
TcpThread *th =  new  TcpThread();
th->client = client;
std:: thread  sthr(&TcpThread::Main, th);
// 释放主线程占用的资源
sthr.detach();
}
mytcp.Close();
getchar ();
return  0;
}

原理就是: 创建一个对象XTCP server,有一个int变量,是用来记录创建的socket.的,他用来和用户建立连接,然后服务器必须要绑定端口,Bind里自动侦听。(调用了listen函数)

然后就是反回一个用户client的XTCP对象,把这个对象赋值给上面

的线程类里的成员,应为他TcpThread*th = new TcpThread();

他里面有一个th->client = client; 把他赋值给这个client.

然后创建线程在线程里等待数据收发, 这个new的对象 是在

线程函数里进行释放的 也就是closesocket后面有一个delete this. ,最后就是th->detach() 是释放主线程占用的子线程

的资源,。



移植到linux

先看下makefile

SRC 添加main.cpp 和 XTCP.cpp 就行了

1
2
3
4
5
6
7
8
9
10
11
12
CC=g++
SRC=main.cpp XTCP.cpp
OBJ=hello.o
EXEC=manc
start:
         $(CC) $(SRC) -o $(EXEC) -std=c++11 -lpthread
$(OBJ):
         $(CC)  $(OBJ) -c $(SRC)
clean:
         rm -f $(OBJ) $(EXEC)
run:
         ./$(EXEC)

执行make start  编译连接

执行make run  执行

wKioL1lpxufh3kC6AABa0Vp5PeY887.png-wh_50


成功并发,多个客户端

wKioL1lpx0GBjxNVAAOK-xSNLak213.png-wh_50


        封装TCP类到Windowsd的dll动态库

将一个类封装到dll和linux的so

在这个博客里讲:

    http://12158490.blog.51cto.com/12148490/1947885





 本文转自超级极客51CTO博客,原文链接:http://blog.51cto.com/12158490/1947886,如需转载请自行联系原作者





相关文章
|
8天前
|
安全 Java 数据处理
Python网络编程基础(Socket编程)多线程/多进程服务器编程
【4月更文挑战第11天】在网络编程中,随着客户端数量的增加,服务器的处理能力成为了一个重要的考量因素。为了处理多个客户端的并发请求,我们通常需要采用多线程或多进程的方式。在本章中,我们将探讨多线程/多进程服务器编程的概念,并通过一个多线程服务器的示例来演示其实现。
|
1月前
|
数据处理 C# C++
如何使用C#和C++结构体实现Socket通信
如何使用C#和C++结构体实现Socket通信
|
1月前
|
网络协议 C++
C++ Qt开发:QTcpSocket网络通信组件
`QTcpSocket`和`QTcpServer`是Qt中用于实现基于TCP(Transmission Control Protocol)通信的两个关键类。TCP是一种面向连接的协议,它提供可靠的、双向的、面向字节流的通信。这两个类允许Qt应用程序在网络上建立客户端和服务器之间的连接。Qt 是一个跨平台C++图形界面开发库,利用Qt可以快速开发跨平台窗体应用程序,在Qt中我们可以通过拖拽的方式将不同组件放到指定的位置,实现图形化开发极大的方便了开发效率,本章将重点介绍如何运用`QTcpSocket`组件实现基于TCP的网络通信功能。
37 8
C++ Qt开发:QTcpSocket网络通信组件
|
1月前
|
网络协议 Shell 网络安全
实验目的1.编译安装httpd2.优化路径3.并将鲜花网站上传到web服务器为网页目录4.在客户机访问网站http://www.bdqn.com
实验目的1.编译安装httpd2.优化路径3.并将鲜花网站上传到web服务器为网页目录4.在客户机访问网站http://www.bdqn.com
163 0
|
7天前
|
存储 算法 Linux
【实战项目】网络编程:在Linux环境下基于opencv和socket的人脸识别系统--C++实现
【实战项目】网络编程:在Linux环境下基于opencv和socket的人脸识别系统--C++实现
20 6
|
3天前
|
数据采集 API 数据安全/隐私保护
畅游网络:构建C++网络爬虫的指南
本文介绍如何使用C++和cpprestsdk库构建高效网络爬虫,以抓取知乎热点信息。通过亿牛云爬虫代理服务解决IP限制问题,利用多线程提升数据采集速度。示例代码展示如何配置代理、发送HTTP请求及处理响应,实现多线程抓取。注意替换有效代理服务器参数,并处理异常。
畅游网络:构建C++网络爬虫的指南
|
16天前
|
XML JSON JavaScript
推荐一个比较好用的c++版本http协议库-cpp-httplib
推荐一个比较好用的c++版本http协议库-cpp-httplib
36 1
|
27天前
|
Shell Linux 网络安全
【Shell 命令集合 网络通讯 】Linux 管理Apache HTTP服务器 httpd命令 使用指南
【Shell 命令集合 网络通讯 】Linux 管理Apache HTTP服务器 httpd命令 使用指南
29 0
|
27天前
|
Shell Linux Apache
【Shell 命令集合 网络通讯 】Linux 管理Apache HTTP服务器 apachectl命令 使用教程
【Shell 命令集合 网络通讯 】Linux 管理Apache HTTP服务器 apachectl命令 使用教程
156 1
|
28天前
|
数据采集 缓存 前端开发
http和https请求服务器的时候在请求头部分都带什么到服务器呢?
HTTP和HTTPS请求头基本结构相似,HTTPS多了一层SSL/TLS加密。常见请求头如Accept(指定内容类型)、Authorization(身份验证)、Cookie(会话跟踪)、User-Agent(标识用户代理)等。HTTPS特有的头包括Upgrade-Insecure-Requests(升级到HTTPS)、Strict-Transport-Security(强制使用HTTPS)、Sec-Fetch-*(安全策略)和X-Content-Type-Options、X-Frame-Options等(增强安全性)。实际应用中,请求头会根据需求和安全策略变化。
20 0