使用libcurl实现tcp通信

使用libcurl实现tdp通信,网络服务器为58.247.150.223:8000,发送数据为test sending\n,并且可以接收服务器发回的数据。

/***************************************************************************
 *                                  _   _ ____  _
 *  Project                     ___| | | |  _ \| |
 *                             / __| | | | |_) | |
 *                            | (__| |_| |  _ <| |___
 *                             \___|\___/|_| \_\_____|
 *
 * Copyright (C) 1998 - 2016, Daniel Stenberg, <daniel@haxx.se>, et al.
 *
 * This software is licensed as described in the file COPYING, which
 * you should have received as part of this distribution. The terms
 * are also available at https://curl.haxx.se/docs/copyright.html.
 *
 * You may opt to use, copy, modify, merge, publish, distribute and/or sell
 * copies of the Software, and permit persons to whom the Software is
 * furnished to do so, under the terms of the COPYING file.
 *
 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
 * KIND, either express or implied.
 *
 ***************************************************************************/
/* <DESC>
 * An example of curl_easy_send() and curl_easy_recv() usage.
 * </DESC>
 */

#include <stdio.h>
#include <string.h>
#include <curl/curl.h>
#include <pthread.h>

CURL *curl;
CURLcode res;
curl_socket_t sockfd; /* socket */

/* Auxiliary function that waits on the socket. */
static int wait_on_socket(curl_socket_t sockfd, int for_recv, long timeout_ms)
{
	struct timeval tv;
	fd_set infd, outfd, errfd;
	int ret;

	tv.tv_sec = timeout_ms / 1000;
	tv.tv_usec= (timeout_ms % 1000) * 1000;

	FD_ZERO(&infd);
	FD_ZERO(&outfd);
	FD_ZERO(&errfd);

	FD_SET(sockfd, &errfd); /* always check for error */

	if(for_recv)
	{
		FD_SET(sockfd, &infd);
	}
	else
	{
		FD_SET(sockfd, &outfd);
	}

	/* select() returns the number of signalled sockets or -1 */
	ret = select(sockfd + 1, &infd, &outfd, &errfd, &tv);
	return ret;
}

void *test_recv()
{
	size_t iolen;
	curl_off_t nread;
	puts("Reading response.");

	/* read the response */
	for(;;)
	{
		char buf[1024] = {0};
		wait_on_socket(sockfd, 1, 60000L);
		res = curl_easy_recv(curl, buf, 1024, &iolen);

		if(CURLE_OK != res)
		break;

		nread = (curl_off_t)iolen;

		printf("%s\n", buf);
		printf("Received %" CURL_FORMAT_CURL_OFF_T " bytes.\n", nread);
	}
}

int main(void)
{
	/* Minimalistic http request */
	//const char *request = "GET / HTTP/1.0\r\nHost: example.com\r\n\r\n";
	const char *request = "test sending\n";
	long sockextr;
	size_t iolen;
	curl_off_t nread;

	/* A general note of caution here: if you're using curl_easy_recv() or
	curl_easy_send() to implement HTTP or _any_ other protocol libcurl
	supports "natively", you're doing it wrong and you should stop.

	This example uses HTTP only to show how to use this API, it does not
	suggest that writing an application doing this is sensible.
	*/

	curl = curl_easy_init();
	if(curl)
	{
		curl_easy_setopt(curl, CURLOPT_URL, "58.247.150.223");
		curl_easy_setopt(curl, CURLOPT_PORT, 8000);
		/* Do not do the transfer - only connect to host */
		curl_easy_setopt(curl, CURLOPT_CONNECT_ONLY, 1L);
		res = curl_easy_perform(curl);

		if(CURLE_OK != res)
		{
			printf("Error: %s\n", strerror(res));
			return 1;
		}

		/* Extract the socket from the curl handle - we'll need it for waiting.
		* Note that this API takes a pointer to a 'long' while we use
		* curl_socket_t for sockets otherwise.
		*/
		res = curl_easy_getinfo(curl, CURLINFO_LASTSOCKET, &sockextr);

		if(CURLE_OK != res)
		{
			printf("Error: %s\n", curl_easy_strerror(res));
			return 1;
		}

		sockfd = (curl_socket_t)sockextr;

		/* wait for the socket to become ready for sending */
		if(!wait_on_socket(sockfd, 0, 60000L))
		{
			printf("Error: timeout.\n");
			return 1;
		}

		pthread_t thread_recv_id;
		pthread_create(&thread_recv_id, NULL,(void *)*test_recv,NULL);

		puts("Sending request.");
		/* Send the request. Real applications should check the iolen
		* to see if all the request has been sent */
LOOP:
		res = curl_easy_send(curl, request, strlen(request), &iolen);

		if(CURLE_OK != res)
		{
			printf("Error: %s\n", curl_easy_strerror(res));
			return 1;
		}
		sleep(10);
		goto LOOP;

		/* always cleanup */
		curl_easy_cleanup(curl);
	}
	return 0;
}


  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
作为AI语言模型,我无法实际编写程序,但我可以提供一些概念性的思路和建议,希望对你有所帮助。 BMC (Baseboard Management Controller) 和 ME (Management Engine) 是两种用于服务器管理的技术。BMC 通常是一个独立的芯片,它可以通过网络或串口连接到主机,提供电源管理、远程控制、诊断等功能。ME 则是 Intel CPU 上的一个内置子系统,它可以在主机关闭或操作系统崩溃的情况下,通过网络连接进行远程管理和维护。 在 C 语言中,你可以使用一些库和 API 来实现和 BMC/ME 的通信。以下是一些可能有用的工具和技术: 1. IPMI (Intelligent Platform Management Interface):这是一种标准化的接口,用于 BMC 和管理软件之间的通信。IPMI 定义了一组命令、数据结构和协议,可以通过网络或串口进行传输。在 C 语言中,你可以使用 IPMI 库来封装和解析 IPMI 消息,例如 ipmitool、FreeIPMI 等。 2. MEI (Management Engine Interface):这是 Intel 提供的一种接口,用于 ME 和操作系统之间的通信。MEI 可以通过 PCI、SMBus、SPI 等总线进行传输。在 C 语言中,你可以使用 Intel MEI SDK 来访问 MEI 接口,例如 MEI Driver、MEI Client Library 等。 3. Serial 端口:BMC 通常会提供一个串口来进行本地调试和管理。你可以使用 C 语言中的串口库,如 termios、libserial、serialport 等,来读写串口数据。 4. 网络套接字:BMC 和 ME 可以通过网络进行远程管理。你可以使用 C 语言中的网络库,如 socket、libcurl、libevent 等,来建立 TCP 或 UDP 连接,发送和接收数据。 注意:BMC 和 ME 的通信需要一定的权限和认证机制,以确保安全性和可靠性。在实际应用中,你需要了解具体的协议和规范,并遵循相应的安全措施。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值