前端使用Web Cryptography API进行内容加密,几乎无法破解

这两天换了个小电脑,原来那个电脑不咋行了,还是16年的本。新换了个Mini主机,结果很多密码都是存储在那个电脑上的。

思来想去决定做个程序,将密码存储在云上,然后做个App,同时兼顾PC端和手机端。

需求

  • 使用跨端框架,能同时支撑PC和手机端。(开发效率要高)
  • UI风格要简单大方,最好是扁平化设计。(看习惯了)
  • 内容要加密存储在云上,需要保证在数据库被攻破的情况下内容不泄露。
  • 服务部署在云端,传输数据的过程中不能有数据泄露。即使泄露,也是密文,而非明文。

解决方案

  1. 选择tauri框架开发,跨端框架,同时兼顾Windows、Android。(其他设备我也没有,直接不考虑了)
  2. UI框架选择AntDesign,风格简洁大方,老牌开源值得信赖。
  3. 使用PBKDF2派生密钥,配合AES-GCM算法对内容进行加密,保证数据库在被攻破的情况下,内容依旧无法解密。
  4. 强制https连接,确保数据在传输过程中被窃密或修改。即便被窃走,也是密文,而非明文。

运行流程图

css 复制代码
[用户输入主密码] 
       ↓
[本地使用 salt + password → deriveKey()]
       ↓
[本地使用 key + IV + data → encryptData()]
       ↓
[将 salt, IV, encrypted_data, auth_tag 上传至服务端数据库]

代码

生成密钥

本地设置一个主密码 (Master Password),随机生成一个盐值 (Salt),借助PBKDF2派生密钥。

请注意,这里建议Salt仅初始化的时候生成一次,将其保存在localStore中。

js 复制代码
async function deriveKey(masterPassword) {
    const salt = crypto.getRandomValues(new Uint8Array(16));
    const enc = new TextEncoder();
    const keyMaterial = await crypto.subtle.importKey(
        "raw",
        enc.encode(password),
        { name: "PBKDF2" },
        false,
        ["deriveBits", "deriveKey"]
    );

    return await crypto.subtle.deriveKey(
        {
            name: "PBKDF2",
            salt: salt,
            iterations: 100000, // 迭代次数越高越好,但要考虑性能影响
            hash: "SHA-256"
        },
        keyMaterial,
        { name: "AES-GCM", length: 256 }, // 我们将使用 AES-GCM 加密算法
        true,
        ["encrypt", "decrypt"]
    );
}

注意:这里不建议将迭代次数调的非常高,对性能影响较大,但产生的效果有限。

加密

根据密钥使用AES-GCM算法对明文进行加密,这里需要注意,如果是表单形式的建议直接转为String,可以在后期再转回来。

js 复制代码
async function encryptData(key, data) {
    const iv = crypto.getRandomValues(new Uint8Array(12)); // 初始化向量,GCM模式下建议长度为12字节
    const encryptedData = await crypto.subtle.encrypt(
        {
            name: "AES-GCM",
            iv: iv
        },
        key,
        new TextEncoder().encode(data)
    );

    return {
        iv: Array.from(iv), // 将Uint8Array转换为数组以便于存储或传输
        encryptedData: Array.from(new Uint8Array(encryptedData))
    };
}

这里还可以添加AuthTag作为认证标签,校验当前数据库中的数据是否完整且未篡改。

解密

根据主密码+Salt重新生成密钥,然后用密钥对数据进行解密操作。

js 复制代码
async function decryptData(key, iv, encryptedData) {
    const decryptedData = await crypto.subtle.decrypt(
        {
            name: "AES-GCM",
            iv: new Uint8Array(iv)
        },
        key,
        new Uint8Array(encryptedData)
    );

    return new TextDecoder().decode(decryptedData);
}

有兴趣的朋友可以考虑一下我这套方案,目前来看安全性还是比较高的。

主密码只要是保存好,几乎不存在攻破的可能性。如果嫌麻烦其实完全可以将主密码写入代码,毕竟PC和Android端都是打包好的App。

即便是安装包泄露了,我想也没几个人会想着去解包看看。当然,更安全的方案肯定是存在localStore或者本地配置文件中。

相关推荐
0思必得014 小时前
[Web自动化] Selenium处理动态网页
前端·爬虫·python·selenium·自动化
东东51615 小时前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
catino15 小时前
图片、文件的预览
前端·javascript
layman052817 小时前
webpack5 css-loader:从基础到原理
前端·css·webpack
半桔17 小时前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典
前端·css·html
AI老李17 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
_OP_CHEN17 小时前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!
前端·css·html·网页开发·样式表·界面美化
啊哈一半醒17 小时前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局
PHP武器库17 小时前
ULUI:不止于按钮和菜单,一个专注于“业务组件”的纯 CSS 框架
前端·css
电商API_1800790524717 小时前
第三方淘宝商品详情 API 全维度调用指南:从技术对接到生产落地
java·大数据·前端·数据库·人工智能·网络爬虫