SID也就是安全标识符(Security Identifiers),是标识用户、组和计算机帐户的唯一的号码。在第一次创建该帐户时,将给网络上的每一个帐户发布一个唯一的 SID。Windows 2000 中的内部进程将引用帐户的 SID 而不是帐户的用户或组名。如果创建帐户,再删除帐户,然后使用相同的用户名创建另一个帐户,则新帐户将不具有授权给前一个帐户的权力或权限,原因是该帐户具有不同的 SID 号。安全标识符也被称为安全 ID 或 SID。

SID的作用 
用户通过验证后,登陆进程会给用户一个访问令牌,该令牌相当于用户访问系统资源的票证,当用户试图访问系统资源时,将访问令牌提供给 Windows NT,然后 Windows NT 检查用户试图访问对象上的访问控制列表。如果用户被允许访问该对象,Windows NT将会分配给用户适当的访问权限。 
访问令牌是用户在通过验证的时候有登陆进程所提供的,所以改变用户的权限需要注销后重新登陆,重新获取访问令牌。

SID号码的组成 
如果存在两个同样SID的用户,这两个帐户将被鉴别为同一个帐户,原理上如果帐户无限制增加的时候,会产生同样的SID,在通常的情况下SID是唯一的,他由计算机名、当前时间、当前用户态线程的CPU耗费时间的总和三个参数决定以保证它的唯一性。

一个完整的SID包括: 
• 用户和组的安全描述 
• 48-bit的ID authority 
• 修订版本 
• 可变的验证值Variable sub-authority values 
例:S-1-5-21-310440588-250036847-580389505-500 
我们来先分析这个重要的SID。第一项S表示该字符串是SID;第二项是SID的版本号,对于2000来说,这个就是1;然后是标志符的颁发机构(identifier authority),对于2000内的帐户,颁发机构就是NT,值是5。然后表示一系列的子颁发机构,前面几项是标志域的,最后一个标志着域内的帐户和组。

SID的获得 
开始-运行-regedt32-HKEY_LOCAL_MACHINE\SAM\SAM\Domains\Builtin\Aliases\Members,找到本地的域的代码,展开后,得到的就是本地帐号的所有SID列表。 
其中很多值都是固定的,比如第一个000001F4(16进制),换算成十进制是500,说明是系统建立的内置管理员帐号administrator,000001F5换算成10进制是501,也就是GUEST帐号了,详细的参照后面的列表。 
这一项默认是system可以完全控制,这也就是为什么要获得这个需要一个System的Cmd的Shell的原因了,当然如果权限足够的话你可以把你要添加的帐号添加进去。 
或者使用Support Tools的Reg工具: 
reg query "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\ProfileList

还有一种方法可以获得SID和用户名称的对应关系: 
1. Regedt32: 
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion \ProfileList 
2. 这个时候可以在左侧的窗口看到SID的值,可以在右侧的窗口中ProfileImagePath看到不同的SID关联的用户名, 
比如%SystemDrive%\Documents and Settings\Administrator.momo这个对应的就是本地机器的管理员SID 
%SystemDrive%\Documents and Settings\Administrator.domain这个就是对应域的管理员的帐户

另外微软的ResourceKit里面也提供了工具getsid,sysinternals的工具包里面也有Psgetsid,其实感觉原理都是读取注册表的值罢了,就是省了一些事情。

SID重复问题的产生 
安装NT/2000系统的时候,产生了一个唯一的SID,但是当你使用类似Ghost的软件克隆机器的时候,就会产生不同的机器使用一个SID的问题。产生了很严重的安全问题。 
同样,如果是重复的SID对于对等网来说也会产生很多安全方面的问题。在对等网中帐号的基础是SID加上一个相关的标识符(RID),如果所有的工作站都拥有一样的SID,每个工作站上产生的第一个帐号都是一样的,这样就对用户本身的文件夹和文件的安全产生了隐患。 
这个时候某个人在自己的NTFS分区建立了共享,并且设置了自己可以访问,但是实际上另外一台机器的SID号码和这个一样的用户此时也是可以访问这个共享的。

SID重复问题的解决 
下面的几个试验带有高危险性,慎用,我已经付出了惨痛的代价! 
微软在ResourceKit里面提供了一个工具,叫做SYSPREP,这个可以用在克隆一台工作站以前产生一个新的SID号码。 下图是他的参数

这个工具在DC上是不能运行这个命令的,否则会提示

但是这个工具并不是把所有的帐户完全的产生新的SID,而是针对两个主要的帐户Administrator和Guest,其他的帐号仍然使用原有的SID。

下面做一个试验,先获得目前帐号的SID: 
S-1-5-21-2000478354-688789844-839522115 
然后运行Sysprep,出现提示窗口:

确定以后需要重启,然后安装程序需要重新设置计算机名称、管理员口令等,但是登陆的时候还是需要输入原帐号的口令。 
进入2000以后,再次查询SID,得到: 
S-1-5-21-759461550-145307086-515799519,发现SID号已经得到了改变,查询注册表,发现注册表已经全部修改了,当然全部修改了?。

另外sysinternals公司也提供了类似的工具NTSID,这个到后来才发现是针对NT4的产品,界面如下:

他可不会提示什么再DC上不能用,接受了就开始,结果导致我的一台DC崩溃,重启后提示“安全账号管理器初始化失败,提供给识别代号颁发机构的值为无效值,错误状态0XC0000084,请按确定,重启到目录服务还原模式...”,即使切换到目录服务还原模式也再也进不去了! 
想想自己胆子也够大的啊,好在是一台额外DC,但是自己用的机器,导致重装系统半天,重装软件N天?,所以再次提醒大家,做以上试验的时候一定要慎重,最好在一台无关紧要的机器上试验,否则出现问题我不负责哦?。另外在Ghost的新版企业版本中的控制台已经加入了修改SID的功能,自己还没有尝试,有兴趣的朋友可以自己试验一下,不过从原理上应该都是一样的。 
文章发表之前,又发现了微软自己提供的一个工具“Riprep”,这个工具主要用做在远程安装的过程中,想要同时安装上应用程序。管理员安装了一个标准的公司桌面操作系统,并配置好应用软件和一些桌面设置之后,可以使用Riprep从这个标准的公司桌面系统制作一个Image文件。这个Image文件既包括了客户化的应用软件,又把每个桌面系统必须独占的安全ID、计算机账号等删除了。管理员可以它放到远程安装服务器上,供客户端远程启动进行安装时选用。但是要注意的是这个工具只能在单硬盘、单分区而且是Professional的机器上面用。

巧妙解决服务器重装之后的麻烦

Windows 2003系统的服务器,因意外因素不小心瘫痪后而重新安装了操作系统与活动目录,并将以前的用户帐号一一重新创建之后,发现以前的用户都不能访问服务器中的相关系统资源了,这是为什么呢?

  其实,在Windows 2003服务器系统中,访问权限的大小和每一个用户的SID标识是一一对应的,也就是说任何一个用户的SID标识都是唯一的,因此当我们重新安装了服务器操作系统后,即使我们再将以前的用户帐号逐一地创建好,不过这些用户的SID标识符号已经发生变化了,而服务器是根据用户的SID标识不同来确定访问权限大小的,所以在重新安装了服务器操作系统后,以前的用户SID全部丢失了,当这些用户再次访问以前的系统资源时,服务器当然会拒绝它们的访问。为了解决重装服务器之后的权限丢失麻烦,我们不妨按照下面的操作步骤来恢复以前的用户权限:

  首先找到用户需要访问的目标共享文件夹,然后用鼠标右键单击之,并从弹出的右键菜单中执行“属性”命令,打开共享文件夹的属性设置窗口,单击该窗口中的“安全”标签,进入到如图1所示的标签页面;


图1

  其次单击该标签页面中的“高级”按钮,打开如图2所示的高级安全设置对话框,单击该对话框中的“所有者”标签,并在其后弹出的标签页面中,选中目标用户所对应的帐号名称,同时将“替换子容器及对象的所有者”复选项选中,然后依次单击“应用”按钮、“确定”按钮,通过上面的操作,我们就能将共享资源的访问权限所有者全部更换给了新的目标用户,这样的话该新增用户自然就能访问到他以前能访问的服务器相关资源了。


图2

  应对重装之后的无法访问麻烦

  在安装有Windows 2000操作系统的服务器中,我们常常会发现服务器系统重新安装过之后,局域网中的客户端就无法连接到服务器系统中,而且在连接的时候服务器还会要求客户端输入登录帐号与密码。也许有人会纳闷,为什么在服务器重新安装之前,我们能从客户端正常访问服务器中的资源,而重新安装过服务器之后,怎么就不能正常访问服务器了呢?

  其实,之前我们之所以能够顺利访问服务器,是因为我们已经将服务器禁止使用的Guest帐号启用起来了,而Guest帐号恰恰就是客户端连接服务器时所自动使用的缺省帐号,因此客户端凭借已经起用的Guest帐号当然就能访问到服务器中的资源了;但重新安装了服务器系统后,Guest帐号又会被Windows 2000操作系统自动禁用掉了,因此当我们再次尝试从客户端来访问服务器时,当然就会发生无法访问的故障,同时还会弹出提示窗口要求我们重新输入可用的合法帐号。

  为了消除重装服务器之后的无法访问故障,我们必须用手工方法将服务器系统默认禁用的Guest帐号重新激活。在激活Guest帐号时,必须先以超级管理员帐号登录进服务器系统,之后依次单击服务器系统桌面中的“开始”/“运行”命令,在其后弹出的系统运行对话框中,输入字符串命令“compmgmt.msc”,单击“确定”按钮后,打开系统的计算机管理窗口;

  在该窗口的左侧列表区域,依次展开其中的“系统工具”、“本地用户和组”、“用户”项目,在对应“用户”项目的右侧显示区域中,双击“guest”选项,打开如图3所示的guest帐号属性设置窗口;将该窗口中的“帐户已停用”的选中状态取消,再单击“确定”按钮,这样的话我们就能将服务器默认的帐号重新启用起来了。日后,当我们再次尝试从客户端中登录服务器时,就能确保登录操作成功了。


图3

windows操作系统中SID是什么??相关推荐

  1. windows调用python_如何在Windows操作系统中从R调用Python?

    我正在寻找一种在Windows操作系统上调用R中的python的方法.因为似乎没有可用的R包(至少没有最近更新的包),我正在寻找如何在R脚本中编写一组命令的线索,然后可以以批处理模式发送蟒蛇. 简而言 ...

  2. WINDOWS操作系统中可以允许最大的线程数

    WINDOWS操作系统中可以允许最大的线程数 默认情况下,一个线程的栈要预留1M的内存空间  而一个进程中可用的内存空间只有2G,所以理论上一个进程中最多可以开2048个线程  但是内存当然不可能完全 ...

  3. 扔掉你 Windows 操作系统中的盗版软件吧

    扔掉你 Windows 操作系统中的盗版软件吧 --Windows 下常用盗版软件的替代免费软件列表 作者:杨文博 <http://blog.solrex.cn> 原文链接:http:// ...

  4. 禁用服务器网络协议怎么设置,如何在Windows操作系统中启用和禁用DHCP?

    原标题:如何在Windows操作系统中启用和禁用DHCP? 无论在公共场所还是家中,WiFi可以为您的计算机提供网络连接.我们出行或者参加会议时需要携带计算机.计算机操作系统具有可操作的DHCP,让大 ...

  5. 安装ao 服务器为空,如何在64位Windows操作系统中安装现场审计实施系统AO2011

    龚泽平 [摘 要]对于医院审计.医保审计等各种需要消耗大量内存的审计工作来讲,64位系统具有更加明显的优势.但是当前国家审计署所研发的现场审计实施系统是基于32为系统的,在一定程度上让计算机软硬件都发 ...

  6. 在计算机窗口中什么中的文件不能被删除,在Windows操作系统中,“回收站”可以恢复(1)上使用键删除的文件或文件夹。在“我的电脑”窗口中,...

    55题库为您解答: 正确答案:B 解析:本题考查Windows操作系统应用的基本知识.在Windows操作系统中,"回收站"可以恢复硬盘上使用Del>键删除的文件或文件夹.& ...

  7. 分享在Windows操作系统中独立安装微软MS Access 2019数据库的实用方法

    文章首发于 码友网 – <分享在Windows操作系统中独立安装微软MS Access 2019数据库的实用方法> 本文为大家分享在Windows操作系统中独立安装微软MS Access ...

  8. Windows操作系统中消除汉字乱码有绝招

    我们在操作电脑的时候,经常会遇到汉字乱码,例如打开"写字板",里面的文字是一塌糊涂,中英文.乱码三足鼎立;玩游戏时菜单也一片乱码,让你不知所措;至于电子邮件乱码,那就更常见了,大家 ...

  9. 在win7系统上装linux,在Windows操作系统中安装Linux系统

    很多人对我写下面的东西已不屑一看了,但我写这个帖子的原因是:很多在Windows下想安装Linux的人不知如何开始,如何下手安装.等进入到安装界面又出现了很问题.不得不中途放弃. 好了,从我做起,开始 ...

最新文章

  1. caffe FCN网络的训练——以SIFT-Flow 数据集为例
  2. 报告:2019-2025年,全球数据中心年复合增长率将超过7%
  3. 昨天还在for循环里写加号拼接字符串的那个同事,今天已经不在了
  4. C#中的ForEach
  5. log4j2 mybatis 显示 sql 和 结果集
  6. .NET Core 中使用 Humanizer 显示友好时间格式
  7. 阿里P8亲自教你!熬夜整理华为最新Java笔试题
  8. 百度地图离线sdk java_百度地图SDK java.lang.UnsatisfiedLinkError: Couldn't load BaiduMapSDK...
  9. C#LeetCode刷题之#581-最短无序连续子数组( Shortest Unsorted Continuous Subarray)
  10. 数据的统计分析与描述
  11. eclipse 启动服务后,部署的文件一直是旧的文件的原因分析
  12. 为Node.js编写组件的几种方式
  13. golang中base64编码_Golang实现的Base64加密
  14. 1024shop 各个微服务 UML时序图
  15. 计算机Wor表格制作斜线表头,Word文档里怎么画表格斜线表头
  16. 信息系统项目管理师(第1章)
  17. 转载!一文了解A股市场所有的ETF指数基金
  18. 镜像站:Github, Wiki, Google
  19. 等额本金贷款和等额本息贷款计算和比较
  20. 解决QQ显示“无法访问个人文件夹”方法

热门文章

  1. java如何定义宽高_java – 将相对布局中的宽度和高度设置为百分比
  2. C# 中TextBox控件如何限制输入的字数?
  3. Mobile app视觉传达的魅力
  4. 小米路由器mini刷lede_小米路由Mini刷Breed, 潘多拉和LEDE
  5. Excel技巧—如何在Excel中输入√和×
  6. mybatis mysql 模糊查询语句_mybatis模糊查询语句及注意事项
  7. 25岁,人生规划(职场第二个三年)(理论)
  8. 项目整理:美团/饿了么店铺同步
  9. linux启动grub密码,如何为GRUB系统引导管理器加上密码 | LinuxSir.Org
  10. Active Directory 证书服务(一)