ios客户端字符串加密,服务端c#用的sha256和base64
obj-c
+(NSString*)getShaString:(NSString *)strFormat {
const char *cStr = [strFormat cStringUsingEncoding:NSUTF8StringEncoding];
NSData *data = [NSData dataWithBytes:cStr length:strFormat.length];
unsigned char digest[CC_SHA256_DIGEST_LENGTH];
CC_SHA256(data.bytes, data.length, digest);
NSString *result = [self base64Encoding:digest];
return result;
}
static const char encodingTable[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"
+(NSString*)base64Encoding:(unsigned char[])data {
//if ([data count] == 0)
// return @"";
char *characters = malloc(((CC_SHA256_DIGEST_LENGTH + 2) / 3) * 4);
if (characters == NULL)
return nil;
NSUInteger length = 0;
NSUInteger i = 0;
while (i < CC_SHA256_DIGEST_LENGTH)
{
char buffer[3] = {0,0,0};
short bufferLength = 0;
while (bufferLength < 3 && i < CC_SHA256_DIGEST_LENGTH)
buffer[bufferLength++] = data[i++];
// Encode the bytes in the buffer to four characters, including padding "=" characters if necessary.
characters[length++] = encodingTable[(buffer[0] & 0xFC) >> 2];
characters[length++] = encodingTable[((buffer[0] & 0x03) << 4) | ((buffer[1] & 0xF0) >> 4)];
if (bufferLength > 1)
characters[length++] = encodingTable[((buffer[1] & 0x0F) << 2) | ((buffer[2] & 0xC0) >> 6)];
else characters[length++] = '=';
if (bufferLength > 2)
characters[length++] = encodingTable[buffer[2] & 0x3F];
else characters[length++] = '=';
}
return [[NSString alloc] initWithBytesNoCopy:characters length:length encoding:NSASCIIStringEncoding freeWhenDone:YES];
}
c#
System.Text.ASCIIEncoding encoder = new System.Text.ASCIIEncoding();
byte[] combined = encoder.GetBytes(str);
System.Security.Cryptography.SHA256 hash = System.Security.Cryptography.SHA256.Creat();
hash.ComputeHash(combined);
string result = Convert.ToBase64String(hash.Hash);