android客户端加密代码
来源:互联网 发布:java jdk 1.7 mac下载 编辑:程序博客网 时间:2024/05/16 15:56
java简单加密算法,能够实现简单的加密。
package com.devchina.scurity;import java.security.SecureRandom;import javax.crypto.Cipher;import javax.crypto.KeyGenerator;import javax.crypto.SecretKey;import javax.crypto.spec.SecretKeySpec;public class SecurityEnDe {private static final String defalutSeed = "devchina";private static final String algorithm = "AES";private final static String HEX = "0123456789ABCDEF";public static String encrypt(String cleartext) throws Exception {return encrypt(defalutSeed, cleartext);}public static String encrypt(String seed, String cleartext)throws Exception {byte[] rawKey = getRawKey(seed.getBytes());byte[] result = encrypt(rawKey, cleartext.getBytes());return toHex(result);}public static String decrypt(String encrypted) throws Exception {return decrypt(defalutSeed, encrypted);}public static String decrypt(String seed, String encrypted)throws Exception {byte[] rawKey = getRawKey(seed.getBytes());byte[] enc = toByte(encrypted);byte[] result = decrypt(rawKey, enc);return new String(result);}private static byte[] getRawKey(byte[] seed) throws Exception {KeyGenerator kgen = KeyGenerator.getInstance(algorithm);SecureRandom sr = SecureRandom.getInstance("SHA1PRNG");sr.setSeed(seed);kgen.init(128, sr); // 192 and 256 bits may not be availableSecretKey skey = kgen.generateKey();byte[] raw = skey.getEncoded();return raw;}private static byte[] encrypt(byte[] raw, byte[] clear) throws Exception {SecretKeySpec skeySpec = new SecretKeySpec(raw, algorithm);Cipher cipher = Cipher.getInstance(algorithm);cipher.init(Cipher.ENCRYPT_MODE, skeySpec);byte[] encrypted = cipher.doFinal(clear);return encrypted;}private static byte[] decrypt(byte[] raw, byte[] encrypted)throws Exception {SecretKeySpec skeySpec = new SecretKeySpec(raw, algorithm);Cipher cipher = Cipher.getInstance(algorithm);cipher.init(Cipher.DECRYPT_MODE, skeySpec);byte[] decrypted = cipher.doFinal(encrypted);return decrypted;}public static String toHex(String txt) {return toHex(txt.getBytes());}public static String fromHex(String hex) {return new String(toByte(hex));}public static byte[] toByte(String hexString) {int len = hexString.length() / 2;byte[] result = new byte[len];for (int i = 0; i < len; i++)result[i] = Integer.valueOf(hexString.substring(2 * i, 2 * i + 2),16).byteValue();return result;}public static String toHex(byte[] buf) {if (buf == null)return "";StringBuffer result = new StringBuffer(2 * buf.length);for (int i = 0; i < buf.length; i++) {appendHex(result, buf[i]);}return result.toString();}private static void appendHex(StringBuffer sb, byte b) {sb.append(HEX.charAt((b >> 4) & 0x0f)).append(HEX.charAt(b & 0x0f));}}
- android客户端加密代码
- android客户端加密代码
- Cocos2d-x客户端代码加密
- openssl加密通信客户端代码
- Android SDK代码加密
- android AES加密代码
- iTV android与客户端加密交互流程。
- iTV android与客户端加密交互流程
- Android代码库-MD5加密
- Android常用加密代码实现
- Android AES加密/解密代码
- Android lib库代码加密
- 客户端加密
- android用户登录客户端代码
- QQ空间登录表单密码客户端加密代码
- RSA算法在iOS 客户端的使用 加密方法代码
- Kafka客户端不进行加密处理的代码实例
- android 上aes 加密的代码片段
- 当system或者批处理或者计划任务需要调用其他exe时失败的解决方法(window和linux)
- 多库俄罗斯方块之一(Delphi)
- Word 2010中一种解决空白页无法删除的方法
- 黑马程序员——初识构造函数
- GNU ARM汇编--(十)s3c2440的RTC
- android客户端加密代码
- bt5 notes [2]
- IT男之猝死
- Android软件测试的日志文件抓取简介
- 早期内存管理的缺点
- 解决SPRINGSOURCE TOOL SUITE启动内存错误
- UESTC Summer Team Training #2
- POJ 2318 TOYS (计算几何,向量积,二分查找)
- C#中两个窗体将相互跳转