使用iOS进行Rc4加密解密

搜了一次,网络上绝大部分,都转的是下面的这个封装的:

http://www.cocoachina.com/bbs/read.php?tid-77608.html

首先非常感谢楼主的分享,但是使用后发现这个里面的代码实际上是有问题的:

为了帮后人摆脱此坑的困扰,本人稍微做了一下修正,具体如下:

+(NSString*)HloveyRC4:(NSString*)aInput key:(NSString*)aKey
{

    NSMutableArray *iS = [[NSMutableArray alloc] initWithCapacity:256];
    NSMutableArray *iK = [[NSMutableArray alloc] initWithCapacity:256];

    for (int i= 0; i<256; i++) {
        [iS addObject:[NSNumber numberWithInt:i]];
    }

    int j=1;
  //改动1,s-box的长度应当是256,楼主之前写的是255
    for (short i=0; i<256; i++) {

        UniChar c = [aKey characterAtIndex:i%aKey.length];

        [iK addObject:[NSNumber numberWithChar:c]];
    }

    j=0;

    for (int i=0; i<256; i++) {
        int is = [[iS objectAtIndex:i] intValue];
        UniChar ik = (UniChar)[[iK objectAtIndex:i] charValue];

        j = (j + is + ik)%256;
        NSNumber *temp = [iS objectAtIndex:i];
        [iS replaceObjectAtIndex:i withObject:[iS objectAtIndex:j]];
        [iS replaceObjectAtIndex:j withObject:temp];

    }

    int i=0;
    j=0;

    

    Byte byteBuffer[aInput.length];



    for (short x=0; x<[aInput length]; x++) {
        i = (i+1)%256;

        int is = [[iS objectAtIndex:i] intValue];
        j = (j+is)%256;

        int is_i = [[iS objectAtIndex:i] intValue];
        int is_j = [[iS objectAtIndex:j] intValue]; 

        int t = (is_i+is_j) % 256;
        int iY = [[iS objectAtIndex:t] intValue];

        //改动2:增加交换is_iis_j的具体内容

        [iS exchangeObjectAtIndex:i withObjectAtIndex:j];


        UniChar ch = (UniChar)[aInput characterAtIndex:x];
        UniChar ch_y = ch^iY;

        

        byteBuffer[x] = ch_y;


    }

    [iS release];
    [iK release];

    return result;
}

 

+ (NSString *)byteToBase64String:(Byte [])byteBuffer lengh:(NSInteger)buffLen

{

    NSData *adata = [[NSData alloc] initWithBytes:byteBuffer length:buffLen];

    NSString *string = [adata base64EncodedStringWithOptions:0];

    return string;

}

参考资料:

http://baike.baidu.com/link?url=GDR7_BqVSKStCioLhfGikGMJ_MBwiGCsuB1bowM3ZRvZ0tNGesVt15AKLPXVjV5qfCaAMxwjolEM9dNy9ca3qa

百度百科,c语言实现

 

转载于:https://www.cnblogs.com/Peterahan/p/4625971.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值