CCCrypt函数——iOS加解密必知

需要引入框架  

#import <CommonCrypto/CommonCryptor.h>

 函数定义:

CCCryptorStatus CCCrypt(
    CCOperation op,         /* kCCEncrypt, etc. */
    CCAlgorithm alg,        /* kCCAlgorithmAES128, etc. */
    CCOptions options,      /* kCCOptionPKCS7Padding, etc. */
    const void *key,
    size_t keyLength,
    const void *iv,         /* optional initialization vector */
    const void *dataIn,     /* optional per op and alg */
    size_t dataInLength,
    void *dataOut,          /* data RETURNED here */
    size_t dataOutAvailable,
    size_t *dataOutMoved)

参数说明:

1.CCOperation op

/* 加密:kCCEncrypt = 0,    解密:kCCDecrypt = 1 */

2.CCAlgorithm alg

加解密根据哪个算法标准

kCCAlgorithmAES128=0,
kCCAlgorithmAES=0,
kCCAlgorithmDES=1,
kCCAlgorithm3DES=2,
kCCAlgorithmCAST,
kCCAlgorithmRC4,
kCCAlgorithmRC2, 
kCCAlgorithmBlowfish

3.CCOptions options:

选择的补码方式,以及是否选择ECB模式,默认是CBC模式

kCCModeECB		= 1,
kCCModeCBC		= 2,
kCCModeCFB		= 3,
kCCModeCTR		= 4,
kCCModeF8		= 5, // Unimplemented for now (not included)
kCCModeLRW		= 6, // Unimplemented for now (not included)
kCCModeOFB		= 7,
kCCModeXTS		= 8,
kCCModeRC4		= 9,
kCCModeCFB8		= 10,

4.const void *key:

密钥: 加密和解密的密钥必须一致。必须和选择的算法相匹配,不同的算法要求的秘钥长度不一样

5.size_t keyLength:

密钥的大小,这里是真正决定密钥长度的地方

kCCKeySizeAES128          = 16,
kCCKeySizeAES192          = 24,
kCCKeySizeAES256          = 32,
kCCKeySizeDES             = 8,
kCCKeySize3DES            = 24,
kCCKeySizeMinCAST         = 5,
kCCKeySizeMaxCAST         = 16,
kCCKeySizeMinRC4          = 1,
kCCKeySizeMaxRC4          = 512,
kCCKeySizeMinRC2          = 1,
kCCKeySizeMaxRC2          = 128,
kCCKeySizeMinBlowfish     = 8,
kCCKeySizeMaxBlowfish     = 56,

6.iv

偏移向量,CBC模式下需要;不传默认16位0,只有在ECB模式下不需要

7.const void *dataIn:
要加解密的数据data.bytes

8.size_t dataInLength:

要加解密的数据的大小

9.void *dataOut :

输出的数据,加解密后的数据写在这里,

10.size_t dataOutAvailable:

输出数据时需要的可用空间大小。数据缓冲区的大小(字节)

11.size_t dataOutMoved:

操作成功之后,被写入dataout的字节长度。如果由于提供的缓冲区空间不足而返回kCCBufferTooSmall,则在这里返回所需的缓冲区空间。

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
要在Hive中实现RSA加密和解密的自定义函数,你需要使用Hive的UDF(用户定义的函数)功能,并结合Java的RSA加密和解密算法。 下面是一个基本的示例,展示如何在Hive中实现RSA加密和解密的自定义函数: 1. 创建一个Java类,例如`RSACrypto.java`,实现RSA加密和解密的逻辑。 ```javaimport java.security.*; import javax.crypto.*; import java.util.Base64; public class RSACrypto { public static String encrypt(String plainText, String publicKey) throws Exception { Cipher cipher = Cipher.getInstance("RSA"); KeyFactory keyFactory = KeyFactory.getInstance("RSA"); PublicKey pubKey = keyFactory.generatePublic(new X509EncodedKeySpec(Base64.getDecoder().decode(publicKey))); cipher.init(Cipher.ENCRYPT_MODE, pubKey); byte[] encryptedBytes = cipher.doFinal(plainText.getBytes()); return Base64.getEncoder().encodeToString(encryptedBytes); } public static String decrypt(String encryptedText, String privateKey) throws Exception { Cipher cipher = Cipher.getInstance("RSA"); KeyFactory keyFactory = KeyFactory.getInstance("RSA"); PrivateKey privKey = keyFactory.generatePrivate(new PKCS8EncodedKeySpec(Base64.getDecoder().decode(privateKey))); cipher.init(Cipher.DECRYPT_MODE, privKey); byte[] decryptedBytes = cipher.doFinal(Base64.getDecoder().decode(encryptedText)); return new String(decryptedBytes); } } ``` 2. 编译`RSACrypto.java`文件,并将生成的`.class`文件打包成`jar`文件。 ```shelljavac RSACrypto.javajar cf rsacrypto.jar RSACrypto.class``` 3. 将`rsacrypto.jar`文件上传到Hive的服务器上。 4. 在Hive中创建一个函数,使用`CREATE FUNCTION`语句。 ```sqlCREATE FUNCTION rsa_encrypt AS 'com.example.RSACrypto' USING JAR 'hdfs:///path/to/rsacrypto.jar'; CREATE FUNCTION rsa_decrypt AS 'com.example.RSACrypto' USING JAR 'hdfs:///path/to/rsacrypto.jar'; ``` 5. 使用自定义函数进行RSA加密和解密。 ```sqlSELECT rsa_encrypt('Hello World', '<public_key>') AS encrypted_text; SELECT rsa_decrypt('<encrypted_text>', '<private_key>') AS decrypted_text; ``` 请确保替换`<public_key>`和`<private_key>`为实际的RSA公钥和私钥。还要注意,这只是一个简单的示例,实际上,您可能需要处理更复杂的情况,例如密钥管理和编码/解码方式等。 希望这个示例能帮助您实现在Hive中使用自定义函数进行RSA加密和解密。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值