我正在尝试获取远程用户的 telnet 连接使用的 TCP 端口号。
在 ssh 连接的情况下,我可以从 SSH_CLIENT 环境变量中获取它,但是在 telnet 连接的情况下如何获取它。是否有任何 C/Unix API 来获取它。
我尝试了以下代码:
u_int32_t
port_session_connected (void)
{
struct sockaddr_storage from;
char *ssh_client;
char *remote_port;
char *temp;
static char remoteport[1024];
int socklen;
int rv = 0, err;
if ((ssh_client = getenv("SSH_CLIENT")) != NULL) {
syslog("(%s): Have SSH_CLIENT: %s", __func__, ssh_client);
if ((temp = strtok(ssh_client, " \t")) != NULL) {
remote_port = strtok(NULL, " \t");
syslog("(%s): Remote port: %s", __func__, remote_port);
if (remote_port) rv = atoi(remote_port);
return rv;
}
} /* For ssh sessions */
socklen = sizeof(from);
if (getpeername(STDIN_FILENO, (struct sockaddr *)&from, &socklen) == 0) {
struct sockaddr_in *sck;
sck = (struct sockaddr_in *)&from;
syslog("(%s): getpeername() success", __func__);
syslog("(%s): Remote IP: %s\n", __func__, inet_ntoa(sck->sin_addr));
syslog("(%s): Remote Port: %d\n", __func__, (int)ntohs(sck->sin_port));
syslog("(%s): Family: %d\n", __func__, (int)(sck->sin_family));
err = getnameinfo((struct sockaddr *)&from, socklen, NULL, 0,
remoteport, sizeof(remoteport),NI_NUMERICSERV);
syslog("(%s): getnameinfo() return: %d", __func__, err);
if (err == 0) {
syslog(LOG_NOTICE, "(%s): getnameinfo() success", __func__);
syslog(LOG_NOTICE, "(%s): Remote port: %s", __func__, remoteport);
rv = atoi(remoteport);
return rv;
}
} /* For telnet session*/
return 0;
}
功能适用于 ssh 连接。但是对于 telnet 连接,我无法获取会话中使用的远程端口号。
登录 Telnet 案例:
(port_session_connected):getpeername()成功(port_session_connected):远程IP:0.0.0.0(port_session_connected):远程端口:0(port_session_connected):家庭:1(port_session_connected):getnameinfo()返回:5
getnameinfo() 失败,err=5,即 EAI_FAMILY /* ai_family not supported */ Family is 1,即 AF_UNIX。
是的,getnameinfo() 仅适用于 AF_INET 和 AF_INET6。
是否有任何 API 或无论如何可以获取 telnet 远程端口。
谢谢