iOS加密方式:RSA DES MD5

2024-05-05 03:32
文章标签 加密 方式 ios rsa des md5

本文主要是介绍iOS加密方式:RSA DES MD5,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近用到了信息安全加密,主要用到了RSA DES MD5

MD5:加密后不可逆(只能加密不可解密),我们用于加密用户的登录密码

DES:对称加密(服务器和客户端公用同一个秘钥),缺点:一旦被抓包破解了秘钥,就能破解所有的传递信息

RSA:非对称加密(会生成一对秘钥(公钥和私钥)), 通过MAC终端生成两个.pem文件,再用vim打开文件,获取里面的字符串(也就是秘钥),

        如果服务器端同时保留公钥和私钥,可以相互解密加密,如果移动端同时保留公钥和私钥,也可以相互解密加密

        一般情况下,防止APP被反编译破解获取一对秘钥,服务器端只保留私钥(只解密不加密),移动端只保留公钥(只加密不解密)


    本来想着:密码加密用MD5,信息传递用RSA,

在用RSA加密时遇到了问题,移动端通过公钥加密发给服务器,服务器通过私钥解密存储信息数据,服务器再通过私钥加密返回数据给移动端,移动端通过公钥进行解密获取数据

但在服务器给移动端返回用私钥加密后的数据时,移动端用公钥解密没有成功(我只是做iOS端的,Android不知道具体情况),所以这种解密方式放弃了,如果大家有解决方案,欢迎交流。


   最终解决思路:密码加密用MD5,信息传递用RSA + DES

首先移动端给服务器传递通过RSA公钥加密后的数据,参数包括DES的密钥(密钥是随机生成的八位字符串) 和 相关参数信息,服务器通过私钥解密信息数据,里面包括DES密钥和 相关参数信息,服务器再通过此DES密钥加密返回数据给移动端,移动端通过此DES密钥进行解密获取数据。优点:因为RSA不容易解密,即使被拦截解密了,获取了DES的密钥,因为DES的密钥是随机生成的,也只能解密这一次的数据信息,不会对其他数据信息产生影响。(注:DES的密钥每一次都要重新随机生成,也就是一个密钥只完成这一次的数据传递)


MD5 DEA的加密秘钥网上可以搜到,不做附属

RSA的秘钥生成代码如下 :具体实施代码如下

先检测电脑是否已安装openssl, mac默认都已安装把

$openssl

显示如下

youngstardeMBP:RSA_key iOS$ openssl

OpenSSL> 

接着在>之后输入  version -a

显示如下则表示已安装

OpenSSL 0.9.8zg 14 July 2015

built on: Jul 16 2015

platform: darwin64-x86_64-llvm

options:  bn(64,64) md2(int) rc4(ptr,char) des(idx,cisc,16,int) blowfish(idx) 

compiler: -arch x86_64 -fmessage-length=0 -pipe -Wno-trigraphs -fpascal-strings -fasm-blocks -O3 -D_REENTRANT -DDSO_DLFCN -DHAVE_DLFCN_H -DL_ENDIAN -DMD32_REG_T=int -DOPENSSL_NO_IDEA -DOPENSSL_PIC -DOPENSSL_THREADS -DZLIB -mmacosx-version-min=10.6

OPENSSLDIR: "/System/Library/OpenSSL"


整体的输入信息为

youngstardeMBP:RSA_key iOS$ openssl

OpenSSL> version -a

OpenSSL 0.9.8zg 14 July 2015

built on: Jul 16 2015

platform: darwin64-x86_64-llvm

options:  bn(64,64) md2(int) rc4(ptr,char) des(idx,cisc,16,int) blowfish(idx) 

compiler: -arch x86_64 -fmessage-length=0 -pipe -Wno-trigraphs -fpascal-strings -fasm-blocks -O3 -D_REENTRANT -DDSO_DLFCN -DHAVE_DLFCN_H -DL_ENDIAN -DMD32_REG_T=int -DOPENSSL_NO_IDEA -DOPENSSL_PIC -DOPENSSL_THREADS -DZLIB -mmacosx-version-min=10.6

OPENSSLDIR: "/System/Library/OpenSSL"

OpenSSL> 

再输入Q回到命令端

youngstardeMBP:RSA_key iOS$ openssl genrsa -out rsa_private_key.pem 1024  

Generating RSA private key, 1024 bit long modulus

................................++++++

.............................++++++

e is 65537 (0x10001)

youngstardeMBP:RSA_key iOS$ 

如果显示如上内容,则恭喜你,私钥已成功生成

在终端输入如下内容,查看私钥内容 (/Users/iOS/Desktop/iOS加密/RSA_key/rsa_private_key.pem 是 私钥文件路径

youngstardeMBP:RSA_key iOS$ vim /Users/iOS/Desktop/iOS加密/RSA_key/rsa_private_key.pem 

显示内容为

-----BEGIN RSA PRIVATE KEY-----

MIICXgIBAAKBgQDFnWQeB8wHQadrXjtpd3EMAAYjWgTdo+B2g9TOLSPJdwnQ0okR

gOmWsFeZqg8/CxSbr3h4fxWNd2nzO0zfBjUcegvws0klgFc6JoZynNeDa3xo07rY

xTIQjZpxySXd5bLS3dfWObPyrOxPNYjn/SGXKFqcV+nEsdPbw48AAU+6GwIDAQAB

AoGANEIp/rMLJoQbNQ6HYZ2ffI/pD6I3lTFII687MIbJZvae1uVGMCXKH/pkQBOz

0nUorv8ZOaxJ085Xa2YsLvJiSr2OWwhJtjl2LPQ0/C/sZ05U7F0HLksJond3jkUo

pdoIJYqFRzO0XDpT1Qu1DjfURUtO9CmCPsMxI9gQgB9/onkCQQDnK1WP4YwxkEWt

FdgIUmYsuNSFq7CbufLxTkB1+R0gFgVNSOWjlCPlHST7VS66XshDpDNcaAx2G3rh

E1zdVkq3AkEA2tdhTKobKLDpAZoTWdrQPyjPnLFxisw+vapc8tLIB4HHKKzPsPDD

LMjOzOD2LdKrr164nz1avWIoh4vWqZz3vQJBALKI5kj8IiE5UoauAy3SLbVGfmRK

SFjNERNKo0A5yEO6nhelQC3IwLw3eRNfI3qury6Gh2BLv6wL5ygjoyoSdhsCQQCh

x/G9XE/hoA9RSNcfaTzkREZfH2rB4kZLrqMyPBL2QcG61y5fL04KUJVZLsGvlHup

lMvFpPTs5qDxu7ZBA7K9AkEAwEjv+FtPRnEi3UXpkWWn4WZhETzYKIxJVx6FS3UU

wah72LWcojCGGkSAkCQ8i+94vhJJ4x5ikk7Q1WJ+9UODig==

-----END RSA PRIVATE KEY-----

~                                                                               

~                                                                               

~                                                                               

~                                                                               

~                                                                               

~                                                                               

~                                                                               

~                                                                               

"~/Desktop/iOS加密/RSA_key/rsa_private_key.pem" 15L, 891C


 更多iOS 学习知识,总结尽在 的墨科技:传送门
















这篇关于iOS加密方式:RSA DES MD5的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/960721

相关文章

C++中零拷贝的多种实现方式

《C++中零拷贝的多种实现方式》本文主要介绍了C++中零拷贝的实现示例,旨在在减少数据在内存中的不必要复制,从而提高程序性能、降低内存使用并减少CPU消耗,零拷贝技术通过多种方式实现,下面就来了解一下... 目录一、C++中零拷贝技术的核心概念二、std::string_view 简介三、std::stri

Linux脚本(shell)的使用方式

《Linux脚本(shell)的使用方式》:本文主要介绍Linux脚本(shell)的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述语法详解数学运算表达式Shell变量变量分类环境变量Shell内部变量自定义变量:定义、赋值自定义变量:引用、修改、删

python判断文件是否存在常用的几种方式

《python判断文件是否存在常用的几种方式》在Python中我们在读写文件之前,首先要做的事情就是判断文件是否存在,否则很容易发生错误的情况,:本文主要介绍python判断文件是否存在常用的几种... 目录1. 使用 os.path.exists()2. 使用 os.path.isfile()3. 使用

Mybatis的分页实现方式

《Mybatis的分页实现方式》MyBatis的分页实现方式主要有以下几种,每种方式适用于不同的场景,且在性能、灵活性和代码侵入性上有所差异,对Mybatis的分页实现方式感兴趣的朋友一起看看吧... 目录​1. 原生 SQL 分页(物理分页)​​2. RowBounds 分页(逻辑分页)​​3. Page

Linux链表操作方式

《Linux链表操作方式》:本文主要介绍Linux链表操作方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、链表基础概念与内核链表优势二、内核链表结构与宏解析三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势六、典型应用场景七、调试技巧与

Linux实现线程同步的多种方式汇总

《Linux实现线程同步的多种方式汇总》本文详细介绍了Linux下线程同步的多种方法,包括互斥锁、自旋锁、信号量以及它们的使用示例,通过这些同步机制,可以解决线程安全问题,防止资源竞争导致的错误,示例... 目录什么是线程同步?一、互斥锁(单人洗手间规则)适用场景:特点:二、条件变量(咖啡厅取餐系统)工作流

RedisTemplate默认序列化方式显示中文乱码的解决

《RedisTemplate默认序列化方式显示中文乱码的解决》本文主要介绍了SpringDataRedis默认使用JdkSerializationRedisSerializer导致数据乱码,文中通过示... 目录1. 问题原因2. 解决方案3. 配置类示例4. 配置说明5. 使用示例6. 验证存储结果7.

Python程序打包exe,单文件和多文件方式

《Python程序打包exe,单文件和多文件方式》:本文主要介绍Python程序打包exe,单文件和多文件方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python 脚本打成exe文件安装Pyinstaller准备一个ico图标打包方式一(适用于文件较少的程

Python验证码识别方式(使用pytesseract库)

《Python验证码识别方式(使用pytesseract库)》:本文主要介绍Python验证码识别方式(使用pytesseract库),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全... 目录1、安装Tesseract-OCR2、在python中使用3、本地图片识别4、结合playwrigh

Spring中管理bean对象的方式(专业级说明)

《Spring中管理bean对象的方式(专业级说明)》在Spring框架中,Bean的管理是核心功能,主要通过IoC(控制反转)容器实现,下面给大家介绍Spring中管理bean对象的方式,感兴趣的朋... 目录1.Bean的声明与注册1.1 基于XML配置1.2 基于注解(主流方式)1.3 基于Java