在Linux系統中,C++可以通過多種方式處理網絡通信。以下是一些常用的方法和庫:
套接字是網絡通信的基礎,C++可以通過POSIX套接字API進行網絡編程。
socket()函數。bind()函數將套接字綁定到特定的IP地址和端口。listen()函數監聽傳入的連接請求。accept()函數接受連接請求。send()和recv()函數進行數據傳輸。close()函數關閉套接字。#include <iostream>
#include <sys/socket.h>
#include <netinet/in.h>
#include <unistd.h>
int main() {
int server_fd, new_socket;
struct sockaddr_in address;
int opt = 1;
int addrlen = sizeof(address);
char buffer[1024] = {0};
// 創建套接字
if ((server_fd = socket(AF_INET, SOCK_STREAM, 0)) == 0) {
perror("socket failed");
exit(EXIT_FAILURE);
}
// 綁定地址
if (setsockopt(server_fd, SOL_SOCKET, SO_REUSEADDR | SO_REUSEPORT, &opt, sizeof(opt))) {
perror("setsockopt");
exit(EXIT_FAILURE);
}
address.sin_family = AF_INET;
address.sin_addr.s_addr = INADDR_ANY;
address.sin_port = htons(8080);
if (bind(server_fd, (struct sockaddr *)&address, sizeof(address)) < 0) {
perror("bind failed");
exit(EXIT_FAILURE);
}
// 監聽連接
if (listen(server_fd, 3) < 0) {
perror("listen");
exit(EXIT_FAILURE);
}
// 接受連接
if ((new_socket = accept(server_fd, (struct sockaddr *)&address, (socklen_t*)&addrlen)) < 0) {
perror("accept");
exit(EXIT_FAILURE);
}
// 數據傳輸
read(new_socket, buffer, 1024);
std::cout << "Message received: " << buffer << std::endl;
send(new_socket, "Hello from server", 17, 0);
// 關閉套接字
close(new_socket);
close(server_fd);
return 0;
}
Boost.Asio是一個跨平臺的C++庫,用于網絡和低級I/O編程。
boost::asio::io_service。boost::asio::ip::tcp::socket。connect()或listen()和accept()。write()和read()。#include <iostream>
#include <boost/asio.hpp>
using boost::asio::ip::tcp;
int main() {
try {
boost::asio::io_service io_service;
tcp::acceptor acceptor(io_service, tcp::endpoint(tcp::v4(), 8080));
tcp::socket socket(io_service);
// 接受連接
acceptor.accept(socket);
// 數據傳輸
char buffer[1024] = {0};
boost::asio::read(socket, boost::asio::buffer(buffer, 1024));
std::cout << "Message received: " << buffer << std::endl;
boost::asio::write(socket, boost::asio::buffer("Hello from server", 17));
// 關閉套接字
socket.close();
} catch (std::exception& e) {
std::cerr << "Exception: " << e.what() << std::endl;
}
return 0;
}
libcurl是一個用于傳輸數據的庫,支持多種協議,包括HTTP、HTTPS、FTP等。
curl_global_init()。curl_easy_init()。curl_easy_setopt()設置URL、請求方法等。curl_easy_perform()。curl_easy_cleanup()和curl_global_cleanup()。#include <iostream>
#include <curl/curl.h>
static size_t WriteCallback(void* contents, size_t size, size_t nmemb, void* userp) {
((std::string*)userp)->append((char*)contents, size * nmemb);
return size * nmemb;
}
int main() {
CURL* curl;
CURLcode res;
std::string readBuffer;
curl_global_init(CURL_GLOBAL_DEFAULT);
curl = curl_easy_init();
if(curl) {
curl_easy_setopt(curl, CURLOPT_URL, "http://example.com");
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, WriteCallback);
curl_easy_setopt(curl, CURLOPT_WRITEDATA, &readBuffer);
res = curl_easy_perform(curl);
curl_easy_cleanup(curl);
if(res != CURLE_OK) {
std::cerr << "curl_easy_perform() failed: " << curl_easy_strerror(res) << std::endl;
} else {
std::cout << "Response: " << readBuffer << std::endl;
}
}
curl_global_cleanup();
return 0;
}
根據具體需求選擇合適的庫和方法進行網絡通信。