- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章简单讲解iOS应用开发中的MD5加密的相关使用由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
1、简单说明 。
1.说明 。
在开发应用的时候,数据的安全性至关重要,而仅仅用POST请求提交用户的隐私数据,还是不能完全解决安全问题.
如:可以利用软件(比如Charles)设置代理服务器,拦截查看手机的请求数据 。
“青花瓷”软件 。
因此:提交用户的隐私数据时,一定不要明文提交,要加密处理后再提交 。
。
2.常见的加密算法 。
MD5 \ SHA \ DES \ 3DES \ RC2和RC4 \ RSA \ IDEA \ DSA \ AES 。
3.加密算法的选择 。
一般公司都会有一套自己的加密方案,按照公司接口文档的规定去加密 。
。
2、MD5 。
1.简单说明 。
MD5:全称是Message Digest Algorithm 5,译为“消息摘要算法第5版” 。
效果:对输入信息生成唯一的128位散列值(32个字符) 。
。
2.MD5的特点 。
(1)输入两个不同的明文不会得到相同的输出值 。
(2)根据输出值,不能得到原始的明文,即其过程不可逆 。
。
3.MD5的应用 。
由于MD5加密算法具有较好的安全性,而且免费,因此该加密算法被广泛使用 。
主要运用在数字签名、文件完整性验证以及口令加密等方面 。
4.MD5破解 。
MD5解密网站:http://www.cmd5.com 。
5.MD5改进 。
现在的MD5已不再是绝对安全,对此,可以对MD5稍作改进,以增加解密的难度 。
加盐(Salt):在明文的固定位置插入随机串,然后再进行MD5 。
先加密,后乱序:先对明文进行MD5,然后对加密得到的MD5串的字符进行乱序 。
总之宗旨就是:黑客就算攻破了数据库,也无法解密出正确的明文 。
代码示例:
#import "HMViewController.h" #import "NSString+Hash.h" 。
#define Salt @"fsdhjkfhjksdhjkfjhkd546783765" 。
@interface HMViewController () 。
@end 。
@implementation HMViewController 。
- (void)viewDidLoad { [super viewDidLoad]; [self digest:@"123"]; // [self digest:@"abc"]; [self digest:@"456"]; } 。
/** * 直接用MD5加密 */ - (NSString *)digest:(NSString *)str { NSString *anwen = [str md5String]; NSLog(@"%@ - %@", str, anwen); return anwen; } 。
/** * 加盐 */ - (NSString *)digest2:(NSString *)str { str = [str stringByAppendingString:Salt]; NSString *anwen = [str md5String]; NSLog(@"%@ - %@", str, anwen); return anwen; } 。
/** * 多次MD5 */ - (NSString *)digest3:(NSString *)str { NSString *anwen = [str md5String]; anwen = [anwen md5String]; NSLog(@"%@ - %@", str, anwen); return anwen; } 。
/** * 先加密, 后乱序 */ - (NSString *)digest4:(NSString *)str { NSString *anwen = [str md5String]; // 注册: 123 ---- 2CB962AC59075B964B07152D234B7020 // 登录: 123 --- 202CB962AC59075B964B07152D234B70 NSString *header = [anwen substringToIndex:2]; NSString *footer = [anwen substringFromIndex:2]; anwen = [footer stringByAppendingString:header]; NSLog(@"%@ - %@", str, anwen); return anwen; } @end 。
(1)直接使用MD5加密(去MD5解密网站即可破解) 。
(2)使用加盐(通过MD5解密之后,很容易发现规律) 。
(3)多次MD5加密(使用MD5解密之后,发现还是密文,那就接着MD5解密) 。
(4)先加密,后乱序(破解难度增加) 。
3、注册和验证的数据处理过程 。
1.提交隐私数据的安全过程 – 注册 。
2.提交隐私数据的安全过程 – 登录 。
最后此篇关于简单讲解iOS应用开发中的MD5加密的相关使用的文章就讲到这里了,如果你想了解更多关于简单讲解iOS应用开发中的MD5加密的相关使用的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我想做的是让 JTextPane 在 JPanel 中占用尽可能多的空间。对于我使用的 UpdateInfoPanel: public class UpdateInfoPanel extends JP
我在 JPanel 中有一个 JTextArea,我想将其与 JScrollPane 一起使用。我正在使用 GridBagLayout。当我运行它时,框架似乎为 JScrollPane 腾出了空间,但
我想在 xcode 中实现以下功能。 我有一个 View Controller 。在这个 UIViewController 中,我有一个 UITabBar。它们下面是一个 UIView。将 UITab
有谁知道Firebird 2.5有没有类似于SQL中“STUFF”函数的功能? 我有一个包含父用户记录的表,另一个表包含与父相关的子用户记录。我希望能够提取用户拥有的“ROLES”的逗号分隔字符串,而
我想使用 JSON 作为 mirth channel 的输入和输出,例如详细信息保存在数据库中或创建 HL7 消息。 简而言之,输入为 JSON 解析它并输出为任何格式。 最佳答案 var objec
通常我会使用 R 并执行 merge.by,但这个文件似乎太大了,部门中的任何一台计算机都无法处理它! (任何从事遗传学工作的人的附加信息)本质上,插补似乎删除了 snp ID 的 rs 数字,我只剩
我有一个以前可能被问过的问题,但我很难找到正确的描述。我希望有人能帮助我。 在下面的代码中,我设置了varprice,我想添加javascript变量accu_id以通过rails在我的数据库中查找记
我有一个简单的 SVG 文件,在 Firefox 中可以正常查看 - 它的一些包装文本使用 foreignObject 包含一些 HTML - 文本包装在 div 中:
所以我正在为学校编写一个 Ruby 程序,如果某个值是 1 或 3,则将 bool 值更改为 true,如果是 0 或 2,则更改为 false。由于我有 Java 背景,所以我认为这段代码应该有效:
我做了什么: 我在这些账户之间创建了 VPC 对等连接 互联网网关也连接到每个 VPC 还配置了路由表(以允许来自双方的流量) 情况1: 当这两个 VPC 在同一个账户中时,我成功测试了从另一个 La
我有一个名为 contacts 的表: user_id contact_id 10294 10295 10294 10293 10293 10294 102
我正在使用 Magento 中的新模板。为避免重复代码,我想为每个产品预览使用相同的子模板。 特别是我做了这样一个展示: $products = Mage::getModel('catalog/pro
“for”是否总是检查协议(protocol)中定义的每个函数中第一个参数的类型? 编辑(改写): 当协议(protocol)方法只有一个参数时,根据该单个参数的类型(直接或任意)找到实现。当协议(p
我想从我的 PHP 代码中调用 JavaScript 函数。我通过使用以下方法实现了这一点: echo ' drawChart($id); '; 这工作正常,但我想从我的 PHP 代码中获取数据,我使
这个问题已经有答案了: Event binding on dynamically created elements? (23 个回答) 已关闭 5 年前。 我有一个动态表单,我想在其中附加一些其他 h
我正在尝试找到一种解决方案,以在 componentDidMount 中的映射项上使用 setState。 我正在使用 GraphQL连同 Gatsby返回许多 data 项目,但要求在特定的 pat
我在 ScrollView 中有一个 View 。只要用户按住该 View ,我想每 80 毫秒调用一次方法。这是我已经实现的: final Runnable vibrate = new Runnab
我用 jni 开发了一个 android 应用程序。我在 GetStringUTFChars 的 dvmDecodeIndirectRef 中得到了一个 dvmabort。我只中止了一次。 为什么会这
当我到达我的 Activity 时,我调用 FragmentPagerAdapter 来处理我的不同选项卡。在我的一个选项卡中,我想显示一个 RecyclerView,但他从未出现过,有了断点,我看到
当我按下 Activity 中的按钮时,会弹出一个 DialogFragment。在对话框 fragment 中,有一个看起来像普通 ListView 的 RecyclerView。 我想要的行为是当
我是一名优秀的程序员,十分优秀!