C语言实现任何文件的加密解密功能

 更新时间:2019年03月19日 15:53:58   作者:贝尔拉梅拉热翔  
这篇文章主要为大家详细介绍了C语言实现任何文件的加密解密功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C语言实现文件加密解密功能的具体代码,供大家参考,具体内容如下

使用命令提示符,实现任何文件的加密和解密功能。

代码如下:

//#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include<time.h>
#include<sys/stat.h>
 
 
#pragma warning(disable:4996)
 
//加密
void Encryption(char *p, size_t n)
{
 for (int i = 0; i < n;++i)
 {
 *p += 7;
 }
}
 
//解密
void Decrypt(char *p, size_t n)
{
 for (int i = 0; i < n;++i)
 {
 *p -= 7;
 }
}
 
char *EnOrDe = {0};
 
int main(int argc, char *args[])
{
 clock_t c1 = clock();//系统当前时间,毫秒为单位
 
 char *FileNameSrc = (char *)calloc(160, sizeof(char));//待操作文件
 
 char *p2 = (char *)calloc(200, sizeof(char));//操作后文件名
 
 //从命令行获取文件名和要处理的操作
 FileNameSrc = args[1];//文件名,包含路径
 
 char *p1 = args[1];
 
 EnOrDe = args[2];//en表示加密,de表示解密
 
 /*FileNameSrc = "E:\\iPhone6-new.txt" ;
 char *p1 = FileNameSrc;
 EnOrDe = "de";*/
 
 
 /**********处理生成新的文件名***********/
 //char *p2 = { 0 };
 /*FileNameSrc = p1;*/
 //printf("%s\n", FileNameSrc);
 //printf("%s\n", EnOrDe);
 
 int index = 0;
 while (*p1)
 {
 if (*p1!='.')
 {
 *p2 = *p1;
 p2++;
 p1++;
 index++;
 }
 else if (*p1 == '.')
 {
 *p2 = '_';
 p2++;
 *p2 = 'H';
 p2++;
 *p2 = '.';
 p2++;
 p1++;
 index+=2;
 }
 }
 printf("\n");
 printf("信息摘要:\n");
 printf("--------------------------------------\n");
 printf("原文件:%s\n", FileNameSrc);
 printf("操作:%s (en——加密,de——解密)\n", EnOrDe);
 printf("预计结果文件:%s\n", p2 - index - 1);
 printf("--------------------------------------\n\n");
 printf("请稍后,玩命处理中......\n");
 
 char *FileNameDst = p2 - index - 1;
 
 FILE *pr = fopen(FileNameSrc, "rb");
 FILE *pw = fopen(FileNameDst, "wb");
 
 struct stat st = { 0 };
 size_t fileSize = st.st_size;//以字节为单位
 
 //char *buf = NULL;
 //if (fileSize<1024*1024)//小于1M
 //{
 // buf = malloc(sizeof(char) * 1024 * 20);//分配20K
 //}
 //else
 //{
 // buf = malloc(sizeof(char)*fileSize / 10);
 //}
 char *buf = calloc(1024 * 1024 * 25, sizeof(int));//分配100M
 
 /*************定义函数指针***************/
 void(*pFunc)(char *, size_t);
 pFunc = NULL;
 if (strcmp(EnOrDe, "en") == 0)
 {
 pFunc = Encryption;
 }
 else if (strcmp(EnOrDe, "de") == 0)
 {
 pFunc = Decrypt;
 }
 /*************定义函数指针***************/
 
 
 while (!feof(pr))
 {
 //memset(buf, 0, sizeof(buf));//calloc自动初始化为0
 size_t res = fread(buf, sizeof(char), sizeof(buf), pr);
 
 pFunc(buf, res);
 
 fwrite(buf, sizeof(char), res, pw);
 }
 fclose(pr);
 fclose(pw);
 printf("\n");
 printf("--------------------------------------\n");
 printf("执行成功!\n所在目录:%s\n", FileNameDst);
 clock_t c2 = clock();//系统当前时间,毫秒为单位
 printf("耗时:%u毫秒\n", c2-c1);
 printf("--------------------------------------\n");
 return 0;
}

效果:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • visual studio 2022 编译出来的文件被删除并监视目录中的文件变更(示例详解)

    visual studio 2022 编译出来的文件被删除并监视目录中的文件变更(示例详解)

    这篇文章主要介绍了visual studio 2022 编译出来的文件被删除 并监视目录中的文件变更,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-08-08
  • C++双向循环列表用法实例

    C++双向循环列表用法实例

    这篇文章主要介绍了C++双向循环列表,实例分析了C++双向循环列表的创建、输出、添加、删除、移动的相关操作技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-07-07
  • C语言中字符型数据和浮点型数据介绍

    C语言中字符型数据和浮点型数据介绍

    大家好,本篇文章主要讲的是C语言中字符型数据和浮点型数据介绍,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览
    2022-01-01
  • 浅谈c++ stl迭代器失效的问题

    浅谈c++ stl迭代器失效的问题

    下面小编就为大家带来一篇浅谈c++ stl迭代器失效的问题。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧,祝大家游戏愉快哦
    2016-12-12
  • 详解C语言数组灵活多变的访问形式

    详解C语言数组灵活多变的访问形式

    这篇文章主要介绍了详解C语言数组灵活多变的访问形式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-01-01
  • C++实现简易选课系统代码分享

    C++实现简易选课系统代码分享

    这篇文章主要介绍了C++实现简易选课系统及实现代码的分享,具有一定的参考价值,需要的小伙伴可以参考一下,希望对你有所帮助
    2022-01-01
  • C语言 常量详解及示例代码

    C语言 常量详解及示例代码

    本文主要讲解C语言 常量,这里整理了 C语言常量的基础知识,并附代码示例和示例详细讲解,希望能帮助开始学习C 语言的同学
    2016-08-08
  • 简单谈谈C++ 中指针与引用

    简单谈谈C++ 中指针与引用

    下面用通俗易懂的话来概述一下,指针-对于一个类型T,T*就是指向T的指针类型,也即一个T*类型的变量能够保存一个T对象的地址,而类型T是可以加一些限定词的,引用-引用是一个对象的别名,主要用于函数参数和返回值类型,符号X&表示X类型的引用。
    2015-09-09
  • 基于OpenCv的运动物体检测算法

    基于OpenCv的运动物体检测算法

    这篇文章主要为大家详细介绍了基于OpenCv的运动物体检测算法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • C++实现基于不相交集合的O(mlgn)复杂度的kruskal算法

    C++实现基于不相交集合的O(mlgn)复杂度的kruskal算法

    这篇文章主要为大家详细介绍了C++如何实现基于不相交集合的O(mlgn)复杂度的kruskal算法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下
    2023-02-02

最新评论