|
|
| ssl_socket ()=default |
| | 默认构造函数
|
| | ssl_socket (const native_handle_type fd) |
| | 从原生句柄构造
|
| | ssl_socket (tcp_socket sock) |
| | 从TCP socket转移构造
|
|
| ~ssl_socket () override=default |
| | 析构函数
|
| void | init_server_ssl (const ssl_context &ctx) |
| | 初始化服务器端SSL
|
| void | init_client_ssl (const ssl_context &ctx, const string &hostname="") |
| | 初始化客户端端SSL
|
| NEFORCE_NODISCARD string | peer_certificate_info () const |
| | 获取对等方证书信息
|
| ssize_t | send (memory_view< const char > data, int flags=0) override |
| | 发送加密数据
|
| ssize_t | receive (memory_view< char > buffer, int flags=0) override |
| | 接收解密数据
|
| NEFORCE_NODISCARD bool | is_ssl () const noexcept override |
| | 检查是否为SSL/TLS socket
|
| NEFORCE_NODISCARD ssl_stream & | ssl () noexcept |
| | 获取SSL流对象的引用
|
| NEFORCE_NODISCARD const ssl_stream & | ssl () const noexcept |
| | 获取SSL流对象的常量引用
|
|
| tcp_socket ()=default |
| | 默认构造函数
|
| | tcp_socket (native_handle_type fd) |
| | 从原生句柄构造
|
|
| ~tcp_socket () override=default |
| | 析构函数
|
| void | open (int family=AF_INET) |
| | 打开TCP socket
|
| bool | connect (const ip_address &endpoint, milliseconds timeout, bool was_blocking=true) |
| | 连接到远程服务器
|
| ssize_t | send (memory_view< const char > data, milliseconds timeout, int flags=0) |
| | 带超时的发送数据
|
| void | send_all (memory_view< const char > data) |
| | 发送所有数据
|
| vector< char > | receive_all (size_t expected_size) |
| | 接收指定大小的所有数据
|
|
| ip_socket ()=default |
| | 默认构造函数
|
| | ip_socket (const native_handle_type fd) noexcept |
| | 从原生句柄构造
|
|
| ~ip_socket () override=default |
| | 析构函数
|
| NEFORCE_NODISCARD int | address_family () const noexcept |
| | 获取地址族
|
| NEFORCE_NODISCARD bool | is_ipv4 () const noexcept |
| | 检查是否为IPv4 socket
|
| NEFORCE_NODISCARD bool | is_ipv6 () const noexcept |
| | 检查是否为IPv6 socket
|
| virtual void | connect (const ip_address &endpoint) |
| | 连接到远程端点(TCP客户端)
|
| bool | close () noexcept override |
| | 关闭socket
|
|
| socket_base () |
| | 默认构造函数
|
| | socket_base (const native_handle_type fd) noexcept |
| | 从原生句柄构造
|
| | socket_base (socket_base &&other) noexcept |
| | 移动构造函数
|
| socket_base & | operator= (socket_base &&other) noexcept |
| | 移动赋值运算符
|
|
virtual | ~socket_base () |
| | 析构函数
|
| NEFORCE_NODISCARD native_handle_type | native_handle () const noexcept |
| | 获取原生句柄
|
| NEFORCE_NODISCARD bool | is_open () const noexcept |
| | 检查socket是否已打开
|
| | operator bool () const noexcept |
| | 布尔转换运算符
|
| void | open (int family, int type, int protocol) |
| | 打开socket
|
| bool | try_open (int family, int type, int protocol) noexcept |
| | 尝试打开socket(不抛出异常)
|
| bool | set_nonblocking (bool enable) noexcept |
| | 设置非阻塞模式
|
| bool | shutdown_send () noexcept |
| | 关闭发送方向
|
| bool | shutdown_receive () noexcept |
| | 关闭接收方向
|
| bool | shutdown_both () noexcept |
| | 关闭双向通信
|
| bool | set_option (int level, int optname, const void *value, ::socklen_t len) noexcept |
| | 设置socket选项
|
| bool | get_option (int level, int optname, void *optval, ::socklen_t *optlen) const noexcept |
| | 获取socket选项
|
| bool | set_reuse_address (bool enable=true) noexcept |
| | 设置地址重用(SO_REUSEADDR)
|
| bool | set_reuse_port (bool enable=true) noexcept |
| | 设置端口重用(SO_REUSEPORT)
|
| bool | set_keep_alive (bool enable=true) noexcept |
| | 设置TCP KeepAlive
|
| bool | set_tcp_nodelay (bool enable=true) noexcept |
| | 设置TCP_NODELAY(禁用Nagle算法)
|
| bool | set_receive_buffer_size (int size) noexcept |
| | 设置接收缓冲区大小
|
| bool | set_send_buffer_size (int size) noexcept |
| | 设置发送缓冲区大小
|
| bool | set_send_timeout (milliseconds timeout) noexcept |
| | 设置发送超时时间
|
| bool | set_receive_timeout (milliseconds timeout) noexcept |
| | 设置接收超时时间
|
| NEFORCE_NODISCARD optional< ip_address > | local_endpoint () const |
| | 获取本地端点地址
|
| NEFORCE_NODISCARD optional< ip_address > | remote_endpoint () const |
| | 获取远程端点地址
|
| void | bind (const ip_address &endpoint) |
| | 绑定socket到本地地址
|
| void | listen (int backlog) |
| | 开始监听连接(TCP)
|
| NEFORCE_NODISCARD native_handle_type | release () noexcept |
| | 释放socket所有权
|
SSL/TLS安全Socket类
实现SSL/TLS加密的TCP socket,提供安全的网络通信。 继承自tcp_socket,可以透明地替换普通TCP socket。
主要功能:
- SSL/TLS客户端初始化
- SSL/TLS服务器端初始化
- 加密数据发送和接收
- 对等方证书信息获取
- 无缝透明替换TCP socket
使用示例:
ctx.load_verify_locations("ca-bundle.crt");
string request = "GET / HTTP/1.1\r\nHost: example.com\r\n\r\n";
char buffer[4096];
if (received > 0) {
}
server_ctx.load_certificate("server.crt", "server.key");
ssl_acceptor acceptor;
client_sock.set_ssl_context(server_ctx);
NEFORCE_NODISCARD NEFORCE_CONSTEXPR20 view_type view() const noexcept
获取字符串视图
static NEFORCE_NODISCARD ip_address any(ports port=ports::undef, int family=AF_INET) noexcept
获取通配地址
static NEFORCE_NODISCARD optional< ip_address > parse(const string &host, ports port=ports{}) noexcept
从字符串解析IP地址
NEFORCE_NODISCARD ssl_socket accept_ssl()
接受TLS客户端连接
ssize_t receive(memory_view< char > buffer, int flags=0) override
接收解密数据
ssl_socket()=default
默认构造函数
NEFORCE_NODISCARD string peer_certificate_info() const
获取对等方证书信息
void init_client_ssl(const ssl_context &ctx, const string &hostname="")
初始化客户端端SSL
void open(const ip_address &endpoint, int backlog=SOMAXCONN)
打开并开始监听
void send_all(memory_view< const char > data)
发送所有数据
void open(int family=AF_INET)
打开TCP socket
bool connect(const ip_address &endpoint, milliseconds timeout, bool was_blocking=true)
连接到远程服务器
void println(Args &&... args)
打印多个值并换行
duration< int64_t, milli > milliseconds
毫秒持续时间
basic_string_view< char > string_view
字符字符串视图
在文件 ssl_socket.hpp 第 79 行定义.