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;
}

效果:

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

(0)

相关推荐

  • 基于C语言实现的aes256加密算法示例

    本文实例讲述了基于C语言实现的aes256加密算法.分享给大家供大家参考,具体如下: aes256.h: #ifndef uint8_t #define uint8_t unsigned char #endif #ifdef __cplusplus extern "C" { #endif typedef struct { uint8_t key[32]; uint8_t enckey[32]; uint8_t deckey[32]; } aes256_context; void aes

  • C语言使用openSSL库AES模块实现加密功能详解

    本文实例讲述了C语言使用openSSL库AES模块实现加密功能.分享给大家供大家参考,具体如下: 概述 在密码学里面一共有3中分类: 1.对称加密/解密 对称加密比较常见的有DES/AES.加密方和解密方都持有相同的密钥.对称的意思就是加密和解密都是用相同的密钥. 2.非对称加密/解密 常见的加密算法DSA/RSA.如果做过Google Pay的话,应该不会陌生.非对称意味着加密和解密使用的密钥不是相同的.这种应用的场合是需要保持发起方的权威性,比如Google中一次支付行为,只能Google通

  • C语言使用openSSL库DES模块实现加密功能详解

    本文实例讲述了C语言使用openSSL库DES模块实现加密功能.分享给大家供大家参考,具体如下: 在通讯过程中为了防止普通的玩家截取协议修改内容并且发送,我们是有必要对协议进行加密的.当前这样的加密手段都已经是变成世界里面的基础设施了.我们只需要将其引入到工程中就好.本文将会基于OpenSSL来编写一个加密.解密的实例.时下流行的加密解密方式有DES/AES.先我们来聊聊历史吧. 历史介绍 DES(Data Encryption Standard) DES一度是电子数据对称加密的主导者.他影响了

  • 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(disabl

  • Java实现文件的加密解密功能示例

    本文实例讲述了Java实现文件的加密解密功能分享给大家供大家参考,具体如下: package com.copy.encrypt; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; impor

  • C语言实现加密解密功能

    加密主要是通过一种算法对原内容进行处理,使原来内容不直观可见.解密过程通常要知道加密的算法,然后对加密后的内容进行逆处理,从而实现解密功能.当然解密也有一些暴力破解的方法.接下来以 c 语言 为例讲解一种简单的加密解密以及暴力破解字符串的方法,带您走进加密解密技术的大门. 先讲一下凯撒加密,凯撒密码相传是古罗马凯撒大帝用来保护重要军情的加密系统.它是一种置换密码,通过将字母顺序推后起到加密作用.如字母顺序推后 3 位,字母 A 将被推作字母 D,字母 B 将被推作字母 E.本实例类似于凯撒加密.

  • Java探索之Thread+IO文件的加密解密代码实例

    这篇文章向大家分享了几段代码,主要是关于Thread+IO文件的加密解密,下面看看具体代码: 加密启动线程 package com.hz.subsection; import java.io.File; public class enCodeFileThread extends Thread { public Files files; public File file; public File dst; public enCodeFileThread(String name,Files file

  • C#实现对文件进行加密解密的方法

    本文实例讲述了C#实现对文件进行加密解密的方法.分享给大家供大家参考.具体如下: using System; using System.IO; using System.Security.Cryptography; public class Example19_9 { public static void Main() { // Create a new file to work with FileStream fsOut = File.Create(@"c:\temp\encrypted.tx

  • java使用异或对文件进行加密解密

    本文实例为大家分享了java使用异或对文件进行加密解密的具体代码,供大家参考,具体内容如下 1.使用异或的方式加密文件的原理 一个数异或另一个数两次,结果一定是其本身 2.使用异或的原理加密文件 /** * 将文件内容加密 * 使用异或的方式将a.txt加密复制出一个b.txt,放到同一个文件夹下 */ @Test public void encryptFile(){ FileInputStream in = null; FileOutputStream out = null; try { St

  • python实现对服务器脚本敏感信息的加密解密功能

    背景 在实际项目实施中,会编写很多在服务器执行的作业脚本.程序中凡是涉及到数据库链接.操作系统用户链接.IP地址.主机名称的内容都是敏感信息.在纯内网系统中往因为开发时间紧迫,往往都直接将这些敏感信息明文方式写在脚本中了. 稍微规范一点的,创建一个通用的config文件,将所有这类敏感信息记录在这个文件中,脚本以读取文件方式获取这些信息.这种方式的好处是脚本不用在应用迁移.灾备部署的时候再起不同的版本,尤其是大数据平台作业运行的脚本,如果是需要做灾备集群,这种方式可以减少生产变更时的人工干预操作

  • JavaScript实现的前端AES加密解密功能【基于CryptoJS】

    本文实例讲述了JavaScript实现的前端AES加密解密功能.分享给大家供大家参考,具体如下: js前端AES加密 最近由于项目需求做了一次MITM,突然即使发现使用HTTPS,也不能保证数据传输过程中的安全性. 通过中间人攻击,可以直接获取到Http协议的所有内容. 于是开始尝试做一些简单的加密,在一定程度上保证安全性. 本次采用AES加密数据,所以客户端和服务端使用的相同秘钥.(仅作为演示,正式环境推荐使用RSA) 首先准备一份明文密码和加密使用的KEY var source = "ABC

  • Spring Cloud微服务架构的构建:分布式配置中心(加密解密功能)

    前言 要会用,首先要了解.图懒得画,借鉴网上大牛的图吧,springcloud组建架构如图: 微服务架构的应用场景: 1.系统拆分,多个子系统 2.每个子系统可部署多个应用,应用之间负载均衡实现 3.需要一个服务注册中心,所有的服务都在注册中心注册,负载均衡也是通过在注册中心注册的服务来使用一定策略来实现. 4.所有的客户端都通过同一个网关地址访问后台的服务,通过路由配置,网关来判断一个URL请求由哪个服务处理.请求转发到服务上的时候也使用负载均衡. 5.服务之间有时候也需要相互访问.例如有一个

  • php实现的三个常用加密解密功能函数示例

    本文实例讲述了php实现的三个常用加密解密功能函数.分享给大家供大家参考,具体如下: 算法一: //加密函数 function lock_url($txt,$key='www.jb51.net') { $chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-=+"; $nh = rand(0,64); $ch = $chars[$nh]; $mdKey = md5($key.$ch); $mdKe

随机推荐