本篇博客记录本次使用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. js实现(可实现局部打印)

    1.js实现(可实现局部打印) <input id="btnPrint" type="button" value="打印" oncli ...

  2. [Java算法] -- 1. 常用排序之冒泡排序和选择排序

    使用Java语言实现冒泡排序和选择排序 推荐一个数据结构可视化的网站:http://zh.visualgo.net/zh (暂时访问不了) 对排序不太熟悉的朋友,建议去上面的网站学习一下,你将会发现一 ...

  3. WebServices 注解汇总

    Web Service 元数据注释 @WebService 1.serviceName: 对外发布的服务名,指定 Web Service 的服务名称:wsdl:service.缺省值为 Java 类的 ...

  4. artTemplate使用

    bower install artTemplate --save https://github.com/aui/artTemplate 快速上手 模板定义:   <div id="co ...

  5. navibar记录

    @import (reference) "kmc-common.less"; .kmc{ font-family: PingFangSC-Reguxlar; font-weight ...

  6. 基于coridc算法的定点小数除法器的实现

    `timescale 1ns / 1ps /////////////////////////////////////////////////////////////////////////////// ...

  7. spark wordcount 编程模型详解

    spark wordcount中一共经历多少个RDD?以及RDD提供的toDebugString    在控制台输入spark-shell   系统会默认创建一个SparkContext   sc h ...

  8. 《C# 从现象到本质》出版,免费送书10本

    我的第一本书<C# 从现象到本质>已于近日正式在京东和淘宝天猫上开始销售了.至此,我的图书写作和出版活动正式告一段落.图书销售网址见下. 试读样章 京东 天猫 从看书到写书 借着图书出版之 ...

  9. CLion之C++框架篇-优化框架,单元测试(二)

    背景   结合上一篇CLion之C++框架篇-安装工具,基础框架的搭建(一),继续进行框架优化!   googletest(GTest)是Google开源的C++测试框架,与CLion组合,对C++环 ...

  10. 包建强的培训课程(15):Android App热修复技术

    @import url(/css/cuteeditor.css); Normal 0 10 pt 0 2 false false false EN-US ZH-CN X-NONE $([{£¥·‘“〈 ...