某app返回内容进行了加密处理
其本地解密实现如下
@NotNull public final String decrypt(@NotNull String str, @NotNull String str2) { Intrinsics.checkParameterIsNotNull(str, "input"); Intrinsics.checkParameterIsNotNull(str2, "key"); Cipher instance = Cipher.getInstance("AES/CBC/NoPadding"); Object bytes = str2.getBytes(Charsets.UTF_8); Intrinsics.checkExpressionValueIsNotNull(bytes, "(this as java.lang.String).getBytes(charset)"); SecretKeySpec secretKeySpec = new SecretKeySpec(bytes, "AES"); Object bytes2 = str2.getBytes(Charsets.UTF_8); Intrinsics.checkExpressionValueIsNotNull(bytes2, "(this as java.lang.String).getBytes(charset)"); instance.init(2, secretKeySpec, new IvParameterSpec(bytes2)); Object doFinal = instance.doFinal(Base64.decode(str, 0)); Intrinsics.checkExpressionValueIsNotNull(doFinal, "encrypt"); return StringsKt.trim(new String(doFinal, Charsets.UTF_8), new char[]{'\u0000'}); }
key值为一个写死的字符串
参数有两个 str //加密后的字符串 str2 //解密需要的 key
另偏移向量为 str2 utf8 的字节数组
实现如下
function decrypt($str, $key) { if([string]::IsNullOrEmpty($str)){return $null} $toEncryptArray=[Convert]::FromBase64String($str) $ivArray=[Text.Encoding]::UTF8.GetBytes($key) $rm=[System.Security.Cryptography.RijndaelManaged]::new() $rm.Key=[Text.Encoding]::UTF8.GetBytes($key) $rm.IV=$ivArray $rm.Mode=[System.Security.Cryptography.CipherMode]::CBC $rm.Padding=[System.Security.Cryptography.PaddingMode]::None $cTransform=$rm.CreateDecryptor() $resultArray=$cTransform.TransformFinalBlock($toEncryptArray,0,$toEncryptArray.length) return [Text.Encoding]::UTF8.GetString($resultArray).Trim() }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架
2019-03-18 检查错误的视频文件