首先需要将字符串使用md5加密,添加NSString的md5的类别方法如下
.h文件
1
2
3
4
5
6
7
|
#import <CommonCrypto/CommonDigest.h> @interface NSString (md5) -(NSString *) md5HexDigest; @end |
.m文件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
#import "NSString+md5.h" @implementation NSString (md5) - (NSString *) md5HexDigest { const char *original_str = [self UTF8String]; unsignedchar result[CC_MD5_DIGEST_LENGTH]; CC_MD5(original_str, strlen (original_str), result); NSMutableString *hash = [NSMutableStringstring]; for ( int i = 0; i < 16; i++) [hash appendFormat:@ "%02X" , result[i]]; NSLog(@ "lowercaseString = %@" ,[hash lowercaseString]); return [hash lowercaseString]; } @end |
然后就是转换算法了,其实与java版本的相同,只是用OC来实现
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
- (NSString *)shortUrl:(NSString *)url { NSArray *chars = [[NSArray alloc] initWithObjects:@ "a" , @ "b" , @ "c" , @ "d" , @ "e" , @ "f" , @ "g" , @ "h" , @ "i" , @ "j" , @ "k" , @ "l" , @ "m" , @ "n" , @ "o" , @ "p" , @ "q" , @ "r" , @ "s" , @ "t" , @ "u" , @ "v" , @ "w" , @ "x" , @ "y" , @ "z" , @ "0" , @ "1" , @ "2" , @ "3" , @ "4" , @ "5" , @ "6" , @ "7" , @ "8" , @ "9" , @ "A" , @ "B" , @ "C" , @ "D" , @ "E" , @ "F" , @ "G" , @ "H" , @ "I" , @ "J" , @ "K" , @ "L" , @ "M" , @ "N" , @ "O" , @ "P" , @ "Q" , @ "R" , @ "S" , @ "T" , @ "U" , @ "V" , @ "W" , @ "X" , @ "Y" , @ "Z" , nil]; NSLog(@ "chars = %d" , [chars count]); NSString *key = @ "xxxxxx" ; NSString *hex = [NSStringstringWithFormat:@ "%@" ,[[key stringByAppendingFormat:@ "%@" ,url] md5HexDigest]]; NSLog(@ "hex = %@" , hex); NSMutableArray *resUrl = [[NSMutableArrayalloc] initWithCapacity:4]; for ( int i=0; i<4; i++) { // 把加密字符按照 8 位一组 16 进制与 0x3FFFFFFF 进行位与运算 NSString *sTempSubString = [hex substringWithRange:NSMakeRange(i*8, 8)]; // 这里需要使用 long 型来转换,因为 Inteper只能处理 31 位 , 首位为符号位 , 如果不用 long ,则会越界 long longOfTemp; sscanf ([sTempSubString cStringUsingEncoding:NSASCIIStringEncoding], "%lx" , &longOfTemp); long lHexLong = 0x3FFFFFFF & longOfTemp; NSString *outChars = @ "" ; for ( int j=0; j<6; j++) { // 把得到的值与 0x0000003D 进行位与运算,取得字符数组 chars 索引 long index = 0x0000003D & lHexLong; // 把取得的字符相加 outChars = [outChars stringByAppendingFormat:@ "%@" ,[chars objectAtIndex:( int )index]]; // 每次循环按位右移 5 位 lHexLong = lHexLong >> 5; } // 把字符串存入对应索引的输出数组 [resUrl insertObject:outChars atIndex:i]; } return [resUrl objectAtIndex:0]; //这里可以返回任意一个元素作为短链接(0,1,2,3) } |
提 示:长链接转换短链接,原理很简单,就相当于重命名,只是自己的服务器定义自己的规则,有自己的密钥(也就是算法中定义的key变量,需要替换成自己用品 定义的key),然后确定使用resUrl中的哪个index的元素为可以识别的短链接,如果确定为第0个,那么算法中就要返回第0个。要拿来自己用的 话,只需要改一下key值即可。
必须有服务器定义key,要不点击转换成功后的链接浏览器是无法识别的,还有就是这里返回的字符串仅仅是一 串字符,并不带有域名什么的,还需要自己确定一套域名规则,比如新浪的地址转换成功后都是以http://t.cn/打头的,那么你就需要定义一个类似的 域名,域名具体如何定义这就不细说了!
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
原文链接:http://blog.csdn.net/u011374880/article/details/44225511