學(xué)海拾遺

          生活、技術(shù)、思想無處不在學(xué)習(xí)
          posts - 52, comments - 23, trackbacks - 0, articles - 3
            BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理
          You may already know that when FTP (File Transfer Protocol) commands cross the wire, they use port 21 by default. You may also know that port 20 is assigned to FTP data. Unfortunately, most FTP data sessions do not actually use port 20.

          So you have just taken a trace of an FTP session and noticed that a PORT command crossed the wire. When you looked at the decode, you saw the strangest command sequence:

          PORT 10,2,0,2,4,31

          [We have several FTP trace files online at
          http://www.packet-level.com/traceFiles.htm.]

          What does this mean? First let us take a look at the purpose of the PORT command. Then we will decipher the numbers following the command.

          THE PORT COMMAND
          FTP communications use two port number values - one for commands (port 21 by default) and one for data transfer (this is where the PORT command comes into play).

          The PORT command is sent by an FTP client to establish a secondary connection (address and port) for data to travel over. In some FTP implementations port 20 is used for data, but that is the exception rather than the rules. Typically in a trace you will see data crossing over a dynamic port number (IANA states that this range should be between 49152 through 65535, but most likely you'll see your application using something just above 1024 - the area that used to be the dynamic port number area).

          Figure 1 shows the summary of an FTP communication. Packet 16 contains the PORT command. [This trace file is online at http://www.packet-level.com/traceFiles.htm.]


          Figure 1: The PORT command and parameters are visible in Sniffer's summary column.


          An FTP client issues a PORT to the FTP server and defines what port the client will be listening on for the data channel connection. Upon receipt of the PORT command, the server establishes a new TCP connection to the client using that TCP port value.

          You may see numerous PORT commands issued during a single FTP session - a new data channel must be established to transfer directory listings and perform file GET and PUT operations.

          The Freaky Numbers

          After the PORT command, you will see a series of six numbers - these numbers indicate the IP address and port number to use in establishing a data transfer connection. The first four numbers (10,2,0,2 in our example above) indicate the client IP address. The second numbers, 4,15 indicate the client port number.

          4,15? Strange. When you look at your trace, you would notice that the server establishes a connection on the client port 1039 (D=1039 in packet 19 in Figure 1). How did we get from 4,15 to 1039? Here we go. To interpret and translate the value 4,15 into a port number the receiver must do some decimal to hex translations - here is an example:

          first number (4) translate to hex (0x04)
          second number (15) translate to hex (0x0F)

          Now take the entire set of hex bytes (0x040F) and translate the bytes from hex to decimal (1055). Figure 2 displays the conversion value in Hex Workshop's Base Converter applet. (Hex Workshop and Base Converter are available online at www.bpsoft.com.) Voila!


          Figure 2: Hex value 040F is equivalent to decimal value 1039.


          Most folks get snagged when they try to translate both decimal values as a single set (415 = 0x019F) - that just will not work. You must split the values and convert individually to hex before combining and converting to decimal.

          Now you know - when you see another PORT command on the wire, you should be able to guess what port the data transfer process will use.

          View All Articles by Laura Chappell


          About the Author:
          Laura Chappell is the Sr. Protocol Analyst for the Protocol Analysis Institute. Laura focuses on researching, writing and lecturing on network analysis and security. In 2003, over 60 of Laura's courses become available via internet/CD and a series of "White Hat Toolbox: Security Tools, Tricks and Traces" are releasing at http://www.packet-level.com. Laura can be reached at lchappell@packet-level.com.

          More it_network_systems Articles


          Traceback: http://www.securitypronews.com/it/networksystems/spn-21-20030917UnderstandingtheFTPPORTCommand.html


          只有注冊用戶登錄后才能發(fā)表評(píng)論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 龙州县| 张家界市| 醴陵市| 江孜县| 巨野县| 长寿区| 贡觉县| 琼结县| 齐齐哈尔市| 新建县| 永德县| 甘肃省| 城口县| 湘潭县| 舒兰市| 门源| 玛纳斯县| 新龙县| 永泰县| 文化| 蓬莱市| 塘沽区| 凌云县| 乌拉特中旗| 潍坊市| 山阳县| 通化市| 台前县| 巴南区| 会宁县| 阿尔山市| 永昌县| 昭苏县| 岢岚县| 宜春市| 七台河市| 桐柏县| 偏关县| 珲春市| 奎屯市| 双流县|