0

我正在尝试获取远程用户的 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 远程端口。

谢谢

4

1 回答 1

1

对等体的地址由accept()服务器端的调用返回。由于这是由 telnet 守护程序完成的,因此无法从您的代码中访问它(参见Stevens, Vol.1 p.118)。

因此,一种可能的方法是编写某种代理,它接受传入的连接,记录对等地址信息,然后建立与真正的 telnet 守护程序的连接并将连接传递给它。

于 2012-11-23T08:32:09.397 回答