java 加密 aec_java的sha1加密和object-c的sha1加密后的值不一样,谁能帮我解决一下。多谢了...

java代码importjava.security.MessageDigest;//importsun.misc.BASE64Encoder;publicclassSecurityUtil{publicstaticStringencryptPassword(Stringpassword)throwsException{returnge...

java代码

import java.security.MessageDigest;

//import sun.misc.BASE64Encoder;

public class SecurityUtil {

public static String encryptPassword(String password) throws Exception {

return getSHA(password);

}

public static String getSHA(String vars) throws Exception {

MessageDigest md5 = MessageDigest.getInstance("SHA-1");

md5.update(vars.getBytes("UTF-8"));

byte[] digesta = md5.digest();

BASE64Encoder base64 = new BASE64Encoder();

return base64.encode(digesta);

}

public static void main(String[] arg) throws Exception {

System.out.println(encryptPassword("000000"));

}

}

加密后输出:yYSu0BSux2I6VPBZHaB6hf1Ldi0=

object-c代码

+(NSString*) digest:(NSString*)input

{

//const char *cstr = [input cStringUsingEncoding:NSUTF8StringEncoding];

const

char *cstr=[input cStringUsingEncoding:NSUTF16StringEncoding];

//const char *cstr="000000";

NSData *data = [NSData

dataWithBytes:cstr length:input.length];

uint8_t digest[CC_SHA1_DIGEST_LENGTH];

CC_SHA1(data.bytes, data.length,

digest);

//NSMutableString* output = [NSMutableString stringWithCapacity:CC_SHA1_DIGEST_LENGTH * 2];

NSMutableString*

output = [NSMutableString stringWithCapacity:CC_SHA1_DIGEST_LENGTH];

for(int i = 0; i < CC_SHA1_DIGEST_LENGTH; i++)

[output appendFormat:@"%02x", digest[i]];

return output;

}

输出000000后输出:c984aed014aec7623a54f0591da07a85fd4b762d

好像是差在编码方式或是初位上,请高人指点。

我想object-c加密后与java的一样。

展开

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值