本篇博客记录本次使用golang语言tcp方式进行telnet服务器访问

环境:

1、win7系统telnet服务器,使用地址:192.168.8.189

2、python使用telnetlib库对telnet服务器进行访问的客户端例程

3、服务端用户名:admin  密码:123456

本次功能实现过程:

第一步:抓包获取telnet交互流程分析

1、打开cmd。输入:telnet 192.168.8.189      访问 telnet服务器,依次输入用户名密码,登录成功后输入:exit 退出;

2、打开wireshark对上述流程进行抓包;

流查看抓包内容如下:

转储16进制查看:

内容分析结果:

1、回车换行内容为:0d 0a     也就是window本身的换行:\r\n;

2、回显内容包含大量屏幕坐标信息,基本无法直接使用;

看到该内容后想起以前使用python进行telnet服务器访问时,回显内容无屏幕坐标信息,遂找出以前写的python程序对访问信息进行抓包查看:

第二步:用使用telnetlib库编写的python程序对服务器进行访问,对交互流程抓包

转储16进制:

查看内容发现回显内容无屏幕坐标信息,对比两次交互内容,决定使用golang对方式二进行模拟,注意图中红色框内信息;

golang程序例程:

第一步:创建连接

func telnet_Creat(host string,usr string,pass string)  (conn net.Conn, err error) {
telnetClientObj := new(TelnetClient)
telnetClientObj.IP = host
telnetClientObj.Port = ""
telnetClientObj.IsAuthentication = true
telnetClientObj.UserName = usr
telnetClientObj.Password = pass
conn,err =telnetClientObj.Telnet() return conn,err
}
func (this *TelnetClient) Telnet(timeout int) (conn net.Conn, err error) {
raddr := this.IP + ":" + this.Port
conn, err = net.DialTimeout("tcp", raddr, time.Duration(timeout)*time.Second)
if nil != err {
log.Print("pkg: model, func: Telnet, method: net.DialTimeout, errInfo:", err)
return
}
if false == this.telnetProtocolHandshake(conn) {
log.Print("pkg: model, func: Telnet, method: this.telnetProtocolHandshake, errInfo: telnet protocol handshake failed!!!")
return
}
return
}
 

第二步:模拟登录(telnetProtocolHandshake)

func (this *TelnetClient) telnetProtocolHandshake(conn net.Conn) bool {
var buf []byte
log.Print("telnetProtocolHandshake")
n, err := conn.Read(buf[:])
if nil != err {
log.Print("pkg: model, func: telnetProtocolHandshake, method: conn.Read, errInfo:", err)
return false
}
log.Print("1====",string(buf[:n]))
log.Printf("%x",(buf[:n]))
buf[] = 0xff
buf[] = 0xfc
buf[] = 0x25
buf[] = 0xff
buf[] = 0xfe
buf[] = 0x01
n, err = conn.Write(buf[:])
if nil != err {
log.Print("pkg: model, func: telnetProtocolHandshake, method: conn.Write, errInfo:", err)
return false
} n, err = conn.Read(buf[:])
if nil != err {
log.Print("pkg: model, func: telnetProtocolHandshake, method: conn.Read, errInfo:", err)
return false
}
log.Print("2====",string(buf[:n]))
buf[] = 0xff
buf[] = 0xfe
buf[] = 0x03
buf[] = 0xff
buf[] = 0xfc
buf[] = 0x27
n, err = conn.Write(buf[:])
if nil != err {
log.Print("pkg: model, func: telnetProtocolHandshake, method: conn.Write, errInfo:", err)
return false
} n, err = conn.Read(buf[:])
if nil != err {
log.Print("pkg: model, func: telnetProtocolHandshake, method: conn.Read, errInfo:", err)
return false
}
log.Print("3====",string(buf[:n]))
n, err = conn.Write([]byte(this.UserName + "\r\n"))
if nil != err {
log.Print("pkg: model, func: telnetProtocolHandshake, method: conn.Write, errInfo:", err)
return false
}
time.Sleep(time.Millisecond * ) n, err = conn.Read(buf[:])
if nil != err {
log.Print("pkg: model, func: telnetProtocolHandshake, method: conn.Read, errInfo:", err)
return false
}
log.Print("4====",string(buf[:n]))
n, err = conn.Write([]byte(this.Password+ "\r\n"))
if nil != err {
log.Print("pkg: model, func: telnetProtocolHandshake, method: conn.Write, errInfo:", err)
return false
}
time.Sleep(time.Millisecond * )
n, err = conn.Read(buf[:])
if nil != err {
log.Print("pkg: model, func: telnetProtocolHandshake, method: conn.Read, errInfo:", err)
return false
} log.Print("5====",string(buf[:n])) buf[] = 0xff
buf[] = 0xfc
buf[] = 0x18
n, err = conn.Write(buf[:])
if nil != err {
log.Print("pkg: model, func: telnetProtocolHandshake, method: conn.Write, errInfo:", err)
return false
}
n, err = conn.Read(buf[:])
if nil != err {
log.Print("pkg: model, func: telnetProtocolHandshake, method: conn.Read, errInfo:", err)
return false
}
log.Print("6====",string(buf[:n])) return true
}

完整程序:

package tool

import (
"log"
"net"
"time"
) type TelnetClient struct {
IP string
Port string
IsAuthentication bool
UserName string
Password string
} func main() {
conn,err:= telnet_Creat(host,usr,pass)
if nil != err {
return err }
defer conn.Close()
//后续对conn进行操作即可
}
func telnet_Creat(host string,usr string,pass string)  (conn net.Conn, err error) {
telnetClientObj := new(TelnetClient)
telnetClientObj.IP = host
telnetClientObj.Port = "23"
telnetClientObj.IsAuthentication = true
telnetClientObj.UserName = usr
telnetClientObj.Password = pass
conn,err =telnetClientObj.Telnet(20) return conn,err
}
func (this *TelnetClient) Telnet(timeout int) (conn net.Conn, err error) {
raddr := this.IP + ":" + this.Port
conn, err = net.DialTimeout("tcp", raddr, time.Duration(timeout)*time.Second)
if nil != err {
log.Print("pkg: model, func: Telnet, method: net.DialTimeout, errInfo:", err)
return
}
if false == this.telnetProtocolHandshake(conn) {
log.Print("pkg: model, func: Telnet, method: this.telnetProtocolHandshake, errInfo: telnet protocol handshake failed!!!")
return
}
return
}
func (this *TelnetClient) telnetProtocolHandshake(conn net.Conn) bool {
var buf [4096]byte
log.Print("telnetProtocolHandshake")
n, err := conn.Read(buf[0:])
if nil != err {
log.Print("pkg: model, func: telnetProtocolHandshake, method: conn.Read, errInfo:", err)
return false
}
log.Print("1====",string(buf[0:n]))
log.Printf("%x",(buf[0:n]))
buf[0] = 0xff
buf[1] = 0xfc
buf[2] = 0x25
buf[3] = 0xff
buf[4] = 0xfe
buf[5] = 0x01
n, err = conn.Write(buf[0:6])
if nil != err {
log.Print("pkg: model, func: telnetProtocolHandshake, method: conn.Write, errInfo:", err)
return false
} n, err = conn.Read(buf[0:])
if nil != err {
log.Print("pkg: model, func: telnetProtocolHandshake, method: conn.Read, errInfo:", err)
return false
}
log.Print("2====",string(buf[0:n]))
buf[0] = 0xff
buf[1] = 0xfe
buf[2] = 0x03
buf[3] = 0xff
buf[4] = 0xfc
buf[5] = 0x27
n, err = conn.Write(buf[0:6])
if nil != err {
log.Print("pkg: model, func: telnetProtocolHandshake, method: conn.Write, errInfo:", err)
return false
} n, err = conn.Read(buf[0:])
if nil != err {
log.Print("pkg: model, func: telnetProtocolHandshake, method: conn.Read, errInfo:", err)
return false
}
log.Print("3====",string(buf[0:n]))
n, err = conn.Write([]byte(this.UserName + "\r\n"))
if nil != err {
log.Print("pkg: model, func: telnetProtocolHandshake, method: conn.Write, errInfo:", err)
return false
}
time.Sleep(time.Millisecond * 500) n, err = conn.Read(buf[0:])
if nil != err {
log.Print("pkg: model, func: telnetProtocolHandshake, method: conn.Read, errInfo:", err)
return false
}
log.Print("4====",string(buf[0:n]))
n, err = conn.Write([]byte(this.Password+ "\r\n"))
if nil != err {
log.Print("pkg: model, func: telnetProtocolHandshake, method: conn.Write, errInfo:", err)
return false
}
time.Sleep(time.Millisecond * 2000)
n, err = conn.Read(buf[0:])
if nil != err {
log.Print("pkg: model, func: telnetProtocolHandshake, method: conn.Read, errInfo:", err)
return false
} log.Print("5====",string(buf[0:n])) buf[0] = 0xff
buf[1] = 0xfc
buf[2] = 0x18
n, err = conn.Write(buf[0:3])
if nil != err {
log.Print("pkg: model, func: telnetProtocolHandshake, method: conn.Write, errInfo:", err)
return false
}
n, err = conn.Read(buf[0:])
if nil != err {
log.Print("pkg: model, func: telnetProtocolHandshake, method: conn.Read, errInfo:", err)
return false
}
log.Print("6====",string(buf[0:n])) return true
}

如有问题可添加VX :d11235812  一起学习交流;

【原创】使用golang访问windows telnet服务器的更多相关文章

  1. 客户端访问windows server2016 服务器共享 速度慢

    客户端(windows10)敲完地址后,要过很久才会谈出窗口.  所有的客户端都出现过此现象. 解决:关闭server的 Smb1.0

  2. centos7下安装openvpn,访问内网服务器 (二) windows访问

    一.简介 在上一章中已经安装好了openvpn,并且已经启动成功,现在就可以通过openvpn的客户端进行连接访问内网服务器了. 二.安装openvpn客户端 下载地址: https://www.te ...

  3. 使用VNC+SSH建立安全的远程桌面访问WINDOWS服务器

    用了一段时间的MONO,现在MONO也支持了ENTITY FRAMEWORK 6.但是实际上在LINUX环境里用MYSQL还是会有很多坑.并且之前在网络游戏服务端SCUT上扩展一些功能时候也遇到了一些 ...

  4. 【RL-TCPnet网络教程】第32章 RL-TCPnet之Telnet服务器

    第32章      RL-TCPnet之Telnet服务器 本章节为大家讲解RL-TCPnet的Telnet应用,学习本章节前,务必要优先学习第31章的Telnet基础知识.有了这些基础知识之后,再搞 ...

  5. 使用外网访问阿里云服务器ZooKeeper

    参考网址: zookeeper单机/集群安装详解 使用外网访问阿里云服务器ZooKeeper 阿里云服务管理控制台 1. 阿里云ECS安装zookeeper 环境:我安装的是zookeeper3.4. ...

  6. Linux使用笔记: 使用Samba访问windows的共享目录(转载)

    转自:http://easwy.com/blog/archives/mount-a-windows-shared-folder-on-linux-with-samba/ 通常我们使用Samba都是在W ...

  7. 允许外部访问Windows本机的指定端口

    背景:目前公司有一台公网Windows服务器,有公网IP和内网IP,防火墙已开启 需求:9999端口需要对外开放 方案:在防火墙的入站规则里添加一条规则,使外部能够访问9999端口 问题:添加好规则后 ...

  8. Mac OS X 访问 Windows 共享文件夹

    Mac OS X 访问 Windows 共享文件夹 mac没有网络邻居,但可以使用finder访问局域网中windows共享的文件 1.点击 Finder 前往菜单中的「前往服务器」(或快捷键 com ...

  9. telnet时显示:允许更多到 telnet 服务器的连接。请稍候再试

    telnet时显示:允许更多到 telnet 服务器的连接.请稍候再试    解决办法: windows自带telnet服务器默认的最大连接数为2,要想修改该设置,可以在命令行键入tlntadmn c ...

随机推荐

  1. pointer-events: none 的两个应用场景

    简介 pointer-events: none 真是个神奇的属性. 该属性有什么用?借用 CSS3 pointer-events:none 应用举例及扩展 的总结来说: pointer-events: ...

  2. C++标准库之string返回值研究

    先说结论(不一定适用所有环境): 1) GCC默认开启了返回值优化(RVO),除非编译时指定“-fno-elide-constructors”: 2) 现代C++编译器一般都支持返回值优化: 3) s ...

  3. python data science handbook1

    import numpy as np import matplotlib.pyplot as plt import seaborn; seaborn.set() rand = np.random.Ra ...

  4. iText框架(生成pdf文档)

    1.创建一个itext的简单示例 a.导包(pom.xml文件) <dependencies> <dependency> <groupId>com.lowagie& ...

  5. ARM指令学习

    跳转指令 直接向程序计数器PC写入i跳转地址值,可以实现在4GB的地址空间中的任意跳转. ARM跳转指令可以完成向前或向后的32MB的地址空间的跳转. -B 跳转指令 -BL 带返回的跳转指令 -BL ...

  6. 虚拟机找不到/mnt/hgfs挂载目录——debian与 vmware

    如果在安装好 VMware Tools 并在设置里面设定好共享目录之后仍然找不到 /mnt/hgfs 默认挂载目录,那么尝试以下步骤: 1. 确认VMware Tools 和共享目录设定已经完成: 2 ...

  7. CentOS 5 常见的configure error的解决方法

    仅限于CentOS 5 configure: error: No curses/termcap library found 网上有的说法是: --with-named-curses-libs=/usr ...

  8. [转] Vmware vs Virtualbox vs KVM vs XEN: virtual machines performance comparison

    http://www.ilsistemista.net/index.php/virtualization/1-virtual-machines-performance-comparison.html? ...

  9. Web browse的发展演变

    Web browse 译为中文是网络浏览器或网页浏览器. Web浏览器如今可谓遍地开花,无论你最终选择了什么浏览器,你可能都会举得他们的功能性想当然的,但是你们可能不知道这些Web浏览器是20年发展的 ...

  10. AVPass技术分析:银行劫持类病毒鼻祖BankBot再度来袭,如何绕过谷歌play的杀毒引擎?

    背景 近期,一批伪装成flashlight.vides和game的应用,发布在google play官方应用商店.经钱盾反诈实验室研究发现,该批恶意应用属于新型BankBot.Bankbot家族算得上 ...