HTTP Basic 认证

HTTP Basic 认证

难度等级:【初级】

由RFC7617定义的HTTP Basic认证是一种非常基础而简单的认证模式,因此叫他Basic认证。他本质上就是浏览器提供的一个接口,能够根据HTTP返回值,自动弹出一个登录框,让用户输入ID和密码,最后发给服务器校验,如若成功,此后每次请求都会携带这个头部。Basic认证确实省去了许多麻烦事:不需要再手写一个前端登录界面,不需要缓存token塞到请求头,不需要定义复杂的交互接口。对于小型网站来说,Basic认证能够快速实现一个登录模块。

浏览器原生的4种弹框

  1. console.alert('警告!'); // 一段消息、确定键。【1个按钮】
  1. console.confirm('确认?'); // 一段消息、确定键、取消键。【2个按钮】
  1. console.prompt('输入:'); // 一段消息、输入框、确定键、取消键。【1个文本框,2个按钮】
  1. Basic 认证弹窗:一段消息、ID输入框、密码输入框、登录键、取消键。【2个文本框,2个按钮】

RFC 7617基本逻辑

  1. 浏览器请求HTTP。

  2. 服务器返回401 Unauthorized。

  3. 浏览器弹出登录窗口。

  4. 用户输入用户名和密码,并确认。

  5. 浏览器用Base64编码用户名和密码。

  6. 浏览器通过Authorization头部请求HTTP。

  7. 服务器验证用户名和密码。

  8. 服务器返回200 OK或者401 Unauthorized。

NodeJS代码实现

go 复制代码
// HTTP Basic 认证
require('http').on('request', (req, res) => {
  let auth = req.headers.authorization?.replace('Basic ', '');
  auth = Buffer.from(auth || '', 'base64').toString('utf-8');
  if ("username:password" === auth) {
    res.writeHead(200);
    res.end('成功');
  } else {
    res.writeHead(401, {
      'WWW-Authenticate': 'Basic realm="inveta"'
    });
    res.end('失败');
  }
});
相关推荐
牛奶4 小时前
200 OK不是"成功"?HTTP状态码潜规则
前端·http·浏览器
冬奇Lab20 小时前
一天一个开源项目(第46篇):Caddy - 自动 HTTPS 的现代化 Web 服务器,支持 HTTP/3
网络协议·nginx·开源
牛奶1 天前
从一行字到改变世界:HTTP这三十年都经历了什么?
前端·http·http3
牛奶1 天前
浏览器到底在偷偷帮你做什么?——HTTP缓存与刷新机制
前端·http·浏览器
韭菜炒大葱3 天前
前端经典面试题:从 URL 输入到页面展示,中间经历了什么?
前端·http·面试
Sheffield4 天前
Docker的跨主机服务与其对应的优缺点
linux·网络协议·docker
YuMiao8 天前
gstatic连接问题导致Google Gemini / Studio页面乱码或图标缺失问题
服务器·网络协议
不可能的是9 天前
前端 SSE 流式请求三种实现方案全解析
前端·http
Jony_11 天前
高可用移动网络连接
网络协议
chilix11 天前
Linux 跨网段路由转发配置
网络协议