TELNET二进制传输

 1. .命令和代码
TRANSMIT-BINARY0
2.命令意义
*IACWILLTRANSMIT-BINARY
这个命令请求的发送方请求开始传输,或确定现在要传输的数据在接收方会以八位二进制方式解释。
*IACWON'TTRANSMIT-BINARY
如果连接已在二进制方式下,发送此命令要求接收方恢复原来标准的NVTASCII方式解释数据。如果现在还未在二进制方式下,发送方拒绝传输将被接受者解释为二进制数据的字符(也就是说,数据传输者要求继续按现在方式进行传输)。只有当双方均同意的情况下才有可能进行二进制传输。
*IACDOTRANSMIT-BINARY
发送者要求传输数据,或确定数据将要被传输,这些数据均被解释为8位二进制的。
*IACDON'TTRANSMIT-BINARY
如果现在处于二进制状态下,命令发送方要求数据发送方进行标准的NTVASCII的传输。如果连接未在二进制状态下,发出命令者要求数据发送方按现在的状态发送数据。只有当双方均同意的情况下才有可能进行二进制传输。
3.默认情况
默认情况为:WON'TTRANSMIT-BINARY和DON'TTRANSMIT-BINARY,连接未在二进制状态下。
4.选项出现的原因
有时候利用telnet上的二进制传输会更有效率,这就是出现的根本原因吧。而双方只要把对数据的解释方式加以改变就可以完成这一选项,因此也比较方便。
5.选项描述
开始二进制传输后,接收方对没有IAC开始的数据以二进制进行解释。IAC后面的是标准的TELNET命令。如果IAC后面的命令不可识别,它和IACNOP命令的效果一样。
6.实现问题
实现二进制传输则不能进行其它模式的传输,这是可以预见的。然而,如果双方能够理解它们同处于二进制传输模式或者例如它们同处于Echo模式,如果他们对此进行了协商,则不会出现什么问题。
我们看到上面的命令意义解释可以注意到WON'T和DON'T的意义要看现在是不是处于二进制传输模式下,假设现在处于EBCDIC模式下,而且一方也不知道任何二进制传输的命令,如果它接收到DOTRANSMIT-BINARY,它根本不知道这是什么,因此返回WON'TTRANSMIT-BINARY,如果对于WON'TTRANSMIT-BINARY的默认值是NVTASCII,发送DOTRANSMIT-BINARY可能希望接收方转到NVTASCII,但接收DOTRANSMIT-BINARY的一方有可能不这么做。
因此,我们有这样一条规则:当连接不处于二进制状态时,默认值(也就是说,对WON'T和DON'T的解释)是维持现状,无论是在在NVTASCII,EBCDIC或者是其他状态。然而,当连接处于二进制状态时,这规则就不顶用了。这就要求连接双方维持一个保存所有可用的连接状态的栈,这样才能正确解释WON'T和DON'T。在二进制状态下,WON'T和DON'T会使状态返回NVTASCII。
因为telnet是一个双向的通道,因此必须保证双向的数据流都是二进制的。在实现时遵守防止循环的规则,这一规则在telnet协议中有描述。下面我们看看从一个进程和终端开始或接收二进制传输的情况:
a.从终端开始二进制传输
实现者应该考虑在二进制状态下如何产生8位有效数据,其中不带什么校验位之类的东西。
b.二进制传输到进程
实现者应该考虑在二进制状态下进行如何接收所有的二进制数据。例如TOPS-20会在终端级解释一些特定字符(例如,ETX,中断control-C),而不把它们传送到进程。
c.从进程开始的二进制传输
实现者应该考虑传输的字符如何不对对方的终端解释为其它的字符。例如TOPS-20会将非打印字符转为一个箭头和一个可打印字符。
d.二进制传输到终端
实现者应该考虑接收到的数据如何传送到本地终端。包括本地应该加入的一些字符,校验运算或字符转换。

 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值