gpt4 book ai didi

c - 从 recvfrom 获取错误的 ip 地址和端口号

转载 作者:可可西里 更新时间:2023-11-01 10:19:16 25 4
gpt4 key购买 nike

无论我的 ip 和端口是什么,我都会得到以下 ip 和端口“204.204.204.204@52428”。我使用的是 windows 10 和 ipv4 地址

#include "stdafx.h"

#undef UNICODE

#define WIN32_LEAN_AND_MEAN

#include <windows.h>
#include <winsock2.h>
#include <ws2tcpip.h>
#include <stdlib.h>
#include <stdio.h>

// Need to link with Ws2_32.lib
#pragma comment (lib, "Ws2_32.lib")
// #pragma comment (lib, "Mswsock.lib")

#define DEFAULT_BUFLEN 512
#define DEFAULT_PORT "27015"

int __cdecl main(int argc, char **argv)
{
WSADATA wsaData;
int iResult;

SOCKET ListenSocket = INVALID_SOCKET;
SOCKET ClientSocket = INVALID_SOCKET;

struct addrinfo *result = NULL;
struct addrinfo hints;

int iSendResult;
char recvbuf[DEFAULT_BUFLEN];
int recvbuflen = DEFAULT_BUFLEN;

// Initialize Winsock
iResult = WSAStartup(MAKEWORD(2, 2), &wsaData);
if (iResult != 0) {
printf("WSAStartup failed with error: %d\n", iResult);
return 1;
}

ZeroMemory(&hints, sizeof(hints));
hints.ai_family = AF_INET;
hints.ai_socktype = SOCK_STREAM;
hints.ai_protocol = IPPROTO_TCP;
hints.ai_flags = AI_PASSIVE;

// Resolve the server address and port
iResult = getaddrinfo(NULL, argv[1], &hints, &result);
if (iResult != 0) {
printf("getaddrinfo failed with error: %d\n", iResult);
WSACleanup();
return 1;
}

// Create a SOCKET for connecting to server
ListenSocket = socket(result->ai_family, result->ai_socktype, result->ai_protocol);
if (ListenSocket == INVALID_SOCKET) {
printf("socket failed with error: %ld\n", WSAGetLastError());
freeaddrinfo(result);
WSACleanup();
return 1;
}

// Setup the TCP listening socket
iResult = bind(ListenSocket, result->ai_addr, (int)result->ai_addrlen);
if (iResult == SOCKET_ERROR) {
printf("bind failed with error: %d\n", WSAGetLastError());
freeaddrinfo(result);
closesocket(ListenSocket);
WSACleanup();
return 1;
}

freeaddrinfo(result);

iResult = listen(ListenSocket, SOMAXCONN);
if (iResult == SOCKET_ERROR) {
printf("listen failed with error: %d\n", WSAGetLastError());
closesocket(ListenSocket);
WSACleanup();
return 1;
}

// Accept a client socket
ClientSocket = accept(ListenSocket, NULL, NULL);
if (ClientSocket == INVALID_SOCKET) {
printf("accept failed with error: %d\n", WSAGetLastError());
closesocket(ListenSocket);
WSACleanup();
return 1;
}

// No longer need server socket
closesocket(ListenSocket);

struct sockaddr_in from_addr;
socklen_t fromlen = sizeof(from_addr);
char from_ip[2048] = "";
int nbytes = 0;

// Receive until the peer shuts down the connection
do {

nbytes = recvfrom(ClientSocket, recvbuf, recvbuflen, 0, (sockaddr *) &from_addr, &fromlen);
InetNtop(AF_INET, &from_addr.sin_addr, from_ip, sizeof(from_ip));

if (nbytes > 0) {
printf("Received %d bytes from %s@%d", nbytes, from_ip, ntohs(from_addr.sin_port));

// Echo the buffer back to the sender
iSendResult = send(ClientSocket, recvbuf, nbytes, 0);
if (iSendResult == SOCKET_ERROR) {
printf("send failed with error: %d\n", WSAGetLastError());
closesocket(ClientSocket);
WSACleanup();
return 1;
}
printf("\tBytes sent: %d\n", iSendResult);
}
else if (nbytes == 0)
printf("Connection closing...\n");
else {
printf("recv failed with error: %d\n", WSAGetLastError());
closesocket(ClientSocket);
WSACleanup();
return 1;
}
fromlen = sizeof(from_addr);

} while (nbytes > 0);

// shutdown the connection since we're done
iResult = shutdown(ClientSocket, SD_SEND);
if (iResult == SOCKET_ERROR) {
printf("shutdown failed with error: %d\n", WSAGetLastError());
closesocket(ClientSocket);
WSACleanup();
return 1;
}

// cleanup
closesocket(ClientSocket);
WSACleanup();

return 0;
}

打印在这个 block 中发生的地方

    struct sockaddr_in from_addr;
socklen_t fromlen = sizeof(from_addr);
char from_ip[2048] = "";
int nbytes = 0;

// Receive until the peer shuts down the connection
do {

nbytes = recvfrom(ClientSocket, recvbuf, recvbuflen, 0, (sockaddr *) &from_addr, &fromlen);
InetNtop(AF_INET, &from_addr.sin_addr, from_ip, sizeof(from_ip));

if (nbytes > 0) {
printf("Received %d bytes from %s@%d", nbytes, from_ip, ntohs(from_addr.sin_port));

// Echo the buffer back to the sender
iSendResult = send(ClientSocket, recvbuf, nbytes, 0);
if (iSendResult == SOCKET_ERROR) {
printf("send failed with error: %d\n", WSAGetLastError());
closesocket(ClientSocket);
WSACleanup();
return 1;
}
printf("\tBytes sent: %d\n", iSendResult);
}
else if (nbytes == 0)
printf("Connection closing...\n");
else {
printf("recv failed with error: %d\n", WSAGetLastError());
closesocket(ClientSocket);
WSACleanup();
return 1;
}
fromlen = sizeof(from_addr);

} while (nbytes > 0);

我不确定如何解决这个问题?

最佳答案

不要在 TCP 套接字上调用 recvfrom()。我很惊讶它能起作用;我想它会“恢复”到 recv() 行为并忽略源地址和长度参数。

您可以从 accept() 调用中获取对等方的地址信息。

关于c - 从 recvfrom 获取错误的 ip 地址和端口号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33625250/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com