广告
返回顶部
首页 > 资讯 > 移动开发 >Android编程加密算法小结(AES、Base64、RAS加密算法)
  • 912
分享到

Android编程加密算法小结(AES、Base64、RAS加密算法)

ras加密小结aes算法base64Android 2022-06-06 09:06:17 912人浏览 薄情痞子
摘要

本文实例总结了Android编程加密算法。分享给大家供大家参考,具体如下: android常用加密算法之Base64加密算法: package com.long; impo

本文实例总结Android编程加密算法。分享给大家供大家参考,具体如下:

android常用加密算法之Base64加密算法:


package com.long;

import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.OutputStream;

public class Base64 {
 private static final char[] legalChars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"
   .toCharArray();
 public static String encode(byte[] data) {
  int start = 0;
  int len = data.length;
  StringBuffer buf = new StringBuffer(data.length * 3 / 2);
  int end = len - 3;
  int i = start;
  int n = 0;
  while (i <= end) {
   int d = ((((int) data[i]) & 0x0ff) << 16)
     | ((((int) data[i + 1]) & 0x0ff) << 8)
     | (((int) data[i + 2]) & 0x0ff);
   buf.append(legalChars[(d >> 18) & 63]);
   buf.append(legalChars[(d >> 12) & 63]);
   buf.append(legalChars[(d >> 6) & 63]);
   buf.append(legalChars[d & 63]);
   i += 3;
   if (n++ >= 14) {
    n = 0;
    buf.append(" ");
   }
  }
  if (i == start + len - 2) {
   int d = ((((int) data[i]) & 0x0ff) << 16)
     | ((((int) data[i + 1]) & 255) << 8);
   buf.append(legalChars[(d >> 18) & 63]);
   buf.append(legalChars[(d >> 12) & 63]);
   buf.append(legalChars[(d >> 6) & 63]);
   buf.append("=");
  } else if (i == start + len - 1) {
   int d = (((int) data[i]) & 0x0ff) << 16;
   buf.append(legalChars[(d >> 18) & 63]);
   buf.append(legalChars[(d >> 12) & 63]);
   buf.append("==");
  }
  return buf.toString();
 }
 private static int decode(char c) {
  if (c >= 'A' && c <= 'Z')
   return ((int) c) - 65;
  else if (c >= 'a' && c <= 'z')
   return ((int) c) - 97 + 26;
  else if (c >= '0' && c <= '9')
   return ((int) c) - 48 + 26 + 26;
  else
   switch (c) {
   case '+':
    return 62;
   case '/':
    return 63;
   case '=':
    return 0;
   default:
    throw new RuntimeException("unexpected code: " + c);
   }
 }
 public static byte[] decode(String s) {
  ByteArrayOutputStream bos = new ByteArrayOutputStream();
  try {
   decode(s, bos);
  } catch (IOException e) {
   throw new RuntimeException();
  }
  byte[] decodedBytes = bos.toByteArray();
  try {
   bos.close();
   bos = null;
  } catch (IOException ex) {
   System.err.println("Error while decoding BASE64: " + ex.toString());
  }
  return decodedBytes;
 }
 private static void decode(String s, OutputStream os) throws IOException {
  int i = 0;
  int len = s.length();
  while (true) {
   while (i < len && s.charAt(i) <= ' ')
    i++;
   if (i == len)
    break;
   int tri = (decode(s.charAt(i)) << 18)
     + (decode(s.charAt(i + 1)) << 12)
     + (decode(s.charAt(i + 2)) << 6)
     + (decode(s.charAt(i + 3)));
   os.write((tri >> 16) & 255);
   if (s.charAt(i + 2) == '=')
    break;
   os.write((tri >> 8) & 255);
   if (s.charAt(i + 3) == '=')
    break;
   os.write(tri & 255);
   i += 4;
  }
 }
}

android常用加密算法之AES加密算法:


package com.long;
import java.security.SecureRandom;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecreTKEy;
import javax.crypto.spec.SecretKeySpec;

public class Encryption {
 private final static String HEX = "0123456789ABCDEF";
 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 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("AES");
  SecureRandom sr = SecureRandom.getInstance("SHA1PRNG");
  sr.setSeed(seed);
  kgen.init(128, sr); // 192 and 256 bits may not be available
  SecretKey skey = kgen.generateKey();
  byte[] raw = skey.getEncoded();
  return raw;
 }
 private static byte[] encrypt(byte[] raw, byte[] clear) throws Exception {
  SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");
  Cipher cipher = Cipher.getInstance("AES");
  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, "AES");
  Cipher cipher = Cipher.getInstance("AES");
  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常用加密算法之RAS加密算法:


import java.security.Key; 
import java.security.KeyFactory; 
import java.security.KeyPair; 
import java.security.KeyPairGenerator; 
import java.security.PrivateKey; 
import java.security.PublicKey; 
import java.security.interfaces.RSAPrivateKey; 
import java.security.interfaces.RSAPublicKey; 
import java.security.spec.PKCS8EncodedKeySpec; 
import java.security.spec.X509EncodedKeySpec; 
import javax.crypto.Cipher; 
import sun.misc.BASE64Decoder; 
import sun.misc.BASE64Encoder; 
public class RSAHelper { 
  public static PublicKey getPublicKey(String key) throws Exception { 
   byte[] keyBytes; 
   keyBytes = (new BASE64Decoder()).decodeBuffer(key); 
   X509EncodedKeySpec keySpec = new X509EncodedKeySpec(keyBytes); 
   KeyFactory keyFactory = KeyFactory.getInstance("RSA"); 
   PublicKey publicKey = keyFactory.generatePublic(keySpec); 
   return publicKey; 
  } 
  public static PrivateKey getPrivateKey(String key) throws Exception { 
   byte[] keyBytes; 
   keyBytes = (new BASE64Decoder()).decodeBuffer(key); 
   PKCS8EncodedKeySpec keySpec = new PKCS8EncodedKeySpec(keyBytes); 
   KeyFactory keyFactory = KeyFactory.getInstance("RSA"); 
   PrivateKey privateKey = keyFactory.generatePrivate(keySpec); 
   return privateKey; 
  } 
  public static String getKeyString(Key key) throws Exception { 
   byte[] keyBytes = key.getEncoded(); 
   String s = (new BASE64Encoder()).encode(keyBytes); 
   return s; 
  } 
  public static void main(String[] args) throws Exception { 
   KeyPairGenerator keyPairGen = KeyPairGenerator.getInstance("RSA"); 
   //密钥位数 
   keyPairGen.initialize(1024); 
   //密钥对 
   KeyPair keyPair = keyPairGen.generateKeyPair(); 
   // 公钥 
   PublicKey publicKey = (RSAPublicKey) keyPair.getPublic(); 
   // 私钥 
   PrivateKey privateKey = (RSAPrivateKey) keyPair.getPrivate(); 
   String publicKeyString = getKeyString(publicKey); 
   System.out.println("public:\n" + publicKeyString); 
   String privateKeyString = getKeyString(privateKey); 
   System.out.println("private:\n" + privateKeyString); 
   //加解密类 
   Cipher cipher = Cipher.getInstance("RSA");//Cipher.getInstance("RSA/ECB/PKCS1Padding"); 
   //明文 
   byte[] plainText = "我们都很好!邮件:@sina.com".getBytes(); 
   //加密 
   cipher.init(Cipher.ENCRYPT_MODE, publicKey); 
   byte[] enBytes = cipher.doFinal(plainText); 
   //通过密钥字符串得到密钥 
   publicKey = getPublicKey(publicKeyString); 
   privateKey = getPrivateKey(privateKeyString); 
   //解密 
   cipher.init(Cipher.DECRYPT_MODE, privateKey); 
   byte[]deBytes = cipher.doFinal(enBytes); 
   publicKeyString = getKeyString(publicKey); 
   System.out.println("public:\n" +publicKeyString); 
   privateKeyString = getKeyString(privateKey); 
   System.out.println("private:\n" + privateKeyString); 
   String s = new String(deBytes); 
   System.out.println(s); 
  } 
}

希望本文所述对大家Android程序设计有所帮助。

您可能感兴趣的文章:Android 通过Base64上传图片到服务器实现实例Android数据加密之Base64编码算法的简单实现android POST数据遇到的UTF-8编码(乱码)问题解决办法android WEBp编解码详解Mac OS下为Android Studio编译FFmpeg解码库的详细教程Android图片的Base64编码与解码及解码Base64图片方法


--结束END--

本文标题: Android编程加密算法小结(AES、Base64、RAS加密算法)

本文链接: https://www.lsjlt.com/news/26328.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Android编程加密算法小结(AES、Base64、RAS加密算法)
    本文实例总结了Android编程加密算法。分享给大家供大家参考,具体如下: android常用加密算法之Base64加密算法: package com.long; impo...
    99+
    2022-06-06
    ras 加密 小结 aes 算法 base64 Android
  • AES加密算法
    AES算法原理 对称加密算法(用于取代DES算法,发展历史DES-3DES-AES) 明文长度固定为128位(DES:64位),密钥长度可128位、192位、256位(DES:64位) 加密原理...
    99+
    2023-09-03
    算法 网络 服务器
  • Android之RAS加密算法测试实例
    代码如下:import java.security.Key;   import java.security.KeyFactory;  ...
    99+
    2022-06-06
    ras 算法测试 算法 测试 Android
  • Go加密解密算法小结
    目录前言md5hmacsha1AESECB模式CBC模式CRT模式CFB模式 OFB模式RSA加密参考:前言 加密解密在实际开发中应用比较广泛,常用加解密分为:&ldquo...
    99+
    2022-11-13
  • 什么是AES加密算法
    AES加密算法(Advanced Encryption Standard,高级加密标准)是一种对称加密算法,由美国国家标准与技术研究...
    99+
    2023-09-20
    AES
  • ASP.NETCore实现AES-GCM加密算法
    传统的加密算法中,一个主要的问题是无法确认密钥或密文的有效性,也就是说,当密钥或密文错误时,照样能解密,但不报错。还需要我们制定一个一个原文的校验算法。 为了简化这个过程,一种方式是...
    99+
    2022-11-13
  • golang常用加密解密算法总结(AES、DES、RSA、Sha1、MD5)
    目录关于加密解密AESDESRSAMD5Sha1Base64在项目开发过程中,当操作一些用户的隐私信息,诸如密码、帐户密钥等数据时,往往需要加密后可以在网上传输。这时,需要一些高效地...
    99+
    2022-11-13
  • Android数据加密之Base64编码算法的简单实现
    前面学习总结了平时开发中遇见的各种数据加密方式,最终都会对加密后的二进制数据进行Base64编码,起到一种二次加密的效果,其实呢Base64从严格意义上来说的话不是一种加密算法...
    99+
    2022-06-06
    编码 加密 算法 base64 Android
  • C#中实现AES算法加密解读
    目录先上效果图先添加辅助类开始实现总结先上效果图 文件和加密文件之间的转换。 先添加辅助类 public class AES_EnorDecrypt { ...
    99+
    2023-02-26
    C# AES算法加密 AES算法加密 C# AES加密
  • C#加解密之AES算法的实现
    目录实现功能开发环境实现代码实现效果从这一篇开始呢,写一下常用的一些加解密方式。一般我们来说呢,对于加密,我们分为可逆和不可逆。可逆加密又可分为对称加密(AES、DES等)和非对称加...
    99+
    2022-11-13
  • C#中如何实现AES算法加密
    这篇文章主要介绍了C#中如何实现AES算法加密的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C#中如何实现AES算法加密文章都会有所收获,下面我们一起来看看吧。先上效果图文件和加密文件之间的转换。先添加辅助类&...
    99+
    2023-07-05
  • python实现AES算法及AES-CFB8加解密源码
    目录Python实现AES算法生成轮密钥加密解密完整代码如下测试测试程序Python实现AES-CFB8加解密Python实现AES算法 密码学课程老师留的作业,我觉得用python...
    99+
    2022-11-13
  • android中Sha256加密算法
    import java.io.UnsupportedEncodingException; import java.security.MessageDigest; import...
    99+
    2022-06-06
    sha 加密 sha256 算法 Android
  • Golang如何实现AES对称加密算法
    本篇内容主要讲解“Golang如何实现AES对称加密算法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Golang如何实现AES对称加密算法”吧!前置知识在正式学习加密解密之前,首先看看如何生成...
    99+
    2023-07-05
  • 小程序前端AES加密的方法
    本篇内容主要讲解“小程序前端AES加密的方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“小程序前端AES加密的方法”吧!一.前言什么是AES加密:高级加密标准(英语:Advanced Encr...
    99+
    2023-06-26
  • Android编程之MD5加密算法实例分析
    本文实例分析了Android编程之MD5加密算法。分享给大家供大家参考,具体如下: Android MD5加密算与J2SE平台一模一样,因为Android 平台支持 java....
    99+
    2022-06-06
    加密 md5加密算法 md5加密 算法 Android
  • 解析Android数据加密之异或加密算法
    前言: 这几天被公司临时拉到去做Android IM即时通信协议实现,大致看了下他们定的协议,由于之前没有参与,据说因服务器性能限制,只达成非明文传递,具体原因我不太清楚,不...
    99+
    2022-06-06
    加密 异或 算法 Android
  • Android数据加密之异或加密算法的实现方法
    这几天被公司临时拉到去做Android IM即时通信协议实现,大致看了下他们定的协议,由于之前没有参与,据说因服务器性能限制,只达成非明文传递,具体原因我不太清楚,不过这里用的...
    99+
    2022-06-06
    加密 方法 异或 算法 Android
  • Golang实现AES对称加密算法实例详解
    目录前言前置知识生成随机数生成随机字符串加密和解密加密解密总结前言 安全总是相对的,对于敏感数据最好要有一定保护措施,尤其是在线数据,通过加密可转换信息为编码,从而防止非法获取。对开...
    99+
    2023-02-21
    golang 对称加密 go语言aes加密 对称加密 aes
  • Java实现微信小程序加密数据解密算法
    目录微信小程序加密介绍Bouncy Castle Crypto工具包解密引入依赖算法实现Hutool工具类解密引入依赖算法实现验证完整代码微信小程序加密介绍 我们开发微信小程序的过程...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作