传递URL中编码的用户名和密码时,例如: https://Aladdin:OpenSesame@www.example.com/index.html
客户端实际上是在Authorization标头中发送了吗? 服务器端需要哪种处理才能进行这种URL编码?
答案 0 :(得分:6)
客户端实际上是通过授权标头发送此内容吗?
这取决于客户是什么。如果客户端是浏览器,答案是否定的。以下是实验结果:
一般来说,出于安全原因,浏览器会忽略在URL中主动发送的身份验证信息。
但是,如果客户端是开发工具,则可以在base64中对身份验证信息进行编码,并将其作为授权标头发送。以下是一些实验结果:
是否发送授权标头取决于工具的设计。
此类网址编码需要在服务器端进行哪种处理?
在服务器端,您需要做的就是从Authorization标头获取base64编码的字符串,对其进行解码,并检查它是否有效。
如果在示例网址中使用HTTP协议会有什么不同吗?
为了安全起见,是的,通过HTTP的授权标头是非常不安全的。 Base64编码/解码不会带来任何安全性好处,可以被所有人解码。
否则,它们是相同的。