C语言加密解密
当用户输入字符串后 字符串 传入加密函数 进行加密,返回加密后的结果。
解密也是同理。
加 i 的值是因为 i 是不断增加的 这样会使得加密后的值不会直接找到规律
加密 偏移量也可以用别的值替代。
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define KEY 5 // 偏移量
/**
*根据传入的字符串
* 参数1 要加密的字符串
* 返回加密后的参数
*/
char * encrypt(char[]);//加密
char * encryptr(char[]); //解密
int main()
{
char name[100];
printf("请输入需要加密的字符:");
scanf("%s",name);
encrypt(name);
printf("\n加密后的字符为:%s",name);
printf("\n");
printf("请输入需要解密的字符:");
scanf("%s",name);
encryptr(name);
printf("\n解密后的字符为:%s",name);
return 0;
}
char * encrypt(char str[]) //字符串加密
{
int i;
int count=strlen(str); //字符串长度
for(i=0;i<count;i++) //为什么for循环里不直接用strlen(str)量,因为for循环会每循环一次 就测量一次 所以不推荐使用
{
str[i]=str[i]+i+KEY; //str数组中的第i个值加上i的值加上偏移量
}
return str; //返回加密后的的字符串
}
char * encryptr(char str[]) //解密
{
int i;
int count=strlen(str); //字符串长度
for(i=0;i<count;i++)
{
str[i]=str[i]-i-KEY; //str数组中的第i个值减去i的值减去偏移量
}
return str; //返回解密后的字符串
}