关于 telnet 命令

telnet命令通常用来远程登录。telnet程序是基于TELNET协议的远程登录客户端程序。Telnet协议是TCP/IP协议族中的一员,是Internet远程登陆服务的标准协议和主要方式。它为用户提供了在本地计算机上完成远程主机工作的 能力。在终端使用者的电脑上使用telnet程序,用它连接到服务器。终端使用者可以在telnet程序中输入命令,这些命令会在服务器上运行,就像直接在服务器的控制台上输入一样。可以在本地就能控制服务器。要开始一个 telnet会话,必须输入用户名和密码来登录服务器。Telnet是常用的远程控制Web服务器的方法。

  但是,telnet因为采用明文传送报文,安全性不好,很多Linux服务器都不开放telnet服务,而改用更安全的ssh方式了。但仍然有很多别的系统可能采用了telnet方式来提供远程登录,因此弄清楚telnet客户端的使用方式仍是很有必要的。

telnet命令还可做别的用途,比如确定远程服务的状态,比如确定远程服务器的某个端口是否能访问。

1.命令格式:

telnet[参数][主机]

2.命令功能:

执行telnet指令开启终端机阶段作业,并登入远端主机。

3.命令参数:

-8 允许使用8位字符资料,包括输入与输出。

-a 尝试自动登入远端系统。

-b<主机别名> 使用别名指定远端主机名称。

-c 不读取用户专属目录里的.telnetrc文件。

-d 启动排错模式。

-e<脱离字符> 设置脱离字符。

-E 滤除脱离字符。

-f 此参数的效果和指定"-F"参数相同。

-F 使用Kerberos V5认证时,加上此参数可把本地主机的认证数据上传到远端主机。

-k<域名> 使用Kerberos认证时,加上此参数让远端主机采用指定的领域名,而非该主机的域名。

-K 不自动登入远端主机。

-l<用户名称> 指定要登入远端主机的用户名称。

-L 允许输出8位字符资料。

-n<记录文件> 指定文件记录相关信息。

-r 使用类似rlogin指令的用户界面。

-S<服务类型> 设置telnet连线所需的IP TOS信息。

-x 假设主机有支持数据加密的功能,就使用它。

-X<认证形态> 关闭指定的认证形态。

配置 telnet 服务

查看机器上是否安装了 telnet 服务端和客户端(可能 linux 会自带 telnet 的客户端,但是没有 telnet 的服务端):rpm -qa | grep telnet

rpm -qa | grep xinetd
xinetd-2.3.14-39.el6_4.x86_64

查询到如上结果说明已经安装了,若没有安装的话安装一下即可

telnet 是挂在 xinetd 底下的(telnet 进程的守护进程是 xinetd),查看是否安装了xinetd服务
rpm -qa | grep xinetd
xinetd-2.3.14-39.el6_4.x86_64

安装好了后修改 telnet server 的配置:

vim /etc/xinetd.d/telnet

 service telnet 

 { 

 disable = no #启用 

 flags = REUSE #socket可重用 

 socket_type = stream #连接方式为TCP 

 wait = no #为每个请求启动一个进程 

 user = root #启动服务的用户为root 

 server = /usr/sbin/in.telnetd #要激活的进程 

 log_on_failure += USERID #登录失败时记录登录用户名 

 } 

 如果要配置允许登录的客户端列表,加入 

 only_from = 192.168.0.2 #只允许192.168.0.2登录 

 如果要配置禁止登录的客户端列表,加入 

 no_access = 192.168..{,,} #禁止192.168.0.、192.168.0.3、192.168..4登录 

 如果要设置开放时段,加入 

 access_times = :-: :-: # 每天只有这两个时段开放服务(我们的上班时间:P) 

 如果你有两个IP地址,一个是私网的IP地址如192.168.0.,一个是公网的IP地址如218.75.74.,如果你希望用户只能从私网来登录telnet服务,那么加入 

 bind = 192.168.0.2 

 各配置项具体的含义和语法可参考xined配置文件属性说明(man xinetd.conf) 

注意:disable 属性一定要设置成 no,dissable 为 yes 即没有开启 telnet 服务

配置 telnet 服务的监听端口

# vim /etc/services

找到以下两句

telnet 23/tcp

telnet 23/udp

如果前面有#字符,就去掉它。telnet的默认端口是23,这个端口也是黑客端口扫描的主要对象,因此最好将这个端口修改掉,修改的方法很简单,就是将23这个数字修改掉,改成大一点的数字,比如61123。注意,1024以下的端口号是internet保留的端口号,因此最好不要用,还应该注意不要与其它服务的端口冲突。

由于 telnet 服务进程也是由 xinetd 进程守护的,配置好 telnet 服务后需要重启 xinetd 进程重新加载配置文件:service xinetd restart

检查服务是否开启

完成以上步骤后我们可以通过 23 端口检查一下 telnet 服务是否开启

netstat -tnl | grep 23

tcp 0 0 0.0.0.0:23 0.0.0.0:* LISTEN

如果上面的一行存在就说明服务已经运行了

测试

执行命令:telnet 127.0.0.1

出现如上结果说明我们前面的配置是正确的,已经成功开启了 telnet 服务。但是 telnet 服务默认是不能直接用 root 用户登录的,所以才会登录失败。对于这个问题,我们可以先登录一个普通用户,再切换到 root 用户。也可以修改配置文件使 telnet 可以直接登录 root 用户

解决 telnet 不能直接登录 root 账户问题

在 centos 6.3 系统下,我们可以选择如下两种解决方案:

1.将 /etc/securetty 文件重命名,mv /etc/securetty /etc/securetty.backup

2.在 /etc/securetty 文件中加入 pts/1,如下图

再尝试 telnet 直接登录 root 用户:

显示如上图信息即登录成功。可以通过 exit 命令退出 telnet 登录

telnet 客户端与 web 服务交互

执行命令 telnet 127.0.0.1 80

建立连接后发送一个 GET 请求(当然发送其他 http 请求也是可以的),输入 GET /domain

访问本机监听 80 端口的 /domain 接口

结果如下:

telnet 工具的更多相关文章

  1. Telnet 工具远程连接服务器

    1.启动tomcat 2. 使用telnet命令  打开CMD,输入telnet  localhost 8080 3.显示如下界面,说明已经连接成功 4. 复制如下代码到连接成功的界面 HEAD / ...

  2. 通过telnet连接查看memcache服务器(转)

    memcache作为一款优秀的进程外缓存,常常被运用于高并发系统架构中.这里主要谈谈怎么通过telnet工具,查看memcache运行状况并对其key进行管理维护.假设memcache安装目录:/us ...

  3. win7 telnet命令无法使用

    很多做网络测试的同学发现安装win7后,无法使用telnet命令了,提示“telnet不是内部或外部命令,也不是可运行的程序”,但是很需要在win7中使用telnet工具,怎么办? 首先你要要确认你的 ...

  4. 【Linux远程管理】Telnet远程连接管理

    Telnet,命令行界面下的远程管理工具,因为其历史非常悠久,几乎所有的操作系统都有该工具, 但是,Telnet在传输数据是是通过明文传输的,没有加密,所以现在几乎不会使用Telnet进行管理了. ( ...

  5. ubuntu 下telnet 操纵memcache 实现

    memcache作为一款优秀的进程外缓存,常常被运用于高并发系统架构中.这里主要谈谈怎么通过telnet工具,查看memcache运行状况并对其key进行管理维护.假设memcache安装目录:/us ...

  6. telnet 命令使用详解

    1..关于NTLM验证由于Telnet功能太强大,而且也是入侵者使用最频繁的登录手段之一,因此微软公司为Telnet添加了身份验证,称为NTLM验证,它要求Telnet终端除了需要有Telnet服务主 ...

  7. 使用net Manager工具远程连接oracle

    一,在服务端配置oracle端口 在命令行中输入netca命令,打开相关配置默认端口号为1521 二,配置端口后使用Telnet工具调试端口是否联通 在命令行输入telnet 服务器ip 端口号 三, ...

  8. telnet 命令使用方法详解,telnet命令怎么用

    telnet 命令使用方法详解,telnet命令怎么用? 文章类型:电脑教程 原创:天诺时空   什么是Telnet? 对于Telnet的认识,不同的人持有不同的观点,可以把Telnet当成一种通信协 ...

  9. telnet 命令使用方法详解,telnet命令怎么用?

    什么是Telnet? 对于Telnet的认识,不同的人持有不同的观点,可以把Telnet当成一种通信协议,但是对于入侵者而言,Telnet只是一种远程登录的工具.一旦入侵者与远程主机建立了Telnet ...

随机推荐

  1. 一行代码让App运行时iPhone不会进入锁屏待机状态

    转自:http://www.cocoachina.com/iphonedev/sdk/2010/1028/2260.html 如果你不希望应用运行时 iPhone 进入锁屏待机状态,加入下面这行代码即 ...

  2. params must be [a-zA-Z0-9] for verification sms

    阿里短信发送短信时返回这个信息,之前是可以发送的,现在阿里应该是做了限制的.如果你的短信模板类型为“验证码”,发送的短信内容只能是包含字母和数字 所以当你的短信内容包含特殊符号和中文时,请把短信模板类 ...

  3. 使用net Manager工具配置远程连接oracle

    一,在服务端配置oracle端口在命令行中输入netca命令,打开相关配置默认端口号为1521 二,配置端口后使用Telnet工具调试端口是否联通 在命令行输入telnet 服务器ip 端口号 三,找 ...

  4. Qt Read and Write Csv File

    This page discusses various available options for working with csv documents in your Qt application. ...

  5. 好久没做.Net开发了,今天配置IIS和.Net Framework 4.0遇到点问题

    装了64位的Win7后,装了VS再装IIS,结果IIS里面有.NET4.0,但是程序始终是跑不起来,最后觉得可能是因为4.0没有注册到IIS,因为之前在win2003中有遇到类似的情况.最终成功解决, ...

  6. js 右击事件

    $.fn.extend({        "rightclick": function (fn) {            $(this).mousedown(function ( ...

  7. mongo学习- group操作

    group可以使用 $sum,$avg,$max,$min,$first,$last

  8. Web Api 中返回JSON的正确做法(转)

    出处:http://www.cnblogs.com/acles/archive/2013/06/21/3147667.html 在使用Web Api的时候,有时候只想返回JSON:实现这一功能有多种方 ...

  9. java并发编程实战:第十二章---并发程序的测试

    并发程序中潜在错误的发生并不具有确定性,而是随机的. 安全性测试:通常会采用测试不变性条件的形式,即判断某个类的行为是否与其规范保持一致 活跃性测试:进展测试和无进展测试两方面,这些都是很难量化的(性 ...

  10. 凭借对KMP算法的了解,用java实现了一下,结果和java自带的字符串indexOf比,性能差了十倍。。。

    public class KMP { private char[] source = {'a','b','c','b','c','a','b','a','b','d','d','e','f','g', ...