首先需要将字符串使用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