SMB协议概述
一、概述
SMB(Server Message Block)是由微软开发的一种软件程序级的网络传输协议,主要用来使得一个网络上的计算机共享计文件、打印机、串行端口和通讯等资源。它也提供认证的进行进程间通信机能。经过Unix服务器厂商重新开发后,它可以用于连接Unix服务器和Windows客户机,执行打印和文件共享等任务。
SMB一开始的设计是在NetBIOS协议上运行的(而NetBIOS本身则运行在NetBEUI、IPX/SPX或TCP/IP协议上)。从Windows2000开始,微软引入SMB Direct Over TCP,重新命名为 CIFS(Common Internet File System),并打算将它与NetBIOS相脱离,试图使它成为Internet上计算机之间相互共享数据的一种标准。CIFS是公开或开放的SMB协议版本。
二、基于NBT的SMB
NetBIOS 支持两种通信模式:会话(session)或数据报(datagram)。会话模式是指两台计算机为“对话"建立一个连接,允许处理大量信息,并支持差错监测和恢复功能。数据报模式面向“无连接"(信息独立发送)操作,发送的信息较小,由应用程序提供差错监测和恢复功能。此外数据报模式也支持将信息广播到局域网中的每台计算机上。若SMB运行在NBT(NetBIOS Over TCP)协议上,而NBT提供三种不同的服务:
- 名字服务(NetBIOS Name Service)
- 数据包服务(NetBIOS Datagram Service)
- 会话服务(NetBIOS Session Service)
NetBIOS 名称映射到IP地址上有三种方法:
- IP 广播 - 当目标地址不在本地 cache 上时,广播一个 包含目标计算机 NetBIOS 名称的数据包。目标计算机返回其 IP 地址。
- lmhosts 文件 - 这是一个负责映射 IP 地址和 NetBIOS 计算机名称的文件。
- NBNS - NetBIOS 命名服务器负责 将 NetBIOS 名称映射到 IP 地址上。
1. 名字服务(NetBIOS Name Service,即NBNS)
运行在137(UDP)端口,提供计算机的名字或IP地址查询服务,类似于TCP/IP协议中的DNS,负责查找目标机器相应的节点地址(TCP/IP协议中为IP地址),并赋予一个NetBIOS名称。可以使用两种方法:
第一种:位于同一工作组中的电脑之间利用广播功能进行计算机名管理。电脑在启动或者连接网络时,会向同一工作组中的所有计算机质询有没有和自己相同的NetBIOS名称。
另一种:利用WINS(Windows因特网名称服务)管理NetBIOS名称。WINS服务器用于登记记录计算机NetBIOS名称和IP地址的对应关系,供局域网计算机查询。WINS客户端在系统起动时或连接网络时会将自己的NetBIOS名称与IP地址发送给WINS服务器。
非法入侵者向目标主机的138端口发送一个连接请求,就能获得目标主机的名称、注册用户名,以及是否安装主控控制器,IIS是否正在运行等。
2. 数据包服务(NetBIOS Datagram Service)
运行在138(UDP)端口,提供NetBIOS浏览功能,显示连接到于网络的计算机设备列表。每台电脑在启动时或连接网络时通过138端口广播自己的NetBIOS名称,收到NetBIOS广播的计算机会将该计算机追加到浏览列表中;关闭电脑时,计算机会通过138端口广播,收到NetBIOS广播的计算机会将该计算机从浏览列表中删除;当计算机需要连接到于网络的计算机设备列表,会广播一个请求,收到请求主机会发送列表。非法入侵者通过与目标主机的138端口发送请求,就能获得目标主机所处的局域网网络名称以及目标主机的计算机名称。
3. 会话服务(NetBIOS Session Service)
运行在139(TCP)端口,提供“NetBIOS Session Service”服务,基于SMB协议对外提供共享服务,包括Windows文件和打印机共享以及Unix中的Samba服务。
三、CIFS(SMB增强版)
若SMB直接运行在TCP上,即CIFS协议,占用的TCP端口号是445。提供的功能与139端口完全相同。为保证向后兼容性,Windows 2000以后版本中基于NBT的SMB和CIFS同时并存。当Windows系统(允许NBT)来连接SMB服务器时,同时尝试连接139和445端口。如果445端口有响应,那么发送RST包给139端口断开连接,使用455端口提供SMB服务。当445端口无响应时,使用139端口提供SMB服务。
SMB协议概述的更多相关文章
- UWP开发技巧:实现SMB协议操作文件服务器文件
问题来源 文件服务器文件夹操作在PC与Surface端确实还是和传统操作一样没什么区别,但是到了手机端与Surface Hub就没那么方便了,因为文件资源管理器Explorer根本没法添加网路硬盘.对 ...
- SMB协议原理抓包分析
SMB协议原理抓包分析 目录: 1.SMB概述 2.SMB原理 3.SMB配置 一.SMB概述 SMB(全称是Server Message Block)是一个协议名,可用于在计算机间共享文件.打印机. ...
- 基于SMB协议的共享文件读写 博客分类: Java
基于SMB协议的共享文件读写 博客分类: Java 一.SMB协议 SMB协议是基于TCP-NETBIOS下的,一般端口使用为139,445. 服务器信息块(SMB)协议是一种IBM协议,用于在计 ...
- javaweb学习总结十九(http协议概述以及http请求信息分析)
一:http协议概述 1:http协议定义 2:使用telnet程序连接web服务器,获取资源 3:http协议:超文本传输协议,它是基于tcp/ip协议,就是建立在tcp/ip之上工作的, http ...
- 基于SMB协议的共享文件读写
一.SMB协议 SMB协议是基于TCP-NETBIOS下的,一般端口使用为139,445. 服务器信息块(SMB)协议是一种IBM协议,用于在计算机间共享文件.打印机.串口等.SMB 协议可以用在因特 ...
- 嵌入式linux的网络编程(1)--TCP/IP协议概述
嵌入式linux的网络编程(1)--TCP/IP协议概述 1.OSI参考模型及TCP/IP参考模型 通信协议用于协调不同网络设备之间的信息交换,它们建立了设备之间互相识别的信息机制.大家一定都听说过著 ...
- 【HTTP 2】HTTP/2 协议概述(HTTP/2 Protocol Overview)
前情提要 在上一篇文章<[HTTP 2.0] 简介(Introduction)>中,我们简单介绍了 HTTP 2. 在本篇文章中,我们将会了解到 HTTP 2 协议概述部分的内容. HTT ...
- JAVA之旅(三十二)——JAVA网络请求,IP地址,TCP/UDP通讯协议概述,Socket,UDP传输,多线程UDP聊天应用
JAVA之旅(三十二)--JAVA网络请求,IP地址,TCP/UDP通讯协议概述,Socket,UDP传输,多线程UDP聊天应用 GUI写到一半电脑系统挂了,也就算了,最多GUI还有一个提示框和实例, ...
- 【高速接口-RapidIO】1、RapidIO协议概述
一.RapidIO背景介绍 RapidIO是由Motorola和Mercury等公司率先倡导的一种高性能. 低引脚数. 基于数据包交换的互连体系结构,是为满足和未来高性能嵌入式系统需求而设计的一种开放 ...
随机推荐
- linux查看内存、CPU占用资源最多的进程
[内存占用] #利用ps命令,默认使用ps参数会显示的结果 ps -aux USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND root 1 ...
- 使用MongoDB命令工具导出、导入数据
Windows 10家庭中文版,MongoDB 3.6.3, 前言 在前面的测试中,已经往MongoDB的数据库中写入了一些数据.现在要重新测试程序,数据库中的旧数据需要被清理掉,可是,又想保存之前写 ...
- MySQL权限操作:Grant、Revoke
数据库操作: 创建数据库.创建表——CREATE 删除数据库.删除表——DROP 删除表内容——TRUNCATE.DELETE(后者效率低.一行一行地删除记录) 查询数据库.查询表——SELECT 插 ...
- linux内核之accept实现
用户态对accept的标准用法: if ((client_fd = accept(sockfd, (struct sockaddr *)&remote_addr, &sin_size) ...
- post提交数据的四种编码方式
这里总结下post提交数据的四种方式. 参考文章: https://www.jianshu.com/p/3c3157669b64
- KnockoutJs学习笔记(二)
这篇文章主要用于记录学习Working with observable arrays的测试和体会. Observable主要用于单一个体的修改订阅,当我们在处理一堆个体时,当UI需要重复显示一些样式相 ...
- C#基础之数据类型
c#有15个预定义类型,其中13个是值类型,两个是引用类型(string 和 object) 1.整型 2.浮点类型 float数据类型用于较小的浮点数,因为它要求的精度较低. double数据类型比 ...
- Linux下光盘镜像生成和刻录
mkiosfs命令如在/root/下有文件file1 file2 file3maiosfs -o img.ios file1 file2 file3该命令将file1 file2 file3放入到im ...
- caffe中根据 *_train_test.prototxt文件生成 *_deploy.prototxt文件 (转载)
见博客:http://blog.csdn.net/u010417185/article/details/52137825
- thinkphp签到的实现代码
thinkphp签到的实现代码 数据表 1 2 3 4 5 6 7 8 9 10 11 CREATE TABLE `members_sign` ( `id` int(11) unsigned NO ...