热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

android开发分享AndroidAES加密工具类分享

1、aes加密工具类java不支持pkcs7padding,只支持pkcs5padding。我们知道加密算法由算法+模式+填充组成,下一篇介绍ios

1、aes加密工具类

上述就是android开发分享Android AES加密工具类分享的全部内容,如果对大家有所用处且需要了解更多关于Android学习教程,希望大家多多关注—编程笔记

java不支持pkcs7padding,只支持pkcs5padding。我们知道加密算法由算法+模式+填充组成,下一篇介绍ios和android通用的aes加密,本篇文章使用pkcs5padding加密方式。

  package com.example.aesdemo;    import java.io.unsupportedencodingexception;  import javax.crypto.cipher;  import javax.crypto.spec.secretkeyspec;     ///** aes对称加密解密类 **/  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);    system.out.println(key);    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 

2、使用

新建android工程

  package com.example.aesdemo;    import android.os.bundle;  import android.app.activity;  import android.view.menu;  import android.util.log;     public class mainactivity extends activity {  		   protected void oncreate(bundle savedinstancestate) {   		super.oncreate(savedinstancestate);   		setcontentview(r.layout.activity_main);  	  	 string masterpassword = "a";   	 string originaltext = "于";     	 try {   	  string encryptingcode = aeshelper.encrypt(originaltext,masterpassword);   //	  system.out.println("加密结果为 " + encryptingcode);   	  log.i("加密结果为 ",encryptingcode);   	  string decryptingcode = aeshelper.decrypt(encryptingcode,masterpassword);   //	  system.out.println("解密结果为 " + decryptingcode);   	  log.i("解密结果",decryptingcode);   	  } catch (exception e) {   	  // todo auto-generated catch block   	  e.printstacktrace();   	 } 	  	}    	@override  	public boolean oncreateoptionsmenu(menu menu) {  		// inflate the menu; this adds items to the action bar if it is present.  		getmenuinflater().inflate(r.menu.main, menu);  		return true;  	}  }

3、打印结果

  09-19 10:41:05.467: i/加密结果为(707): e55c24701f6380478e1940addfd08d22  09-19 10:41:05.467: i/解密结果(707): 于  


推荐阅读
  • Android 渐变圆环加载控件实现
    本文介绍了如何在 Android 中创建一个自定义的渐变圆环加载控件,该控件已在多个知名应用中使用。我们将详细探讨其工作原理和实现方法。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • Android LED 数字字体的应用与实现
    本文介绍了一种适用于 Android 应用的 LED 数字字体(digital font),并详细描述了其在 UI 设计中的应用场景及其实现方法。这种字体常用于视频、广告倒计时等场景,能够增强视觉效果。 ... [详细]
  • 深入解析Android自定义View面试题
    本文探讨了Android Launcher开发中自定义View的重要性,并通过一道经典的面试题,帮助开发者更好地理解自定义View的实现细节。文章不仅涵盖了基础知识,还提供了实际操作建议。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文基于刘洪波老师的《英文词根词缀精讲》,深入探讨了多个重要词根词缀的起源及其相关词汇,帮助读者更好地理解和记忆英语单词。 ... [详细]
  • 深入解析Spring Cloud Ribbon负载均衡机制
    本文详细介绍了Spring Cloud中的Ribbon组件如何实现服务调用的负载均衡。通过分析其工作原理、源码结构及配置方式,帮助读者理解Ribbon在分布式系统中的重要作用。 ... [详细]
  • 本文详细介绍了如何使用Spring Boot进行高效开发,涵盖了配置、实例化容器以及核心注解的使用方法。 ... [详细]
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • 本文深入探讨了 Java 中的 Serializable 接口,解释了其实现机制、用途及注意事项,帮助开发者更好地理解和使用序列化功能。 ... [详细]
  • 本文详细介绍了Akka中的BackoffSupervisor机制,探讨其在处理持久化失败和Actor重启时的应用。通过具体示例,展示了如何配置和使用BackoffSupervisor以实现更细粒度的异常处理。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 本章将深入探讨移动 UI 设计的核心原则,帮助开发者构建简洁、高效且用户友好的界面。通过学习设计规则和用户体验优化技巧,您将能够创建出既美观又实用的移动应用。 ... [详细]
author-avatar
fuchen201101
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有