Laravel + UniApp AES加密/解密

后端 Laravel

php 复制代码
    public function encrypt($data, $method = 'AES-128-CBC', $passwd = 'jiami123456789', $options = 0, $iv = 'jiami12345678900')
    {
        return openssl_encrypt($data, $method, $passwd, $options, $iv);
    }

    public function decrypt($data, $method = 'AES-128-CBC', $passwd = 'jiami123456789', $options = 0, $iv = 'jiami12345678900')
    {
        return openssl_decrypt($data, $method, $passwd, $options, $iv);
    }

使用

php 复制代码
public function index(Request $request)
    {
        // 字符串加密
        $d['string_encryption'] = $this->encrypt('hello');
        $d['string'] = $this->decrypt($d['string_encryption']);

        // 数组加密
        $data = [
            'name' => 'kay',
            'age' => 20,
        ];

        
        $d['array_encryption'] = $this->encrypt(json_encode($data));
        $d['array_decryption'] = $this->decrypt($d['array_encryption']);
        return $d;
    }

UniApp 实现

javascript 复制代码
npm install crypto-js
javascript 复制代码
// /static/crypto.js
/**
 * 工具类
 */
import Vue from 'vue'
import CryptoJS from 'crypto-js'
// 确保密钥长度至少为16字节(AES-128要求)
let keyStr = "jiami12345678900";
let ivStr = "jiami12345678900";

//加密
export function aes_encrypt(word) {
    try {
        var key = CryptoJS.enc.Utf8.parse(keyStr);
        var iv = CryptoJS.enc.Utf8.parse(ivStr);
        var encrypted = CryptoJS.AES.encrypt(word, key, {
            iv: iv,
            mode: CryptoJS.mode.CBC,
            padding: CryptoJS.pad.Pkcs7
        });
        return encrypted.toString();
    } catch (error) {
        console.error('加密失败:', error);
        throw error;
    }
}

//解密  
export function aes_decrypt(word) {
    try {
        var key = CryptoJS.enc.Utf8.parse(keyStr);
        var iv = CryptoJS.enc.Utf8.parse(ivStr);
        // 完整处理base64格式,替换特殊字符
        var restoreBase64=word.replace(/[\r\n]/g,'');
        
        var decrypt = CryptoJS.AES.decrypt(restoreBase64, key, {
            iv: iv,
            mode: CryptoJS.mode.CBC,
            padding: CryptoJS.pad.Pkcs7
        });
        return CryptoJS.enc.Utf8.stringify(decrypt).toString();
    } catch (error) {
        console.error('解密失败:', error);
        throw error;
    }
}

使用

javascript 复制代码
import { aes_encrypt, aes_decrypt } from '@/static/crypto.js'
javascript 复制代码
let encrypt = aes_encrypt('hello')
console.log('===加密===', encrypt);
var decrypt = aes_decrypt(encrypt)
console.log('===解密===', decrypt);
相关推荐
donecoding8 分钟前
别再让 pnpm 跟着 nvm 跑了!独立安装终极指南
前端·node.js·前端工程化
GISer_Jing10 分钟前
AI全栈转型_TS后端学习路线
前端·人工智能·后端·学习
竹林81810 分钟前
被The Graph的GraphQL查询坑了三天,我用一个真实DeFi项目把链上数据索引彻底搞懂了
前端·graphql
漫游的渔夫10 分钟前
前端开发者做 Agent:别只会执行,用 4 类失败策略让 AI 知道怎么停
前端·人工智能·typescript
用户0595401744613 分钟前
把多级缓存一致性验证从手工测试换成 Pytest 参数化,Bug 排查时间缩短 90%
前端·css
暗不需求15 分钟前
深入理解 LangChain:AI 应用开发框架的工程化实践
前端·langchain
用户0595401744636 分钟前
把 Redis 持久化测试从 800 行 Shell 换成 30 行 pytest,排错效率翻了 10 倍
前端·css
GISer_Jing40 分钟前
AI全栈工程师知识体系全景:从前后端核心架构到落地项目全拆解
前端·人工智能·后端·ai编程
Wect1 小时前
深度剖析浏览器跨域问题
前端·面试·浏览器
陈随易1 小时前
bun将会支持Bun.image,你怎么看?
前端·后端·程序员