SSO(single-sign-on) and NTLM

什么是单点登录

说个简单场景:

在account.xiaomi.com输入账号密码登录之后,①打开dev.mi.com并点击登录,这时候不需要再次输入账号密码就可以登录;②打开iot.mi.com并点击登录,也不需要再次输入账号密码就可以登录

这就是单点登录,dev/iot均使用了account账号体系,只需要登录一次

(不过在dev或iot注销登录之后,account也会被注销,这个逻辑显得有点奇怪)

单点登录可复用的技术有oauth/saml等

好处

最明显的好处就是使用方便,免去了多次输入密码的麻烦。

当然还是便于账号管理,功能复用

坏处

坏处也是明显的,泄露一个账号,所有关联系统内容都被窃取

最著名的例子就是Windows的ntlm单点登录,不仅容易泄露,而且可以重放

简单的file://responder-ip/xx/xx.png链接就会将hash泄露到responder-ip服务器上:responder工具

ntlm格式

 

重放攻击:https://byt3bl33d3r.github.io/practical-guide-to-ntlm-relaying-in-2017-aka-getting-a-foothold-in-under-5-minutes.html

其他 https://mgp25.com/research/infosec/Leaking-NTLM-hashes/

生成各种格式的钓鱼文档https://github.com/Greenwolf/ntlm_theft,用来窃取ntlm hash

 

ntlm泄露防范措施

对于外网攻击:屏蔽445端口的出口通信

对于内网攻击:非必要关闭smb协议,没有其他有效办法

 

另外,SSO实现过程中也会出现各种各样的安全漏洞,也算是一个小弊端

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
aml是一种xml格式的语言。 翻译过来大概叫 安全断言(标记)语言。 这里有两个点: 第一是“安全”, 第二是“断言(assertion)”。 用人话翻译saml就是 用安全的方式表达断言一种语言。 先看它的核心概念“断言”。 断言是什么? 就是做出判断的语言。比如一句话: 小明是超级管理员。 这就是一个断言。再来一个例子:小红没有权限读取根目录。这也是一个断言。 这种“做出判断的语句”我们在很多场合都需要用到。 比如你在网上尝试登陆一个服务的时候, 这个服务需要知道你是不是合法的用户。 这个时候如果你能提供一个“安全,可靠,可信任”的断言:“小明有权登陆XX服务”, 那么这个服务就知道你合法了, 于是就能为你提供服务了。 这个例子比较抽象,但基本上能表达断言在实际用例中的作用了。 实际上saml的大部分用例就在于证明你是谁,你拥有什么权限等等了。 saml中大部分主要内容也都是类似于:你是谁, 你有什么。。等等这些简单的语句。 详细内容后面会介绍。 接下来第二个概念就是“安全”了。 你能提供一个断言, 别人能不能假冒你提供一个断言从而骗取服务端的信任呢? 另外服务端为什么会信任你给的断言呢? 这就涉及到安全的问题了。为了防止断言被假冒,篡改。saml中加入了安全措施。 当然现今能抵御假冒,篡改,重放攻击的利器就是公钥-私钥系统了。 通过给断言加上签名和加密,再结合数字证书系统就确保了saml不受攻击。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值