小牟Andorid下面MD5具体实现的思路总结

news/2024/11/26 9:26:33/

Android的开发往往需要一定数目demo

从今起MD5一些加密算法提取物 看看是如何实现的

首先,我们必须明确为什么加密?

1 数据安全处理

2 防止数据窃取

3 有效的避免恶意攻击

4 保证文件完整性

5 优化搜索 作为文件(数据)索引存在等

以上是基本的加密技术的目的

2 眼下在安卓中使用的加密技术都有哪些?

这个是站点上找到的一些资料 主要是2中算法 一个是SHA1算法 一个就是MD5加密 

其它的还有TEA对称型加密算法 效率比較高

TEA(Tiny Encryption Algorithm)是一种小型的对称加密解密算法,支持128位password,与BlowFish一样TEA每次仅仅能加密/解密8字节数据。TEA特点是速度 快、效率高,实现也很easy。因为针对TEA的攻击不断出现,所以TEA也发展出几个版本号,各自是XTEA、Block TEA和XXTEA。

Android 2.2.1默认使用的加密算法是AES 256-SHA1,但从2010年公布的Android 2.3開始,它默认使用的是一种更弱的加密算法 RC4-MD5。

当Android应用建立SSL加密连接,假设没有指定的话它将默认使用RC4-MD5进行加密。

有人可能会怀疑美国国家安全局(NSA)收买了Android开发人员以减少破解加密连接监视Android用户的难度。

但Georg Lukas在分析了Android源码之后发现。默认加密算法的次序是Sun/甲骨文的Java定义的。Java规格定义的TLS安全传输协议加密算法列表中前两种为RC4和MD5。2011年公布的Java 7增加椭圆曲线加密算法改进了加密列表。但Android是基于 JDK 6,仍然沿用十年前定义的默认加密算法列表。

接下来我们主要使用的还是SHA1 和 MD5 那么我们怎样实现一个MD5加密呢

一般我们在实现MD5加密主要有下面几个步骤

1 首先得到一个信息摘要器 MessageDigest 然后设置MD5

2  我们获取要加密的数据 比如 password=“123456”

3 将这些数据转换成字节数据 password.getBytes()

4 循环对每一个字节数进行处理

这里主要是做2个处理 一个是 对每一个字节数据进行 与运算 通常是与上一个16进制的数

比如 int number = p $ 0xff;

然后 将得到的number'进行转换为16进制的数

Integer.toHexString(number);

假设这个数转换后的长度为1 那么我们就补0

不满八个二进制那么我们就补全

算法思想:

1 用每一个byte去和11111111做与运算 而且得到的是一个int类型的值 byte&11111111

2 把int类型转换成16进制并返回String类型

3 不满8个2进制位就补全


 

5 详细的实现算法例如以下

public class Demo {public static void main(String[] args) throws NoSuchAlgorithmException {//信息摘要器MessageDigest digest = MessageDigest.getInstance("md5");String password = "123456";//加密字符StringBuffer buffer = new StringBuffer();byte [] result = digest.digest(password.getBytes());for (byte b : result) {int number = b & 0xff;//不按标准加密//转换成16进制String numberStr = Integer.toHexString(number);if (numberStr.length()==1) {buffer.append("0");}buffer.append(numberStr);}//MD5加密结果System.out.println(buffer.toString());}
}

 

一般大型站点或者银行 都是对数据进行多次MD5 加密 一般在5次以上银行一般在20次左右 所以非常难被破解 还有就是 在进行每一个byte运算的时候并不一定是依照标准的与16位进行加密 能够使用随意的方式进行 比方与上一个32位的数据 或者夹杂其它字符 甚至能够取反等方式进行加密 这些都被称为加盐

在andorid中我们主要是使用MD5Utils工具进行加密 默认使用标准加密方式

比如 我们能够在我们要加密的地方 这样做

String password = "123456";

MD5Utils.encode(password);

这里有一个MD5Utils的小加密工具 传上来大家能够看看

MD5Utils下载


http://www.ppmy.cn/news/66527.html

相关文章

VMware vSphere Replication 8.7 (for vSphere 8.0U1) - 虚拟机复制和数据保护

请访问原文链接:https://sysin.org/blog/vmware-vsphere-replication-8/,查看最新版。原创作品,转载请保留出处。 作者主页:sysin.org 新增功能 vSphere Replication 8.7 | 2023 年 4 月 18 日 | 内部版本 21591677 vSphere Re…

4 IK分词器

4 IK分词器 4.1测试分词器 在添加文档时会进行分词,索引中存放的就是一个一个的词(term),当你去搜索时就是拿关键字去匹配词,最终 找到词关联的文档。 测试当前索引库使用的分词器: post 发送&#xff…

【2023华为OD笔试必会20题--C语言版】《17 猜字谜》——字符串

本专栏收录了华为OD 2022 Q4和2023Q1笔试题目,100分类别中的出现频率最高(至少出现100次)的20道,每篇文章包括原始题目 和 我亲自编写并在Visual Studio中运行成功的C语言代码。 仅供参考、启发使用,切不可照搬、照抄,查重倒是可以过,但后面的技术面试还是会暴露的。✨✨…

数据结构-查找-线性结构(顺序、折半、分块)查找

目录 一、顺序查找 *查找效率分析 二、折半查找 *查找效率分析 三、分块查找 *查找效率分析 一、顺序查找 有称线性查找, 算法思想:从头到尾挨个查找(反过来也行) typedef struct{int *elem; //数据int TableLen; …

Git 常用命令(优化版本)

Git常用命令 仓库 初始化一个Git代码库:git init克隆一个项目和它的整个代码历史:git clone [url]配置 显示当前的Git配置:git config --list编辑Git配置文件:git config -e [--global]设置提交代码时的用户信息:gi…

java基础知识梳理

虽然已经在实际工作中与java打交道5年之多,但是一直没系统地对java这门语言进行梳理和总结,掌握的知识也比较零散。恰好利用这段时间重新认识下java,并对一些常见的语法和知识点做个总结与回顾,一方面为了加深印象,方便…

浅谈 如何挂载和卸载文件系统,包括使用 mount 和 umount 命令、/etc/fstab 文件等

在Linux系统中,可以使用mount和umount命令来挂载和卸载文件系统。mount命令用于将文件系统挂载到指定的挂载点,umount命令用于卸载已经挂载的文件系统。同时,还可以通过编辑/etc/fstab文件来实现自动挂载文件系统。 使用mount和umount命令 …

SQL 常用函数总结(一)

聚合函数 1. COUNT() COUNT() 函数用于计算一个表格或查询结果集合中的行数。 语法:COUNT(column_name) 或 COUNT(*) column_name 是可选的,表示计算某一列的非空值数量。* 表示计算所有行的数量。 示例1:计算 users 表格中所有记录的数…