当前位置: 首页 > news >正文

Android和.NET通用的AES算法

Android和.NET通用的AES算法

转至:http://www.cnblogs.com/ahui/archive/2011/04/22/2025045.html,在这里谢谢了,但是我非常非常的讨厌这个行号,复制下来全是行号,满头大汗~~~~

 

1.NET源代码:

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Security.Cryptography; namespace Funds.Common { /// <summary> /// AES对称加密解密类 /// </summary> public class AESHelper { #region 成员变量 /// <summary> /// 密钥(32位,不足在后面补0) /// </summary> //private const string _passwd = "ihlih*0037JOHT*)(PIJY*(()JI^)IO%"; private const string _passwd = "1234567890123456"; /// <summary> /// 运算模式 /// </summary> private static CipherMode _cipherMode = CipherMode.ECB; /// <summary> /// 填充模式 /// </summary> private static PaddingMode _paddingMode = PaddingMode.PKCS7; /// <summary> /// 字符串采用的编码 /// </summary> private static Encoding _encoding = Encoding.UTF8; #endregion #region 辅助方法 /// <summary> /// 获取32byte密钥数据 /// </summary> /// <param name="password">密码</param> /// <returns></returns> private static byte[] GetKeyArray(string password) { if (password == null) { password = string.Empty; } if (password.Length < 32) { password = password.PadRight(32, '0'); } else if (password.Length > 32) { password = password.Substring(0, 32); } return _encoding.GetBytes(password); } /// <summary> /// 将字符数组转换成字符串 /// </summary> /// <param name="inputData"></param> /// <returns></returns> private static string ConvertByteToString(byte[] inputData) { StringBuilder sb = new StringBuilder(inputData.Length * 2); foreach (var b in inputData) { sb.Append(b.ToString("X2")); } return sb.ToString(); } /// <summary> /// 将字符串转换成字符数组 /// </summary> /// <param name="inputString"></param> /// <returns></returns> private static byte[] ConvertStringToByte(string inputString) { if (inputString == null || inputString.Length < 2) { throw new ArgumentException(); } int l = inputString.Length / 2; byte[] result = new byte[l]; for (int i = 0; i < l; ++i) { result[i] = Convert.ToByte(inputString.Substring(2 * i, 2), 16); } return result; } #endregion #region 加密 /// <summary> /// 加密字节数据 /// </summary> /// <param name="inputData">要加密的字节数据</param> /// <param name="password">密码</param> /// <returns></returns> public static byte[] Encrypt(byte[] inputData, string password) { AesCryptoServiceProvider aes = new AesCryptoServiceProvider(); aes.Key = GetKeyArray(password); aes.Mode = _cipherMode; aes.Padding = _paddingMode; ICryptoTransform transform = aes.CreateEncryptor(); byte[] data = transform.TransformFinalBlock(inputData, 0, inputData.Length); aes.Clear(); return data; } /// <summary> /// 加密字符串(加密为16进制字符串) /// </summary> /// <param name="inputString">要加密的字符串</param> /// <param name="password">密码</param> /// <returns></returns> public static string Encrypt(string inputString, string password) { byte[] toEncryptArray = _encoding.GetBytes(inputString); byte[] result = Encrypt(toEncryptArray, password); return ConvertByteToString(result); } /// <summary> /// 字符串加密(加密为16进制字符串) /// </summary> /// <param name="inputString">需要加密的字符串</param> /// <returns>加密后的字符串</returns> public static string EncryptString(string inputString) { return Encrypt(inputString, _passwd); } #endregion #region 解密 /// <summary> /// 解密字节数组 /// </summary> /// <param name="inputData">要解密的字节数据</param> /// <param name="password">密码</param> /// <returns></returns> public static byte[] Decrypt(byte[] inputData, string password) { AesCryptoServiceProvider aes = new AesCryptoServiceProvider(); aes.Key = GetKeyArray(password); aes.Mode = _cipherMode; aes.Padding = _paddingMode; ICryptoTransform transform = aes.CreateDecryptor(); byte[] data = null; try { data = transform.TransformFinalBlock(inputData, 0, inputData.Length); } catch { return null; } aes.Clear(); return data; } /// <summary> /// 解密16进制的字符串为字符串 /// </summary> /// <param name="inputString">要解密的字符串</param> /// <param name="password">密码</param> /// <returns>字符串</returns> public static string Decrypt(string inputString, string password) { byte[] toDecryptArray = ConvertStringToByte(inputString); string decryptString = _encoding.GetString(Decrypt(toDecryptArray, password)); return decryptString; } /// <summary> /// 解密16进制的字符串为字符串 /// </summary> /// <param name="inputString">需要解密的字符串</param> /// <returns>解密后的字符串</returns> public static string DecryptString(string inputString) { return Decrypt(inputString, _passwd); } #endregion } }

2.Android代码:

package com.gzsk.meta; import java.io.UnsupportedEncodingException; import javax.crypto.Cipher; import javax.crypto.spec.SecretKeySpec; public class AESHelper { /** 算法/模式/填充 **/ private static final String CipherMode = "AES/ECB/PKCS5Padding"; /** 创建密钥 **/ private static SecretKeySpec createKey(String password) { byte[] data = null; if (password == null) { password = ""; } StringBuffer sb = new StringBuffer(32); sb.append(password); while (sb.length() < 32) { sb.append("0"); } if (sb.length() > 32) { sb.setLength(32); } try { data = sb.toString().getBytes("UTF-8"); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } return new SecretKeySpec(data, "AES"); } /** 加密字节数据 **/ public static byte[] encrypt(byte[] content, String password) { try { SecretKeySpec key = createKey(password); Cipher cipher = Cipher.getInstance(CipherMode); cipher.init(Cipher.ENCRYPT_MODE, key); byte[] result = cipher.doFinal(content); return result; } catch (Exception e) { e.printStackTrace(); } return null; } /** 加密(结果为16进制字符串) **/ public static String encrypt(String content, String password) { byte[] data = null; try { data = content.getBytes("UTF-8"); } catch (Exception e) { e.printStackTrace(); } data = encrypt(data, password); String result = byte2hex(data); return result; } /** 解密字节数组 **/ public static byte[] decrypt(byte[] content, String password) { try { SecretKeySpec key = createKey(password); Cipher cipher = Cipher.getInstance(CipherMode); cipher.init(Cipher.DECRYPT_MODE, key); byte[] result = cipher.doFinal(content); return result; } catch (Exception e) { e.printStackTrace(); } return null; } /** 解密16进制的字符串为字符串 **/ public static String decrypt(String content, String password) { byte[] data = null; try { data = hex2byte(content); } catch (Exception e) { e.printStackTrace(); } data = decrypt(data, password); if (data == null) return null; String result = null; try { result = new String(data, "UTF-8"); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } return result; } /** 字节数组转成16进制字符串 **/ public static String byte2hex(byte[] b) { // 一个字节的数, StringBuffer sb = new StringBuffer(b.length * 2); String tmp = ""; for (int n = 0; n < b.length; n++) { // 整数转成十六进制表示 tmp = (java.lang.Integer.toHexString(b[n] & 0XFF)); if (tmp.length() == 1) { sb.append("0"); } sb.append(tmp); } return sb.toString().toUpperCase(); // 转成大写 } /** 将hex字符串转换成字节数组 **/ private static byte[] hex2byte(String inputString) { if (inputString == null || inputString.length() < 2) { return new byte[0]; } inputString = inputString.toLowerCase(); int l = inputString.length() / 2; byte[] result = new byte[l]; for (int i = 0; i < l; ++i) { String tmp = inputString.substring(2 * i, 2 * i + 2); result[i] = (byte) (Integer.parseInt(tmp, 16) & 0xFF); } return result; } }

相关文章:

  • 据说看完这21个故事的人,30岁前都成了亿万富翁
  • Java那些事之磁盘操作
  • Jffs2根文件系统制作[转]
  • 利用JavaScript全选、反选复选按钮
  • JS对外部文件的加载及对IFRMAME的加载的实现,当加载完成后,指定指向方法(方法回调)...
  • 【开发板技术支持】关于real6410 模拟摄像头与real6410 开发板的接线方式图
  • Exchange2010 dag 的部署
  • 常用的ICON图标网站
  • 【学习】HTML5深入学习
  • 关于 CKEditor上传文件时调用ckeditor的技巧
  • windows计数器和瓶颈
  • 华赛防火墙USG2210 L2TP over IPsec×××配置实例
  • Oracle RAC内部错误:ORA-00600[kjbmprlst:shadow]一例
  • 个人起始
  • 浅谈VS编译自定义编译任务—MSBuild Task(csproject)
  • Linux中的硬链接与软链接
  • Rancher-k8s加速安装文档
  • RxJS: 简单入门
  • SAP云平台运行环境Cloud Foundry和Neo的区别
  • 七牛云假注销小指南
  • 小试R空间处理新库sf
  • 远离DoS攻击 Windows Server 2016发布DNS政策
  • 在 Chrome DevTools 中调试 JavaScript 入门
  • 通过调用文摘列表API获取文摘
  • ​猴子吃桃问题:每天都吃了前一天剩下的一半多一个。
  • !!Dom4j 学习笔记
  • # 数论-逆元
  • #【QT 5 调试软件后,发布相关:软件生成exe文件 + 文件打包】
  • #LLM入门|Prompt#3.3_存储_Memory
  • #在线报价接单​再坚持一下 明天是真的周六.出现货 实单来谈
  • (JS基础)String 类型
  • (PHP)设置修改 Apache 文件根目录 (Document Root)(转帖)
  • (阿里云万网)-域名注册购买实名流程
  • (三)elasticsearch 源码之启动流程分析
  • (原)Matlab的svmtrain和svmclassify
  • (中等) HDU 4370 0 or 1,建模+Dijkstra。
  • (转)eclipse内存溢出设置 -Xms212m -Xmx804m -XX:PermSize=250M -XX:MaxPermSize=356m
  • (转)winform之ListView
  • (转)可以带来幸福的一本书
  • .net core 源码_ASP.NET Core之Identity源码学习
  • .NET Framework .NET Core与 .NET 的区别
  • .NET Micro Framework 4.2 beta 源码探析
  • .NET Micro Framework初体验(二)
  • .NET/C# 使窗口永不激活(No Activate 永不获得焦点)
  • .net和jar包windows服务部署
  • .NET序列化 serializable,反序列化
  • @Bean, @Component, @Configuration简析
  • [ 转载 ] SharePoint 资料
  • [Android 数据通信] android cmwap接入点
  • [Apio2012]dispatching 左偏树
  • [AutoSar]BSW_Memory_Stack_004 创建一个简单NV block并调试
  • [C\C++]读入优化【技巧】
  • [dts]Device Tree机制
  • [ESP32 IDF]web server
  • [G-CS-MR.PS02] 機巧之形2: Ruler Circle