Base64加密解密

import android.widget.Button;

import android.widget.EditText;

import android.widget.TextView;

import android.widget.Toast;

import tsou.com.encryption.R;

import tsou.com.encryption.base64.Base64Utils;

/**

  • 一、什么Base64算法?

  • Base64是网络上最常见的用于传输8Bit字节代码的编码方式之一,

  • Base64并不是安全领域的加密算法,其实Base64只能算是一个编码算法,

  • 对数据内容进行编码来适合传输。标准Base64编码解码无需额外信息即完全可逆,

  • 即使你自己自定义字符集设计一种类Base64的编码方式用于数据加密,

  • 在多数场景下也较容易破解。Base64编码本质上是一种将二进制数据转成文本数据的方案。

  • 对于非二进制数据,是先将其转换成二进制形式,然后每连续6比特(2的6次方=64)

  • 计算其十进制值,根据该值在A–Z,a–z,0–9,+,/ 这64个字符中找到对应的字符,

  • 最终得到一个文本字符串。基本规则如下几点:

    1. 标准Base64只有64个字符(英文大小写、数字和+、/)以及用作后缀等号;
    1. Base64是把3个字节变成4个可打印字符,
  • 所以Base64编码后的字符串一定能被4整除(不算用作后缀的等号);

    1. 等号一定用作后缀,且数目一定是0个、1个或2个。这是因为如果原文长度不能被3整除,
  • Base64要在后面添加\0凑齐3n位。为了正确还原,添加了几个\0就加上几个等号。

  • 显然添加等号的数目只能是0、1或2;

    1. 严格来说Base64不能算是一种加密,只能说是编码转换。。

*/

public class Base64Activity extends AppCompatActivity implements View.OnClickListener {

private EditText encryptionContext;

private Button encryption;

private TextView tvEncryption;

private Button decode;

private TextView tvDecode;

private Activity mActivity;

private Context mContext;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_aes);

mActivity = this;

mContext = this;

encryptionContext = (EditText) findViewById(R.id.et_encryption_context);

encryption = (Button) findViewById(R.id.btn_encryption);

tvEncryption = (TextView) findViewById(R.id.tv_encryption);

decode = (Button) findViewById(R.id.btn_decode);

tvDecode = (TextView) findViewById(R.id.tv_decode);

initListener();

}

private void initListener() {

encryption.setOnClickListener(this);

decode.setOnClickListener(this);

}

@Override

public void onClick(View view) {

switch (view.getId()) {

case R.id.btn_encryption://加密

String encryptionString = encryptionContext.getText().toString().trim();

if (TextUtils.isEmpty(encryptionString)) {

Toast.makeText(mContext, “请输入加密内容”, Toast.LENGTH_SHORT).show();

return;

}

String encode = Base64Utils.encodeString(encryptionString);

tvEncryption.setText(encode);

break;

case R.id.btn_decode://解密

String decodeString = tvEncryption.getText().toString().trim();

if (TextUtils.isEmpty(decodeString)) {

Toast.makeText(mContext, “请先加密”, Toast.LENGTH_SHORT).show();

return;

}

String decode = Base64Utils.decodeString(decodeString);

tvDecode.setText(decode);

break;

}

}

}

Base64Utils

package tsou.com.encryption.base64;

import android.util.Base64;

import java.io.File;

import java.io.FileInputStream;

import java.io.FileOutputStream;

/**

  • Created by Administrator on 2017/9/20 0020.

  • 无论是编码还是解码都会有一个参数Flags,Android提供了以下几种

  • DEFAULT 这个参数是默认,使用默认的方法来加密

  • NO_PADDING 这个参数是略去加密字符串最后的”=”

  • NO_WRAP 这个参数意思是略去所有的换行符(设置后CRLF就没用了)

  • CRLF 这个参数看起来比较眼熟,它就是Win风格的换行符,意思就是使用CR LF这一对作为一行的结尾而不是Unix风格的LF

  • URL_SAFE 这个参数意思是加密时不使用对URL和文件名有特殊意义的字符来作为加密字符,具体就是以-和_取代+和/

*/

public class Base64Utils {

/**

  • 字符串进行Base64编码加密

  • @param str

  • @return

*/

public static String encodeString(String str) {

return Base64.encodeToString(str.getBytes(), Base64.DEFAULT);

}

/**

  • 字符串进行Base64解码解密

  • @param encodedString

  • @return

*/

public static String decodeString(String encodedString) {

return new String(Base64.decode(encodedString, Base64.DEFAULT));

}

/**

  • 对文件进行Base64编码加密

  • @param path

  • @return

*/

public static String encodeFile(String path) {

File file = new File(path);

FileInputStream inputFile = null;

try {

inputFile = new FileInputStream(file);

byte[] buffer = new byte[(int) file.length()];

inputFile.read(buffer);

inputFile.close();

return Base64.encodeToString(buffer, Base64.DEFAULT);

} catch (Exception e) {

e.printStackTrace();

}

return “”;

}

/**

  • 对文件进行Base64解码解密

  • @param encodedPath

  • @return

*/

public static void decodeFile(String encodedPath) {

File desFile = new File(encodedPath);

文末

今天关于面试的分享就到这里,还是那句话,有些东西你不仅要懂,而且要能够很好地表达出来,能够让面试官认可你的理解,例如Handler机制,这个是面试必问之题。有些晦涩的点,或许它只活在面试当中,实际工作当中你压根不会用到它,但是你要知道它是什么东西。

最后在这里小编分享一份自己收录整理上述技术体系图相关的几十套腾讯、头条、阿里、美团等公司2021年的面试题,把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分。

还有 高级架构技术进阶脑图、Android开发面试专题资料,高级进阶架构资料 帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。

【Android核心高级技术PDF文档,BAT大厂面试真题解析】

【算法合集】

【延伸Android必备知识点】

【Android部分高级架构视频学习资源】

Android精讲视频领取学习后更加是如虎添翼!进军BATJ大厂等(备战)!现在都说互联网寒冬,其实无非就是你上错了车,且穿的少(技能),要是你上对车,自身技术能力够强,公司换掉的代价大,怎么可能会被裁掉,都是淘汰末端的业务Curd而已!现如今市场上初级程序员泛滥,这套教程针对Android开发工程师1-6年的人员、正处于瓶颈期,想要年后突破自己涨薪的,进阶Android中高级、架构师对你更是如鱼得水,赶快领取吧!
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》
点击传送门,即可获取!

g-H0j6XrpA-1714933585606)]

【Android部分高级架构视频学习资源】

Android精讲视频领取学习后更加是如虎添翼!进军BATJ大厂等(备战)!现在都说互联网寒冬,其实无非就是你上错了车,且穿的少(技能),要是你上对车,自身技术能力够强,公司换掉的代价大,怎么可能会被裁掉,都是淘汰末端的业务Curd而已!现如今市场上初级程序员泛滥,这套教程针对Android开发工程师1-6年的人员、正处于瓶颈期,想要年后突破自己涨薪的,进阶Android中高级、架构师对你更是如鱼得水,赶快领取吧!
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》
点击传送门,即可获取!

  • 27
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值