据CCN消息,泰国反洗钱办公室(AMLO)秘书Witthaya
Neetitham在曼谷举行的一次关于加密相关犯罪的研讨会上说,政府机构正在计划建立自己的加密钱包,用于解决与比特币和其他加密货币有关的犯罪问题,政府考虑开设加密货币钱包以持有在执法过程中没收的加密资产。

  • RSA简单说明:加密算法算法是公开的,加密方式如下:

Category的 .h 文件:

RSA
公钥私钥声称与互相解密原理

由于都是字符串的方法,就写成字符串的分类,方便以后使用。

1. 在网络上"不允许"传输用户隐私数据的"明文"
2. 在本地"不允许"保存用户隐私数据的"明文"

公钥加密 私钥解密
,私钥加密,公钥验证(签名)

小编致力于用精简的语言说明不精简的问题

import “NSString+util.h”

"公钥"加密,"私钥"解密
"私钥"加密,"公钥"解密

摘要: 对字符串的处理,加密有 MD5、SHA256,生成随机编码 UUID。
iOS中对的加密算法并不很了解
,今天看到一个分类是处理字符串编码的,所以记录一下。

Base64

1.Base64简单说明

描述:Base64可以成为密码学的基石,非常重要。
特点:可以将任意的二进制数据进行Base64编码
结果:所有的数据都能被编码为只用65个字符就能表示的文本文件。
65字符:A~Z a~z 0~9 + / =
对文件进行base64编码后文件数据的变化:编码后的数据~=编码前数据的4/3,会大1/3左右。

2.命令行进行Base64编码和解码

编码:base64 123.png -o 123.txt
解码:base64 123.txt -o test.png -D

2.Base64编码原理

1)将所有字符转化为ASCII码;
2)将ASCII码转化为8位二进制;
3)将二进制3个归成一组(不足3个在后边补0)共24位,再拆分成4组,每组6位;
4)统一在6位二进制前补两个0凑足8位;
5)将补0后的二进制转为十进制;
6)从Base64编码表获取十进制对应的Base64编码;

处理过程说明:

a.转换的时候,将三个byte的数据,先后放入一个24bit的缓冲区中,先来的byte占高位。
b.数据不足3byte的话,于缓冲区中剩下的bit用0补足。然后,每次取出6个bit,按照其值选择查表选择对应的字符作为编码后的输出。
c.不断进行,直到全部输入数据转换完成。
d.如果最后剩下两个输入数据,在编码结果后加1个“=”;
e.如果最后剩下一个输入数据,编码结果后加2个“=”;
f.如果没有剩下任何数据,就什么都不要加,这样才可以保证资料还原的正确性。

3.实现

a.说明:
    1)从iOS7.0 开始,苹果就提供了base64的编码和解码支持
    2)如果是老项目,则还能看到base64编码和解码的第三方框架,如果当前不再支持iOS7.0以下版本,则建议替换。

b.相关代码:
//给定一个字符串,对该字符串进行Base64编码,然后返回编码后的结果
-(NSString *)base64EncodeString:(NSString *)string
{
    //1.先把字符串转换为二进制数据
    NSData *data = [string dataUsingEncoding:NSUTF8StringEncoding];

    //2.对二进制数据进行base64编码,返回编码后的字符串
    return [data base64EncodedStringWithOptions:0];
}

//对base64编码后的字符串进行解码
-(NSString *)base64DecodeString:(NSString *)string
{
    //1.将base64编码后的字符串『解码』为二进制数据
    NSData *data = [[NSData alloc]initWithBase64EncodedString:string options:0];

    //2.把二进制数据转换为字符串返回
    return [[NSString alloc]initWithData:data encoding:NSUTF8StringEncoding];
}

c.终端测试命令
    $ echo -n A | base64
    $ echo -n QQ== |base64 -D

分别为三个方法,分别是生成随机编码UUID(根据当前时间,设备等生成唯一的,不重复的编码)、对字符串进行MD5
算法加密、对字符串进行SHA256算法加密,后两个加密都是不可逆的,只能加密
不能破解。

import <CommonCrypto/CommonDigest.h>

@implementation NSString (util)

  • (NSString *)UUIDString {
    CFUUIDRef uuid = CFUUIDCreate(NULL);
    NSString *s = (__bridge_transfer NSString
    *)CFUUIDCreateString(NULL, uuid);
    if(uuid) {
    CFRelease(uuid);
    }
    return s;
    }

  • (NSString *)MD5 {
    NSData *data = [self dataUsingEncoding:NSUTF8StringEncoding];
    unsigned char result[CC_MD5_DIGEST_LENGTH];
    CC_MD5([data bytes], (CC_LONG)[data length], result);
    return [NSString
    stringWithFormat:
    @”%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x”,
    result[0], result[1],
    result[2], result[3],
    result[4], result[5],
    result[6], result[7],
    result[8], result[9],
    result[10], result[11],
    result[12], result[13],
    result[14], result[15]
    ];
    }

  • (NSString *)SHA256 {
    const char *cstr = [self UTF8String];
    unsigned char result[CC_SHA256_DIGEST_LENGTH];
    CC_SHA256(cstr, (CC_LONG)strlen(cstr), result);
    NSMutableString ret = [NSMutableString
    stringWithCapacity:CC_SHA256_DIGEST_LENGTH
    2];
    for (int i = 0; i < CC_SHA256_DIGEST_LENGTH; i++) {
    [ret appendFormat:@”%02x”,result[i]];
    }
    return [NSString stringWithString:ret];
    }
    @end

在其他地方调用:

NSString *str = @"1";

NSLog(@"--MD5-  %@",[str MD5]);

NSLog(@"--SHA-  %@",[str SHA256]);

NSLog(@"--UUID- %@",[NSString UUIDString]);

Log 结果

–MD5- c4ca4238a0b923820dcc509a6f75849b

–SHA- 6b86b273ff34fce19d6b804eff5a3f5747ada4eaa22f1d49c01e52ddb7875b4b

–UUID- D7CBE61C-6F77-48FA-99BE-F320FB8CB24C

还看到一个加密是iOS7出现的base64,是针对Data的编码与解码。encode 与
decode

NSString *str = @”hello”;

NSData* originData = [str dataUsingEncoding:NSUTF8StringEncoding];

NSString* encodeResult = [originData base64EncodedStringWithOptions:NSDataBase64EncodingEndLineWithLineFeed];

NSLog(@" 编码 encode 结果 :%@",encodeResult);

NSData* decodeData = [[NSData alloc] initWithBase64EncodedString:encodeResult options:0];

NSString* decodeStr = [[NSString alloc] initWithData:decodeData encoding:NSUTF8StringEncoding];

NSLog(@" 解码 decode 结果 :%@",decodeStr);

Log 结果为:

17:11:22.586 SS[61987:3210619] 编码 encode 结果 :aGVsbG8=

17:11:22.587 SS[61987:3210619] 解码 decode 结果 :hello

1. base64 编码格式
2. 密码学演化 "秘密本"-->RSA

import <Foundation/Foundation.h>

@interface
NSString (util)

-(NSString *)MD5;

  • (NSString *)SHA256;

  • (NSString *)UUIDString;

@end

.m文件:

  • 加密相关

HTTPS —
AFSecurityPolicy

散列函数:

特点:

  • 算法是公开的
  • “对相同的数据加密,得到的结果是一样的”
  • 对不同的数据加密,得到的结果是定长的
    • 得到的结果都是 32 个字符长度的字符串
  • 信息摘要,信息”指纹”,是用来做数据识别的!
  • 不能反算的

用途:

  • 密码,服务器并不需要知道用户真实的密码!
  • 搜索

如何判断:对搜索的每个关键字进行散列,得到三个相对应的结果,按位相加结果如果是一样的,那搜索的内容就是一样的!
        张老师 杨老师 苍老师
        苍老师 张老师 杨老师

        张老师            1bdf605991920db11cbdf8508204c4eb
        杨老师             2d97fbce49977313c2aae15ea77fec0f
        苍老师             692e92669c0ca340eff4fdcef32896ee
  • 版权

破解:md5加密是可以被破解的

提升MD5加密安全性,有两个解决办法:

1. 加"盐"(佐料)
2. HMAC:给定一个"秘钥",对明文进行加密,并且做"两次散列"!-> 得到的结果,还是 32 个字符
  • 网络应用程序数据的原则:

目前流行的加密方式:

  • 哈希(散列)函数

    • MD5
    • SHA1
    • SHA256
  • 对称加密算法

    • DES
    • 3DES
    • AES(高级密码标准,美国国家安全局使用的)
  • 非对称加密算法(RSA)

网站地图xml地图