C加密传输
公司电子表格加密用上海迅软信息科技有限公司的加密软件。
首先选中客户端电脑上的单个文件、多个文件或文件夹右键菜单“DSE迅软数据安全->“手动加密”
选中客户端右下角图标,右键菜单“业务申请”->“手动加密”
通过以上两种方式,点击“手动加密”即可弹出手动加密界面
通过“增加文件”按钮可以增加多个文件,“增加目录”按钮可以增加整个文件夹下的所有文件。
需要处理文件后缀名输入框,输入后缀名,点击“过滤文件”可以将不需要处理
的文件过滤掉,例如,加密文件列表中同时包含.doc,.xls,.pdf,的多个文件,
在需要处理文件后缀输入框中输入doc,点“过滤文件”,过滤完以后,需要加
密的文件列表中只有.doc的文件,xls和pdf的文件都被过滤掉了。
加密文件的密级可以自定义,选择“高”,文件手动加密以后密级就为高,选择
好密级,点击“开始”即开始执行手动加密操作,操作完成以后会弹出完成的提
示,并提示,加密成功几个,失败几个。
2. c 语言常用的加密算法——AES加密算法
在C语言中,加密算法是保护数据安全的关键工具,其中常用的算法包括AES、RSA、MD5、SHA-1以及Base64编码。以下内容将具体介绍这些算法在C语言中的实现方法。
AES加密算法是一种广泛应用的对称加密算法,适用于数据加密。在C语言中,可以借助openssl库实现AES加密功能。以下为一个简单的AES加密示例代码,展示了如何使用openssl库进行加密操作。
代码如下:
c
#include
#include
#include aes.h>
#define AES_BLOCK_SIZE 16
void encrypt(unsigned char *plaintext, int plaintext_len, unsigned char *key, unsigned char *iv, unsigned char *ciphertext) {
AES_KEY aes_key;
AES_set_encrypt_key(key, 128, &aes_key);
int num_blocks = plaintext_len / AES_BLOCK_SIZE;
unsigned char iv_[AES_BLOCK_SIZE];
memcpy(iv_, iv, AES_BLOCK_SIZE);
for (int i = 0; i < num_blocks; i++) {
AES_cbc_encrypt(plaintext + (i * AES_BLOCK_SIZE), ciphertext + (i * AES_BLOCK_SIZE), AES_BLOCK_SIZE, &aes_key, iv_, AES_ENCRYPT);
memcpy(iv_, ciphertext + (i * AES_BLOCK_SIZE), AES_BLOCK_SIZE);
}
}
在示例中,加密密钥和初始向量均设置为16字节长度的字符串。待加密的数据为字符串形式,其长度通过`plaintext_len`传递给`encrypt`函数。加密结果存储在`ciphertext`数组中,其长度为原始数据的长度加上一个块大小(16字节)。加密后,输出加密数据的16进制格式。
RSA加密算法是一种非对称加密算法,具有加密与解密密钥不同的特点,是目前应用最为成熟的一种。在C语言中,同样可以使用openssl库实现RSA加密功能。
MD5算法作为广泛使用的加密散列函数,可以产生一个128位的散列值,适用于数字签名和验证、消息摘要等场景。在C语言中,通过 openssl库可以实现MD5加密。
SHA-1算法全称为Secure Hash Algorithm 1,是一种密码哈希函数,用于数字签名、验证和消息摘要等目的。在C语言中,同样借助openssl库实现SHA-1加密。
Base64编码虽然严格意义上不属于加密算法,但其能一定程度隐藏信息,常用于简单的“加密”操作。在C语言中,通过openssl库可以实现Base64编码和解码。
在C语言中,通过使用openssl这样的第三方库,可以高效地实现上述加密算法。这些库已经实现了各种算法的优化实现,方便开发者直接调用。
3. c 语言常用的加密算法——MD5
在C语言中,常用的加密算法主要包括AES、RSA、MD5、SHA-1及Base64编码。
AES加密算法是一种对称加密算法,广泛应用于数据加密。通过OpenSSL库在C语言中实现AES加密。
RSA加密算法为非对称加密算法,使用两把不同的密钥进行加密与解密,是最成熟且常用的非对称加密算法。同样使用OpenSSL库在C语言中实现RSA加密。
MD5算法作为加密散列函数,产生128位散列值,广泛应用于C语言中。通过OpenSSL库实现MD5加密。
SHA-1算法全称为Secure Hash Algorithm 1,用于数字签名、验证、消息摘要等,C语言中通过OpenSSL库实现SHA-1加密。
Base64编码虽非加密算法,但用于隐藏信息,C语言中通过OpenSSL库进行Base64编码与解码。
实现这些算法时通常利用OpenSSL库,因其提供了高效实现,避免了重复开发。
MD5算法在C语言中的实现示例如下:
#include
#include md5.h>
int main() {
char *str = "Hello, world!";
unsigned char digest[MD5_DIGEST_LENGTH];
MD5((unsigned char*) str, strlen(str), digest);
printf("MD5 hash of \"%s\": ", str);
for (int i = 0; i < MD5_DIGEST_LENGTH; i++) {
printf("%02x", digest[i]);
}
printf(" ");
return 0;
}
通过OpenSSL库中的MD5函数,传入字符串与长度,将结果存储在数组中,然后打印数组内容即为MD5散列值。