zoukankan      html  css  js  c++  java
  • SMB/CIFS协议解析二

    一、拷贝文件(远程-->本地)

    1、SMB_COM_NT_CREATE_ANDX (0xa2)
     

          打开文件,获取文件名,获得读取文件的  总长度。
    2、SMB_COM_READ          0x2e)    
           读取文件,获得读取文件内容。
    3、SMB_COM_CLOSE     (0x04) 
         客户端关闭代表文件的TID与FID。

    读取大文件的具体过程
     

    读取文件是分块进行的,每块最大为64k byte,每块都是由read request+tcp data package+read response组成,如上图。
    (1)没有包含文件数据的read request,
    (2)第一个tcp data package是由SMB Header+文件数据组成,
    (3)紧接着是多个只包含文件数据的tcp data package,
    (4)最后是只包含文件数据的read response。
     

       二、拷贝文件(本地-->远程)

    1、SMB_COM_NT_CREATE_ANDX (0xa2)
     

          创建文件,获取文件名。
    2、SMB_COM_WRITE        0x2f)    
           写入文件,获得写入文件内容。
    3、SMB_COM_CLOSE     (0x04) 
         客户端关闭代表文件的TID与FID。
     
    写入文件是分块进行的,每块最大为64k byte,每块都是由tcp data package+write request+write response组成,如上图。
    (1)第一个tcp data package是由SMB Header+文件数据组成,
    (2)紧接着是多个只包含文件数据的tcp data package,
    (3)然后是只包含文件数据的write request,
    (4)最后是没有包含文件数据的write response。

    from:http://blog.sina.com.cn/s/blog_705eb43a0100o5ah.html

  • 相关阅读:
    提交一个spark程序及spark执行器
    前端如何让服务器主动向浏览器推送数据
    h5页面移动端iPhoneX适配方法
    详说tcp粘包和半包
    mysql配置文件 /etc/my.cnf 详细解释
    【todo】MVCC原理及与锁之间的关系
    【todo】innodb表锁的底层实现原理
    【todo】innodb行锁的底层实现原理
    【todo】mysql binlog
    [todo] spring 事务的传播性
  • 原文地址:https://www.cnblogs.com/zhangzl/p/6121180.html
Copyright © 2011-2022 走看看