小谈加密算法

1、为什么要用加密

网站中有很多类似金钱、密码等重要业务数据,一旦被监听、拦截,可能会造成严重的损失。
比如下图:

我们可以很容易的看到某个请求的相关参数数据
这里写图片描述

2、应用场景

加密算法有很多种应用场景,最常见的是用户登录、身份验证、验签等等。目的在于通过算法,将明文转换为密文。将明文转换为密文只是第一步,更深一步的做法是结合sessionId、随机数、token或者https等,最大限度的防止信息被盗取。

3、类型

加密算法通常分为对称性加密算法和非对称性加密算法。

3.1 对称性加密

只存在一把钥匙key,如果A想要与B通讯,那么A使用钥匙进行加密,B接收到密文的钥匙后,使用钥匙解密,获得明文信息。

这里写图片描述

优缺点
效率高、使用维护简单,缺点就是密码一旦泄露,通讯信息就会暴露。

常用加密算法:
DES、三重DES、AES等,稍后会以AES为例,介绍具体用法。

3.2 非对称加密

非对称加密有两把钥匙:私钥和公钥。
这里有几个原则和前提需要先说明:
1)公钥和私钥是成对出现的。
2)公开的是公钥,私钥只有自己知道。
3)用公钥加密的信息,只能用对应的私钥进行解密。

这里写图片描述

A、B各有一对密钥,A的密钥包括:公钥01、私钥02,B的密钥包括:公钥03、私钥04。其中,A拥有B的公钥03,同样的,B也拥有A的公钥01。

当A要与B通讯时,A使用B的公钥03加密,当B拿到密文后,拿自己的私钥04解密。

优缺点:
非对称加密的优缺点正好与对称加密相反,可参照上面。

常用加密算法:
RSA,DSA,ECC

除了上面两种主要类型的加密算法,还有一大类是线性散列算法,也叫签名算法。常用算法有:MD5,SHA1,HMAC。这类算法可以生成一长串不可逆的密文,经常用在校验数据在传输过程中是否经过修改。

4、实例

场景:用户登录,使用res加密,前端js加密,后端解密。

4.1 js文件

   //加密key
   var key =CryptoJS.enc.Utf8
### 回答1: 使用 C 语言编写加密算法的方法有很多种,这里提供一种简单的方法: 1. 选择加密算法。常见的加密算法有对称加密算法和非对称加密算法,其中对称加密算法包括DES、3DES、AES等,非对称加密算法包括RSA、DSA等。根据需求选择适合的加密算法。 2. 编写加密程序。根据选定的加密算法,编写加密程序,其中包括加密算法实现、密钥的生成、密钥的存储等部分。 3. 对要加密的数据进行编码。对于要加密的数据,可以进行一定的编码,如将明文转换成二进制、16进制或Base64编码等,以便于进行加密处理。 4. 调用加密程序进行加密。在程序中调用编写的加密算法程序,将编码后的明文和密钥作为输入,获得密文作为输出。 5. 对加密结果进行解码和验证。对于加密后的密文,需要进行相应的解码,获得加密前的明文。同时需要对解密后的明文进行验证,以确保解密后的明文与原始明文一致。 需要注意的是,加密算法实现需要遵循安全性原则,以保证加密结果的安全性。此外,加密算法的效率也需要考虑,以保证加密处理的速度。 ### 回答2: 使用C语言编写一个加密算法可以有多种方式,以下是其中一种简单的方法: ```c #include <stdio.h> void encrypt(char* str, int key) { for (int i = 0; str[i] != '\0'; i++) { // 对字母进行位移操作,key为移动的位数 if (str[i] >= 'a' && str[i] <= 'z') { str[i] = (str[i] - 'a' + key) % 26 + 'a'; } else if (str[i] >= 'A' && str[i] <= 'Z') { str[i] = (str[i] - 'A' + key) % 26 + 'A'; } } } int main() { char str[100]; int key; printf("请输入要加密的字符串:"); fgets(str, sizeof(str), stdin); printf("请输入要移动的位数(0-25之间的整数):"); scanf("%d", &key); encrypt(str, key); printf("加密后的字符串为:%s", str); return 0; } ``` 这个加密算法采用了简单的字母位移操作,加密过程中,根据输入的移动位数,将字符串中的字母逐个进行位移操作,对于小写字母将其映射到0-25的范围内,对于大写字母也是如此,然后再加上移动位数之后,再将结果映射回对应的ASCII码,最终得到加密后的字符串。 注:这只是一个简单的加密算法示例,实际应用中需要使用更加复杂和安全的加密算法来保护数据的安全性。 ### 回答3: 当谈到加密算法时,C语言提供了许多常见的加密函数和库,例如OpenSSL和Crypto++,可用于开发强大而安全的加密算法。在这里,我将向您介绍一个简单的C语言加密算法示例,以实现对字符串的简单加密。 ```c #include <stdio.h> void encrypt(char* input, int key) { char ch; int i; // 遍历输入字符串 for(i = 0; input[i] != '\0'; ++i) { ch = input[i]; // 对每个字符进行简单的加密 // 可根据实际需求修改加密规则 if(ch >= 'a' && ch <= 'z') { ch = ch + key; if(ch > 'z') { ch = ch - 'z' + 'a' - 1; } input[i] = ch; } else if(ch >= 'A' && ch <= 'Z') { ch = ch + key; if(ch > 'Z') { ch = ch - 'Z' + 'A' - 1; } input[i] = ch; } } } int main() { char str[100]; int key; printf("请输入需要加密的字符串:"); scanf("%s", str); printf("请输入加密密钥(整数):"); scanf("%d", &key); encrypt(str, key); printf("加密后的字符串为:%s\n", str); return 0; } ``` 以上示例中,我们定义了一个简单的加密函数`encrypt`,该函数接受一个字符串以及一个密钥作为参数,对字符串进行简单的加密加密规则是将字符串中的字母按照密钥值进行向后位移,并处理循环回到字母表的开头。最后,我们在`main`函数中获取用户输入的字符串和密钥,并将其传递给加密函数。最后,打印加密后的字符串。 需要注意的是,这只是一个简单的加密算法示例,它的安全性有限。实际应用中,为了达到更高的安全性,我们需要使用更复杂和经过测试的加密算法,并且应谨慎处理密钥的生成和存储。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值