gpt4 book ai didi

C-Server 行为不合理

转载 作者:太空宇宙 更新时间:2023-11-04 01:51:25 26 4
gpt4 key购买 nike

C-SERVER 设计为在收到“111”时打印“ok
没有别的。

(我想不出删除 \n 的方法,所以准确地说是 “111\n”。)

echo '111' | nc <ip> <port>
echo 'TEST-OOO' | nc <ip> <port>
echo '111' | nc <ip> <port>

C-SERVER:(上面3个连接到下面的响应)

111
ok

TEST-OOO

111
-OOO

STRANGE :为什么打印 -OOO

它被设计为在获得“111”时打印“ok”。不是-OOO

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netdb.h>
#include <arpa/inet.h>
#include <err.h>
#include <string.h>

char outt[15];
char inn[100];

int main()
{
int one = 1, client_fd;
struct sockaddr_in svr_addr, cli_addr;
socklen_t sin_len = sizeof(cli_addr);

int sock = socket(AF_INET, SOCK_STREAM, 0);
if (sock < 0)
err(1, "can't open socket");

setsockopt(sock, SOL_SOCKET, SO_REUSEADDR, &one, sizeof(int));

int port = 85;
svr_addr.sin_family = AF_INET;
svr_addr.sin_addr.s_addr = INADDR_ANY;
svr_addr.sin_port = htons(port);

if (bind(sock, (struct sockaddr *) &svr_addr, sizeof(svr_addr)) == -1) {
close(sock);
err(1, "Can't bind");
}

listen(sock, 5);
while (1) {
client_fd = accept(sock, (struct sockaddr *) &cli_addr, &sin_len);

read(client_fd,inn,100);
printf(inn);

if (strcmp( inn, "111\n" ) == 0){
printf("ok\n");
}

snprintf(outt, sizeof outt, "%s\n", inet_ntoa(cli_addr.sin_addr));


if (client_fd == -1) {
perror("Can't accept");
continue;
}

write(client_fd, outt, sizeof(outt) - 1); /*-1:'\0'*/
close(client_fd);
}
}

最佳答案

这段代码:

read(client_fd,inn,100);
printf(inn);

是未定义的行为。 read() 不会以 NUL 字符终止接收到的数据。在这种情况下,inn 的内容会出现在输出中,因为它们仍然存在

这样会更好:

ssize_t bytesRead = read(client_fd,inn,sizeof(inn) - 1);
if ( bytesRead > 0 )
{
inn[ bytesRead ] = '\0';
printf(inn);
}

将打印作为 NUL 终止字符串发送的数据,假设客户端实际上发送了一个没有 NUL 终止的 C 风格字符串。

关于C-Server 行为不合理,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42276587/

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