bbs.qzwx.com:23
Connection Banner:
Server URLs
- bbs.qzwx.com:23
- Website: http://www.qzwx.com
Server Location: 🇺🇸 United States (GeoIP)
Listing
BBS Name: Colossus BBS (from listing)
Listed Location: Centreville, VA, USA
BBS Software
Reported: WWIV
Encoding
Effective encoding: cp437
Scanner detected: cp437
Telnet Fingerprint
This fingerprint is shared by 9 other servers.
Options offered by server: BINARY, ECHO, SGA
Options requested from client: BINARY, SGA, TTYPE
The complete JSON record collected during the scan, including Telnet negotiation results and banner data.
Show JSON
{
"server-probe": {
"fingerprint": "9f29f24cbaab5c1e",
"fingerprint-data": {
"offered-options": [
"BINARY",
"ECHO",
"SGA"
],
"probed-protocol": "server",
"refused-options": [
"AARDWOLF",
"ATCP",
"CHARSET",
"COM_PORT",
"EOR",
"GMCP",
"MCCP2",
"MCCP3",
"MSDP",
"MSP",
"MSSP",
"MXP",
"STATUS",
"ZMP"
],
"requested-options": [
"BINARY",
"SGA",
"TTYPE"
],
"scan-type": "quick"
},
"session_data": {
"banner_after_return": "Logging on at Telnet...\r\n\u001b[6n\r\n\r\n\u001b[40m\u001b[2J\u001b[2;1H\u001b[3;1H\u001b[4;1H\u001b[0;1mWelcome to\u001b[5;1H\u001b[6;1H\u001b[5C\u001b[33m\u2584\u2584\u2588\u2588\u2588\u2588\u2584\u2584\u001b[38C\u001b[0;33mSysOp: Dr. Forbin\u001b[7;1H \u001b[1m\u2584\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2584\u001b[36C\u001b[0;33mCo-SysOp: Dr. Kupri\u001b[8;1H \u001b[1m\u2588\u2588\u2588\u2588\u2588\u2580 \u2580\u2580\u2588\u2588\u2588\u2588 \u001b[34m1200/2400/9600/14.4K baud\u001b[9;1H \u001b[33m\u2590\u2588\u2588\u2588\u2588\u258c\u001b[6C\u2580\u2580 \u001b[34mV.3\u001b[s\r\n\u001b[u2,V.42,V.32bis,V.42bis\u001b[7C\u001b[30mMaintenance: 3:30am-3:45am\u001b[10;1H \u001b[33m\u2588\u2588\u2588\u2588\u2588\u001b[11;1H\u2590\u2588\u2588\u2588\u2588\u258c\u001b[10C\u2584\u2584\u2588\u2588\u2584\u2584 \u2584\u2588\u2584\u001b[6C\u2584\u2584\u2588\u2588\u2584\u2584 \u2584\u2584\u2588\u2588\u2588\u2588\u2584 \u2584\u2584\u2588\u2588\u2588\u2588\u2584 \u2584\u2588\u2588\u2584 \u2584\u2588\u2588\u2584 \u2584\u2584\u2588\u2588\u2588\u2588\u2584\u001b[12;1H\u2590\u2588\u2588\u2588\u2588\u258c\u001b[9C\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2590\u2588\u2588\u2588\u258c \u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588 \u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u258c\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u258c\u2588\u2588\u2588\u2588 \u2588\u2588\u2588\u2588\u258c\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u258c\u001b[13;1H \u2588\u2588\u2588\u2588\u2588\u001b[8C\u001b[s\r\n\u001b[u\u2590\u2588\u2588\u2588\u2580\u2580\u2588\u2588\u2588\u258c\u2588\u2588\u2588\u2588 \u2590\u2588\u2588\u2588\u2580\u2580\u2588\u2588\u2588\u258c\u2588\u2588\u2588\u2588 \u2580\u2580\u2580\u2590\u2588\u2588\u2588\u2588 \u2580\u2580\u2580\u2590\u2588\u2588\u2588\u2588 \u2588\u2588\u2588\u2588\u258c\u2588\u2588\u2588\u2588 \u2580\u2580\u2580\u001b[14;1H \u2590\u2588\u2588\u2588\u2588\u258c\u001b[6C\u2584\u2584\u2580\u2588\u258c \u2590\u2588\u2588\u2588\u2590\u2588\u2588\u2588 \u2588\u2588\u2588\u258c \u2590\u2588\u2588\u2588 \u2588\u2588\u2588\u2588\u2588\u2584 \u2580\u2588\u2588\u2588\u2588\u2588\u2584 \u2590\u2588\u2588\u2588\u2588 \u2588\u2588\u2588\u2588\u258c\u2580\u2588\u2588\u2588\u2588\u2588\u2584\u001b[15;1H \u2588\u2588\u2588\u2588\u2588\u2584 \u2584\u2584\u2588\u2588\u2588\u2588\u2590\u2588\u2584\u2584\u2588\u2588\u2588\u258c\u2588\u2588\u2588\u2588 \u2584\u2584\u2580\u2588\u2588\u2584\u2584\u2588\u2588\u2588\u258c\u2584\u2584 \u2580\u2588\u2588\u2588\u2588\u2584 \u2584 \u2580\u2588\u2588\u2588\u2588\u2584\u2590\u2588\u2588\u2588\u2584\u2588\u2588\u2588\u2588 \u2584\u2584 \u2580\u2588\u2588\u2588\u2588\u2584\u001b[16;1H \u2580\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u001b[s\r\n\u001b[u\u2588\u2580\u2584\u2588\u2588\u2588\u2588\u2588\u2588\u2588 \u2590\u2588\u2588\u2588\u2584\u2588\u2588\u2588\u258c\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2590\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2590\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2590\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u258c\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u001b[17;1H\u001b[5C\u2580\u2580\u2588\u2588\u2588\u2588\u2580\u2580 \u2580\u2580\u2588\u2588\u2580\u2580 \u2580\u2588\u2588\u2588\u2588\u2588\u2580 \u2580\u2580\u2588\u2588\u2580\u2580 \u2580\u2580\u2588\u2588\u2588\u2588\u2588\u2580\u2580 \u2580\u2580\u2588\u2588\u2588\u2588\u2588\u2580 \u2580\u2588\u2588\u2588\u2588\u2588\u2588\u2580 \u2580\u2580\u2588\u2588\u2588\u2588\u2588\u2580\u2580\u001b[0m\u001b[255D\u001b[A\r\n\r\n\r\nEnter number or name or 'NEW'\r\nNN: ",
"banner_before_return": "",
"dsr_replies": 1,
"dsr_requests": 1,
"encoding": "cp437",
"option_states": {
"server_offered": {
"AARDWOLF": false,
"ATCP": false,
"BINARY": true,
"ECHO": true,
"GMCP": false,
"MCCP2": false,
"MCCP3": false,
"MSDP": false,
"MSP": false,
"MSSP": false,
"MXP": false,
"SGA": true,
"ZMP": false
},
"server_requested": {
"AARDWOLF": false,
"ATCP": false,
"BINARY": true,
"GMCP": false,
"MCCP2": false,
"MCCP3": false,
"MSDP": false,
"MSP": false,
"MSSP": false,
"MXP": false,
"SGA": true,
"TTYPE": true,
"ZMP": false
}
},
"scan_type": "quick",
"timing": {
"probe": 0.10465240478515625,
"total": 15.143114805221558
}
}
},
"sessions": [
{
"connected": "2026-03-07T04:17:04.720034+00:00",
"host": "bbs.qzwx.com",
"ip": "98.187.238.116",
"port": 23
}
]
}
Connection Log
Debug-level log of the Telnet negotiation session, showing each IAC (Interpret As Command) exchange between client and server.
Generated by telnetlib3-fingerprint
telnetlib3-fingerprint --loglevel=debug bbs.qzwx.com 23
Show Logfile
DEBUG client.py:1193 Fingerprint client: host=bbs.qzwx.com port=23
INFO client_base.py:186 Connected to <Peer 98.187.238.116 23>
DEBUG stream_writer.py:3330 pending_option[WILL + MXP] = True
DEBUG stream_writer.py:1019 send IAC WILL MXP
DEBUG stream_writer.py:3330 pending_option[WILL + ATCP] = True
DEBUG stream_writer.py:1019 send IAC WILL ATCP
DEBUG stream_writer.py:3330 pending_option[WILL + MCCP3_COMPRESS] = True
DEBUG stream_writer.py:1019 send IAC WILL MCCP3_COMPRESS
DEBUG stream_writer.py:3330 pending_option[WILL + GMCP] = True
DEBUG stream_writer.py:1019 send IAC WILL GMCP
DEBUG stream_writer.py:3330 pending_option[WILL + AARDWOLF] = True
DEBUG stream_writer.py:1019 send IAC WILL AARDWOLF
DEBUG stream_writer.py:3330 pending_option[WILL + MSP] = True
DEBUG stream_writer.py:1019 send IAC WILL MSP
DEBUG stream_writer.py:3330 pending_option[WILL + MSDP] = True
DEBUG stream_writer.py:1019 send IAC WILL MSDP
DEBUG stream_writer.py:3330 pending_option[WILL + MSSP] = True
DEBUG stream_writer.py:1019 send IAC WILL MSSP
DEBUG stream_writer.py:3330 pending_option[WILL + ZMP] = True
DEBUG stream_writer.py:1019 send IAC WILL ZMP
DEBUG stream_writer.py:3330 pending_option[WILL + MCCP2_COMPRESS] = True
DEBUG stream_writer.py:1019 send IAC WILL MCCP2_COMPRESS
DEBUG stream_writer.py:3330 pending_option[DO + MXP] = True
DEBUG stream_writer.py:1019 send IAC DO MXP
DEBUG stream_writer.py:3330 pending_option[DO + ATCP] = True
DEBUG stream_writer.py:1019 send IAC DO ATCP
DEBUG stream_writer.py:3330 pending_option[DO + MCCP3_COMPRESS] = True
DEBUG stream_writer.py:1019 send IAC DO MCCP3_COMPRESS
DEBUG stream_writer.py:3330 pending_option[DO + GMCP] = True
DEBUG stream_writer.py:1019 send IAC DO GMCP
DEBUG stream_writer.py:3330 pending_option[DO + AARDWOLF] = True
DEBUG stream_writer.py:1019 send IAC DO AARDWOLF
DEBUG stream_writer.py:3330 pending_option[DO + MSP] = True
DEBUG stream_writer.py:1019 send IAC DO MSP
DEBUG stream_writer.py:3330 pending_option[DO + MSDP] = True
DEBUG stream_writer.py:1019 send IAC DO MSDP
DEBUG stream_writer.py:3330 pending_option[DO + MSSP] = True
DEBUG stream_writer.py:1019 send IAC DO MSSP
DEBUG stream_writer.py:3330 pending_option[DO + ZMP] = True
DEBUG stream_writer.py:1019 send IAC DO ZMP
DEBUG stream_writer.py:3330 pending_option[DO + MCCP2_COMPRESS] = True
DEBUG stream_writer.py:1019 send IAC DO MCCP2_COMPRESS
DEBUG stream_writer.py:768 recv IAC WILL SGA
DEBUG stream_writer.py:784 WILL SGA unsolicited
DEBUG stream_writer.py:1994 handle_will(SGA)
DEBUG stream_writer.py:3330 pending_option[DO + SGA] = True
DEBUG stream_writer.py:1019 send IAC DO SGA
DEBUG stream_writer.py:3330 remote_option[SGA] = True
DEBUG stream_writer.py:3330 pending_option[DO + SGA] = False
DEBUG stream_writer.py:768 recv IAC WILL BINARY
DEBUG stream_writer.py:784 WILL BINARY unsolicited
DEBUG stream_writer.py:1994 handle_will(BINARY)
DEBUG stream_writer.py:3330 pending_option[DO + BINARY] = True
DEBUG stream_writer.py:1019 send IAC DO BINARY
DEBUG stream_writer.py:3330 remote_option[BINARY] = True
DEBUG stream_writer.py:3330 pending_option[DO + BINARY] = False
DEBUG stream_writer.py:768 recv IAC WILL BINARY
DEBUG stream_writer.py:784 WILL BINARY unsolicited
DEBUG stream_writer.py:1994 handle_will(BINARY)
DEBUG stream_writer.py:768 recv IAC DO BINARY
DEBUG stream_writer.py:1836 handle_do(BINARY)
DEBUG stream_writer.py:3330 pending_option[WILL + BINARY] = True
DEBUG stream_writer.py:1019 send IAC WILL BINARY
DEBUG stream_writer.py:3330 local_option[BINARY] = True
DEBUG stream_writer.py:3330 pending_option[WILL + BINARY] = False
DEBUG stream_writer.py:768 recv IAC DO SGA
DEBUG stream_writer.py:1836 handle_do(SGA)
DEBUG stream_writer.py:3330 pending_option[WILL + SGA] = True
DEBUG stream_writer.py:1019 send IAC WILL SGA
DEBUG stream_writer.py:3330 local_option[SGA] = True
DEBUG stream_writer.py:3330 pending_option[WILL + SGA] = False
DEBUG stream_writer.py:768 recv IAC DO TTYPE
DEBUG stream_writer.py:1836 handle_do(TTYPE)
DEBUG stream_writer.py:3330 pending_option[WILL + TTYPE] = True
DEBUG stream_writer.py:1019 send IAC WILL TTYPE
DEBUG stream_writer.py:3330 pending_option[SB + TTYPE] = True
DEBUG stream_writer.py:3330 local_option[TTYPE] = True
DEBUG stream_writer.py:3330 pending_option[WILL + TTYPE] = False
DEBUG stream_writer.py:768 recv IAC WILL ECHO
DEBUG stream_writer.py:784 WILL ECHO unsolicited
DEBUG stream_writer.py:1994 handle_will(ECHO)
DEBUG stream_writer.py:3330 pending_option[DO + ECHO] = True
DEBUG stream_writer.py:1019 send IAC DO ECHO
DEBUG stream_writer.py:3330 remote_option[ECHO] = True
DEBUG stream_writer.py:3330 pending_option[DO + ECHO] = False
DEBUG stream_writer.py:768 recv IAC DONT MXP
DEBUG stream_writer.py:1959 handle_dont(MXP)
DEBUG stream_writer.py:3330 pending_option[WILL + MXP] = False
DEBUG stream_writer.py:3330 local_option[MXP] = False
DEBUG stream_writer.py:768 recv IAC DONT ATCP
DEBUG stream_writer.py:1959 handle_dont(ATCP)
DEBUG stream_writer.py:3330 pending_option[WILL + ATCP] = False
DEBUG stream_writer.py:3330 local_option[ATCP] = False
DEBUG stream_writer.py:768 recv IAC DONT MCCP3_COMPRESS
DEBUG stream_writer.py:1959 handle_dont(MCCP3_COMPRESS)
DEBUG stream_writer.py:3330 pending_option[WILL + MCCP3_COMPRESS] = False
DEBUG stream_writer.py:3330 local_option[MCCP3_COMPRESS] = False
DEBUG stream_writer.py:768 recv IAC DONT GMCP
DEBUG stream_writer.py:1959 handle_dont(GMCP)
DEBUG stream_writer.py:3330 pending_option[WILL + GMCP] = False
DEBUG stream_writer.py:3330 local_option[GMCP] = False
DEBUG stream_writer.py:768 recv IAC DONT AARDWOLF
DEBUG stream_writer.py:1959 handle_dont(AARDWOLF)
DEBUG stream_writer.py:3330 pending_option[WILL + AARDWOLF] = False
DEBUG stream_writer.py:3330 local_option[AARDWOLF] = False
DEBUG stream_writer.py:768 recv IAC DONT MSP
DEBUG stream_writer.py:1959 handle_dont(MSP)
DEBUG stream_writer.py:3330 pending_option[WILL + MSP] = False
DEBUG stream_writer.py:3330 local_option[MSP] = False
DEBUG stream_writer.py:768 recv IAC DONT MSDP
DEBUG stream_writer.py:1959 handle_dont(MSDP)
DEBUG stream_writer.py:3330 pending_option[WILL + MSDP] = False
DEBUG stream_writer.py:3330 local_option[MSDP] = False
DEBUG stream_writer.py:768 recv IAC DONT MSSP
DEBUG stream_writer.py:1959 handle_dont(MSSP)
DEBUG stream_writer.py:3330 pending_option[WILL + MSSP] = False
DEBUG stream_writer.py:3330 local_option[MSSP] = False
DEBUG stream_writer.py:768 recv IAC DONT ZMP
DEBUG stream_writer.py:1959 handle_dont(ZMP)
DEBUG stream_writer.py:3330 pending_option[WILL + ZMP] = False
DEBUG stream_writer.py:3330 local_option[ZMP] = False
DEBUG stream_writer.py:768 recv IAC DONT MCCP2_COMPRESS
DEBUG stream_writer.py:1959 handle_dont(MCCP2_COMPRESS)
DEBUG stream_writer.py:3330 pending_option[WILL + MCCP2_COMPRESS] = False
DEBUG stream_writer.py:3330 local_option[MCCP2_COMPRESS] = False
DEBUG stream_writer.py:768 recv IAC WONT MXP
DEBUG stream_writer.py:2148 handle_wont(MXP)
DEBUG stream_writer.py:3330 remote_option[MXP] = False
DEBUG stream_writer.py:3330 pending_option[DO + MXP] = False
DEBUG stream_writer.py:768 recv IAC WONT ATCP
DEBUG stream_writer.py:2148 handle_wont(ATCP)
DEBUG stream_writer.py:3330 remote_option[ATCP] = False
DEBUG stream_writer.py:3330 pending_option[DO + ATCP] = False
DEBUG stream_writer.py:768 recv IAC WONT MCCP3_COMPRESS
DEBUG stream_writer.py:2148 handle_wont(MCCP3_COMPRESS)
DEBUG stream_writer.py:3330 remote_option[MCCP3_COMPRESS] = False
DEBUG stream_writer.py:3330 pending_option[DO + MCCP3_COMPRESS] = False
DEBUG stream_writer.py:768 recv IAC WONT GMCP
DEBUG stream_writer.py:2148 handle_wont(GMCP)
DEBUG stream_writer.py:3330 remote_option[GMCP] = False
DEBUG stream_writer.py:3330 pending_option[DO + GMCP] = False
DEBUG stream_writer.py:768 recv IAC WONT AARDWOLF
DEBUG stream_writer.py:2148 handle_wont(AARDWOLF)
DEBUG stream_writer.py:3330 remote_option[AARDWOLF] = False
DEBUG stream_writer.py:3330 pending_option[DO + AARDWOLF] = False
DEBUG stream_writer.py:768 recv IAC WONT MSP
DEBUG stream_writer.py:2148 handle_wont(MSP)
DEBUG stream_writer.py:3330 remote_option[MSP] = False
DEBUG stream_writer.py:3330 pending_option[DO + MSP] = False
DEBUG stream_writer.py:768 recv IAC WONT MSDP
DEBUG stream_writer.py:2148 handle_wont(MSDP)
DEBUG stream_writer.py:3330 remote_option[MSDP] = False
DEBUG stream_writer.py:3330 pending_option[DO + MSDP] = False
DEBUG stream_writer.py:768 recv IAC WONT MSSP
DEBUG stream_writer.py:2148 handle_wont(MSSP)
DEBUG stream_writer.py:3330 remote_option[MSSP] = False
DEBUG stream_writer.py:3330 pending_option[DO + MSSP] = False
DEBUG stream_writer.py:768 recv IAC WONT ZMP
DEBUG stream_writer.py:2148 handle_wont(ZMP)
DEBUG stream_writer.py:3330 remote_option[ZMP] = False
DEBUG stream_writer.py:3330 pending_option[DO + ZMP] = False
DEBUG stream_writer.py:768 recv IAC WONT MCCP2_COMPRESS
DEBUG stream_writer.py:2148 handle_wont(MCCP2_COMPRESS)
DEBUG stream_writer.py:3330 remote_option[MCCP2_COMPRESS] = False
DEBUG stream_writer.py:3330 pending_option[DO + MCCP2_COMPRESS] = False
DEBUG stream_writer.py:762 begin sub-negotiation SB TTYPE
DEBUG stream_writer.py:749 sub-negotiation cmd TTYPE SE completion byte
DEBUG stream_writer.py:3330 pending_option[SB + TTYPE] = False
DEBUG stream_writer.py:2353 recv TTYPE SEND: b''
DEBUG stream_writer.py:2365 send IAC SB TTYPE IS b'xterm-256color' IAC SE
DEBUG client_base.py:496 negotiation complete after 0.20s.
DEBUG stream_writer.py:3330 pending_option[DO + STATUS] = True
DEBUG stream_writer.py:1019 send IAC DO STATUS
DEBUG stream_writer.py:3330 pending_option[DO + CHARSET] = True
DEBUG stream_writer.py:1019 send IAC DO CHARSET
DEBUG stream_writer.py:3330 pending_option[DO + EOR] = True
DEBUG stream_writer.py:1019 send IAC DO EOR
DEBUG stream_writer.py:3330 pending_option[DO + COM_PORT_OPTION] = True
DEBUG stream_writer.py:1019 send IAC DO COM_PORT_OPTION
DEBUG stream_writer.py:768 recv IAC WONT STATUS
DEBUG stream_writer.py:2148 handle_wont(STATUS)
DEBUG stream_writer.py:3330 remote_option[STATUS] = False
DEBUG stream_writer.py:3330 pending_option[DO + STATUS] = False
DEBUG stream_writer.py:768 recv IAC WONT CHARSET
DEBUG stream_writer.py:2148 handle_wont(CHARSET)
DEBUG stream_writer.py:3330 remote_option[CHARSET] = False
DEBUG stream_writer.py:3330 pending_option[DO + CHARSET] = False
DEBUG stream_writer.py:768 recv IAC WONT EOR
DEBUG stream_writer.py:2148 handle_wont(EOR)
DEBUG stream_writer.py:3330 remote_option[EOR] = False
DEBUG stream_writer.py:3330 pending_option[DO + EOR] = False
DEBUG stream_writer.py:768 recv IAC WONT COM_PORT_OPTION
DEBUG stream_writer.py:2148 handle_wont(COM_PORT_OPTION)
DEBUG stream_writer.py:3330 remote_option[COM_PORT_OPTION] = False
DEBUG stream_writer.py:3330 pending_option[DO + COM_PORT_OPTION] = False
INFO fingerprinting.py:755 connection for server fingerprint 9f29f24cbaab5c1e
INFO client_base.py:118 Connection closed to <Peer 98.187.238.116 23>