如何使用 MD5 和 SQL 实现服务器授权?

1、问题背景

目前有一个 SQL 数据库,其中存储着以 MD5 形式加密的密码。服务器需要生成一个唯一密钥,然后将其发送给客户端。在客户端,它将使用该密钥作为盐值,然后将密码与盐值一起散列,并将其发回服务器。

唯一的问题是,SQL 数据库中已经以 MD5 形式存储了密码。因此,要使此方法可行,必须在客户端对密码进行 MD5 摘要,然后再使用盐值再次进行 MD5 摘要。这种方法似乎不妥,想进一步了解是否还有更好的解决办法。

2、解决方案

在以下两种方法中选择一种:

  1. 使用 SSL 来加密连接,然后以纯文本形式从客户端发送密码。服务器随后将进行 md5 摘要,并与数据库中的 md5 哈希值进行比较,以查看它们是否相同。如果相同,则验证成功。在客户端对密码进行 MD5 摘要没有任何意义,因为拥有 md5 密码的黑客可以像获得纯文本密码一样轻松地进入系统。
  2. 在服务器端实现 MD5 摘要。在客户端对密码进行 MD5 摘要,然后将其连同唯一密钥一起发送到服务器。服务器随后使用密钥将密码解密,并将其与数据库中的 MD5 哈希值进行比较,以查看它们是否相同。如果相同,则验证成功。这种方法的安全性更高,因为黑客即使拥有 MD5 密码也很难在没有密钥的情况下进入系统。

以下是一些代码示例,演示了如何使用 PHP 实现上述两种解决方案:

php 复制代码
// 使用 SSL 加密连接
if (isset($_POST['username']) && isset($_POST['password'])) {
  $username = $_POST['username'];
  $password = $_POST['password'];

  // 检查用户名和密码是否正确
  $sql = "SELECT * FROM users WHERE username = '$username' AND password = '$password'";
  $result = $conn->query($sql);

  if ($result->num_rows > 0) {
    // 用户名和密码正确,设置会话并重定向到主页
    session_start();
    $_SESSION['username'] = $username;
    header("Location: index.php");
  } else {
    // 用户名或密码错误,显示错误消息
    echo "Invalid username or password";
  }
}
php 复制代码
// 在服务器端实现 MD5 摘要
if (isset($_POST['username']) && isset($_POST['password'])) {
  $username = $_POST['username'];
  $password = $_POST['password'];

  // 从数据库中获取密钥
  $sql = "SELECT secret_key FROM secrets WHERE username = '$username'";
  $result = $conn->query($sql);

  if ($result->num_rows > 0) {
    $row = $result->fetch_assoc();
    $secret_key = $row['secret_key'];

    // 使用密钥解密密码
    $decrypted_password = decrypt($password, $secret_key);

    // 检查用户名和密码是否正确
    $sql = "SELECT * FROM users WHERE username = '$username' AND password = '$decrypted_password'";
    $result = $conn->query($sql);

    if ($result->num_rows > 0) {
      // 用户名和密码正确,设置会话并重定向到主页
      session_start();
      $_SESSION['username'] = $username;
      header("Location: index.php");
    } else {
      // 用户名或密码错误,显示错误消息
      echo "Invalid username or password";
    }
  } else {
    // 用户名或密钥错误,显示错误消息
    echo "Invalid username or key";
  }
}
相关推荐
WenGyyyL2 分钟前
研读论文——《用于3D工业异常检测的自监督特征自适应》
人工智能·python·深度学习·机器学习·计算机视觉·3d
AI视觉网奇2 分钟前
3d关键点 可视化
开发语言·python·pygame
belldeep5 分钟前
python:trimesh 用于 STL 文件解析和 3D 操作
python·3d·stl
顾一大人24 分钟前
dp自动化登陆之hCaptcha 验证码
爬虫·python·自动化
Code_流苏1 小时前
《Python星球日记》 第71天:命名实体识别(NER)与关系抽取
python·深度学习·ner·预训练语言模型·关系抽取·统计机器学习·标注方式
点云SLAM1 小时前
Python中列表(list)知识详解(2)和注意事项以及应用示例
开发语言·人工智能·python·python学习·数据结果·list数据结果
国强_dev1 小时前
任意复杂度的 JSON 数据转换为多个结构化的 Pandas DataFrame 表格
开发语言·python
伊织code2 小时前
PyTorch API 7 - TorchScript、hub、矩阵、打包、profile
人工智能·pytorch·python·ai·矩阵·api
开开心心就好2 小时前
高效全能PDF工具,支持OCR识别
java·前端·python·pdf·ocr·maven·jetty
程序员三藏3 小时前
软件测试之功能测试详解
自动化测试·软件测试·python·功能测试·测试工具·职场和发展·测试用例