关于CBBase58
项目github地址:
https://github.com/caobo56/CBBase58
从 CoreBitcoin 项目摘出来的base58部分代码,可以直接引用Base58.
创建该repo 是因为公司区块链项目需要用到base58,但在pod和github上又没找到合适的库
于是自己创建一个,方便项目集成
其实 CoreBitcoin项目中又其他与区块链相关的更为完整的pod库
但我不需要那么多,万一其他类别的项目也用到了base58,可以简单的集成CBBase58就可以了
使用方式:
pod 'CBBase58'
CBBase58 的 CBBase58.podspec
Pod::Spec.new do |s|
s.name = "CBBase58"
s.version = "0.9.0"
s.summary = "caobo's CBBase58. A base58 code. Copy from CoreBitcoin."
s.description = <<-DESC
It is a utils used on iOS, which implement by Objective-C.
DESC
s.homepage = "https://github.com/caobo56/CBBase58"
s.license = { :type => "MIT", :file => "LICENSE" }
s.author = { "caobo" => "caobo56@sina.com" }
s.platform = :ios, "8.0"
s.source = { :git => "https://github.com/caobo56/CBBase58.git", :tag => "0.9.0" }
s.source_files = "src", "CBBase58/base58/*.{h,m}"
s.dependency "OpenSSL-Universal"
end
base58的查询字母表
我的CBBase58 是从CoreBitcoin摘出来的,CoreBitcoin是比特币的pod库,他的base58 最后查询的字母表与比特币的保持一致,如果有更改的需要,可以从github上下载代码并修改。
修改代码的位置为:
BTCBase58.m
static const char* BTCBase58Alphabet = "123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz";
关于base58
base58和base64一样是一种二进制转可视字符串的算法,主要用来转换大整数值。区别是,转换出来的字符串,去除了几个看起来会产生歧义的字符,如 0 (零), O (大写字母O), I (大写的字母i) and l (小写的字母L) ,和几个影响双击选择的字符,如/, +。结果字符集正好58个字符(包括9个数字,24个大写字母,25个小写字母)。不同的应用实现中,base58 最后查询的字母表可能不同,所以没有具体的标准。
比特币之所以加入改进版的 Base58 算法,主要为了解决 Base58 导出的字符串没有校验机制,这样,在传播过程中,如果漏写了几个字符,会检测不出来。所以使用了改进版的算法 Base58Check。
下面是几个应用中的字母表:
比特币地址:
123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz
Monero 地址
123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz
Ripple 地址
rpshnaf39wBUDNEGHJKLM4PQRST7VWXYZ2bcdeCg65jkm8oFqi1tuvAxyz
Flickr 的短URL
123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ
关于RIPEMD-160(CBBase58 版本 0.9.1 发布)
RIPEMD(RACE Integrity Primitives Evaluation Message Digest,RACE原始完整性校验消息摘要),是Hans Dobbertin等3人在md4,md5的基础上,于1996年提出来的。算法共有4个标准128、160、256和320,其对应输出长度分别为16字节、20字节、32字节和40字节。不过,让人难以致信的是RIPEMD的设计者们根本就没有真正设计256和320位这2种标准,他们只是在128位和160位的基础上,修改了初始参数和s-box来达到输出为256和320位的目的。所以,256位的强度和128相当,而320位的强度和160位相当。RIPEMD建立在md的基础之上,所以,其添加数据的方式和md5完全一样。
在比特币区块链中,生成地址的过程用到了RIPEMD-160的算法,CoreBitcoin中同样也集成了相关的算法,(其实现也是基于OpenSSL)。
于是在CBBase58 的版本 0.9.1中,我将RIPEMD-160的相关类 NSData+Hashing.h/NSData+Hashing.m 也集成到pod库中,以方便使用。
NSData+Hashing.h 的接口:
#import <Foundation/Foundation.h>
@interface NSData (Hashing)
/// Returns the SHA-256 hash of self.
- (NSData *)SHA256Hash;
/// Returns the RIPEMD-160 hash of self.
- (NSData *)RIPEMD160Hash;
/// Performs the HMAC512-SHA256 algorithm on self using key and stores the result in digest.
- (void)HMACSHA512WithKey:(NSData *)key digest:(NSMutableData *)digest;
@end