Sample code for 30+ languages & platforms
Objective-C

Duplicate Java Verify RSA Signature

See more RSA Examples

Demonstrates how to duplicate a snippet of Java code that verifies an RSA signature.

Chilkat Objective-C Downloads

Objective-C
#import <NSString.h>
#import <CkoCert.h>
#import <CkoRsa.h>

BOOL success = NO;

// This requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.

// This example duplicates the following Java code:

// import com.sun.org.apache.xml.internal.security.utils.Base64;  
// import java.io.ByteArrayInputStream;  
// import java.security.PublicKey;  
// import java.security.Signature;  
// import java.security.cert.CertificateFactory;  
// import java.security.cert.X509Certificate;  
// public class validateSazetak {  
//   public static void main(String[] args) {  
//   String signatureAlgorithm = "SHA256withRSA";  
//   String base64DataToBeSigned = "Hlp...LE4=";  
//   String base64Certificate = "MII...TlQ==";  
//   String base64Signature = "I00...pZA==";  
//   try {  
//       CertificateFactory cf;  
//       X509Certificate certificate = null;  
//       cf = CertificateFactory.getInstance("X.509");  
//       certificate = (X509Certificate) cf.generateCertificate(new 
//       ByteArrayInputStream(Base64.decode(base64Certificate)));  
//        
//       Signature signature = Signature.getInstance(signatureAlgorithm, "SunRsaSign");  
//       PublicKey pk = (PublicKey) certificate.getPublicKey();  
//       signature.initVerify(pk);  
//        
//       byte[] hashBytes = Base64.decode(base64DataToBeSigned);  
//       signature.update(hashBytes);  
//        
//       byte[] sigBytes = Base64.decode(base64Signature);  
//       boolean validity = signature.verify(sigBytes);  
//       System.out.println("Is valid signature:" + validity);  
//     } catch (Exception e) {  
//         System.out.println(e);  
//     }  
// } 

NSString *base64DataToBeSigned = @"Hlp...LE4=";
NSString *base64Certificate = @"MII...TlQ==";
NSString *base64Signature = @"I00...pZA==";

CkoCert *cert = [[CkoCert alloc] init];
success = [cert LoadFromBase64: base64Certificate];
if (success == NO) {
    NSLog(@"%@",cert.LastErrorText);
    return;
}

CkoRsa *rsa = [[CkoRsa alloc] init];

success = [rsa SetX509Cert: cert usePrivateKey: NO];
if (success == NO) {
    NSLog(@"%@",rsa.LastErrorText);
    return;
}

rsa.EncodingMode = @"base64";
success = [rsa VerifyStringENC: base64DataToBeSigned hashAlg: @"sha256" sig: base64Signature];
if (success == NO) {
    NSLog(@"%@",rsa.LastErrorText);
    return;
}

NSLog(@"%@",@"Signature verified.");