package pioneerbarcode.ccw.com.encryptanddecode;

import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.text.TextUtils;
import android.util.Base64;
import android.view.View;
import android.widget.Button;
import android.widget.TextView; import pioneerbarcode.ccw.com.encryptanddecode.utils.AesUtils; public class MainActivity extends AppCompatActivity implements View.OnClickListener { private Button btnBase64New;
private Button btnBase64Older;
private TextView tvOlder;
private String strOlderData;
private TextView tvJiaMiData;
private TextView tvJieMiData;
private Button btnAesJiaMi;
private Button btnAesjieMi;
private TextView tvAesJiaMiData;
private TextView tvAesJieMiData;
    private static String AESPASSWORD = "hehehe";
    @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
setView();
setListener();
} private void setListener() {
btnBase64New.setOnClickListener(this);
btnBase64Older.setOnClickListener(this);
btnAesJiaMi.setOnClickListener(this);
btnAesjieMi.setOnClickListener(this);
} private void setView() {
btnBase64New = (Button) findViewById(R.id.btn_base64_jiemi);
btnBase64Older = (Button) findViewById(R.id.btn_base64_jiami);
tvOlder = (TextView) findViewById(R.id.tv_older);
tvJiaMiData = (TextView) findViewById(R.id.tv_jiami_data);
tvJieMiData = (TextView) findViewById(R.id.tv_jiemi_data); btnAesJiaMi = (Button) findViewById(R.id.btn_Aes_jiami);
btnAesjieMi = (Button) findViewById(R.id.btn_Aes_jiemi);
tvAesJiaMiData = (TextView) findViewById(R.id.tv_Aes_jiami_data);
tvAesJieMiData = (TextView) findViewById(R.id.tv_Aes_jiemi_data); strOlderData = tvOlder.getText().toString().trim();
} @Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.btn_base64_jiemi:
//base64 解密
base64Decode();
break;
case R.id.btn_base64_jiami:
//Base64加密
base64Encrypt();
break;
case R.id.btn_Aes_jiami:
//Aes 加密
aesEncrypt();
break;
case R.id.btn_Aes_jiemi:
//Aes 解密
aesDecode();
break;
default:
break;
}
} /**
* Aes 解密
*/
private void aesDecode() {
try {
if (!TextUtils.isEmpty(tvAesJiaMiData.getText().toString().toString().trim())) {
// Aes 解密后的数据
String data = AesUtils.decrypt(AESPASSWORD, tvAesJiaMiData.getText().toString().trim());
tvAesJieMiData.setText(data);
}
} catch (Exception e) {
e.printStackTrace();
}
} /**
* Aes 加密
*/
private void aesEncrypt() {
try {
String data = AesUtils.encrypt(AESPASSWORD, strOlderData);
//加密后的串
tvAesJiaMiData.setText(data);
} catch (Exception e) {
e.printStackTrace();
}
} /**
* base64解密
*/
private void base64Decode() {
if (!TextUtils.isEmpty(tvJiaMiData.getText().toString().trim())) {
String data = new String(Base64.decode(tvJiaMiData.getText().toString().trim().getBytes(), Base64.DEFAULT));
tvJieMiData.setText(data);
}
} /**
* base64加密
*/
private void base64Encrypt() {
//下面是两种方式 加密
//// 在这里使用的是encode方式,返回的是byte类型加密数据,可使用new String转为String类型
// String olderData_base64 = new String(Base64.encode(strOlderData.getBytes(), Base64.DEFAULT));
//// 加密传入的数据是byte类型的,并非使用decode方法将原始数据转二进制,String类型的数据 使用 str.getBytes()即可
String olderData_base64 = Base64.encodeToString(strOlderData.getBytes(), Base64.DEFAULT);
tvJiaMiData.setText(olderData_base64);
} }
public class AesUtils {
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", "Crypto");
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,new IvParameterSpec(new byte[cipher.getBlockSize()]));
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,new IvParameterSpec(new byte[cipher.getBlockSize()]));
byte[] decrypted = cipher.doFinal(encrypted);
return decrypted;
} private static String toHex(String txt) {
return toHex(txt.getBytes());
}
private static String fromHex(String hex) {
return new String(toByte(hex));
} private 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;
} private 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 final static String HEX = "0123456789ABCDEF";
private static void appendHex(StringBuffer sb, byte b) {
sb.append(HEX.charAt((b>>4)&0x0f)).append(HEX.charAt(b&0x0f));
}
} 经过验证可用
												

android base64 和 aes 加密 解密的更多相关文章

  1. iOS,Android,Jave后台AES加密解密

    AES256 在iOS和Android上的相关代码: http://www.tuicool.com/articles/RVFbmmU 里面可以下载相关的代码. 我们遇到的问题是: 把Android的代 ...

  2. Android数据加密之Aes加密

    前言: 项目中除了登陆,支付等接口采用rsa非对称加密,之外的采用aes对称加密,今天我们来认识一下aes加密. 其他几种加密方式: Android数据加密之Rsa加密 Android数据加密之Aes ...

  3. C#, Java, PHP, Python和Javascript几种语言的AES加密解密实现[转载]

    原文:http://outofmemory.cn/code-snippet/35524/AES-with-javascript-java-csharp-python-or-php c#里面的AES加密 ...

  4. ruby AES加密解密

    最近和京东合作做一个项目,在接口对接传递参数时,参数需要通过AES加密解密. 本来想到用gem 'aescrypt'处理,但是aescrypt的编码方式用的base64,而京东那边用的是16进制.所以 ...

  5. openssl与cryptoAPI交互AES加密解密

    继上次只有CryptoAPI的加密后,这次要实现openssl的了 动机:利用CryptoAPI制作windows的IE,火狐和chrome加密控件后,这次得加上与android的加密信息交互 先前有 ...

  6. java使用AES加密解密 AES-128-ECB加密

    java使用AES加密解密 AES-128-ECB加密 import javax.crypto.Cipher; import javax.crypto.spec.SecretKeySpec; impo ...

  7. AES加密解密——AES在JavaWeb项目中前台JS加密,后台Java解密的使用

    一:前言 在软件开发中,经常要对数据进行传输,数据在传输的过程中可能被拦截,被监听,所以在传输数据的时候使用数据的原始内容进行传输的话,安全隐患是非常大的.因此就要对需要传输的数据进行在客户端进行加密 ...

  8. php与java通用AES加密解密算法

    AES指高级加密标准(Advanced Encryption Standard),是当前最流行的一种密码算法,在web应用开发,特别是对外提供接口时经常会用到,下面是我整理的一套php与java通用的 ...

  9. .Net Core AES加密解密

    一.AES说明 高级加密标准(英语:Advanced Encryption Standard,缩写:AES),在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准.这个标准用来替 ...

随机推荐

  1. Mysql 5.7.12 配置

    打算用express+mysql写一个博客.本来在公司电脑已经配置好了的,但是为了方便在家里也能修改,所以在自己的电脑里也安装好环境. 公司电脑是win7系统32位的,安装的是5.5的mysql,用的 ...

  2. 专为控制打印设计的CSS样式

    大多数Web设计师对打印控制还不是很熟悉,他们往往更迷恋像素,而不是打印机.在现实世界中,很多人依赖从网站上打印网页来参考: 在这个数字时代, 在一些特殊的场合,很多人手中还会拿着纸张.Web开发人员 ...

  3. MySQL中的两种临时表

    MySQL中的两种临时表 伯乐在线2016-07-06 05:16:52阅读(4556)评论(3) 声明:本文由入驻搜狐公众平台的作者撰写,除搜狐官方账号外,观点仅代表作者本人,不代表搜狐立场.举报 ...

  4. js和jquery获取当前对象的子元素

    开发中经常遇到需要获取ul下的il对象,个人总结了js和jquery的方法. HTML片断: <ul class="box"> <li>子元素1</l ...

  5. HTML 与 css 的简单学习

    第21课: 内联元素,又称为行内元素,主要来控制一行内的字: 如: span,不是独占一行,不能设置宽高,竖直方向上不能设置 margin与 pading的值,不过水平方向上可以设置哦.(因为它只在一 ...

  6. ubuntu16.04 + ubuntu + apache2 配置apache解析php

    给apache安装php扩展:  sudo apt-get install libapache2-mod-php 注:这是apache解析php文件的关键,光修改配置文件不安装扩展是不起作用的. 目录 ...

  7. Spring集成Hibernate映射文件的4种方式

    概要: 在Spring的applicationContext.xml中集成Hibernate映射文件,通常是在<sessionFactory>这个Bean实例中进行的,若配置的映射文件较少 ...

  8. maven-web项目中的一些小问题

    1.最新的jetty容器 org.eclipse.jetty 需要JDK1.8的支持. 2.在容器中发布WEB项目时web 中的pom.xml的依赖关系会丧失,依赖和插件需要单独完全编写(尽管IDE会 ...

  9. int(3)和int(10)的区别

    int(M) 在 integer 数据类型中,M 表示最大显示宽度.在 int(M) 中,M 的值跟 int(M) 所占多少存储空间并无任何关系. int(3).int(4).int(8) 在磁盘上都 ...

  10. javascript实现登录验证码

    1.js var code="" ; //在全局 定义验证码 function createCode(){ code = ""; ;//验证码的长度 var c ...