• 加密解密复制文件


    #include "stdafx.h"
    #include <Windows.h>
    #include <io.h>

    #define BUF_SIZE 256

    BOOL cci_f(LPCTSTR,LPCTSTR,DWORD);
    int _tmain (int argc, LPTSTR argv [])
    {
        if(argc != 4)
                {printf("cci shift file1 file2"); return 1;}
        if(!cci_f(argv[2],argv[3],_wtoi(argv[1])))
                {printf("false"); return 2;}
        return 0;
    }

    BOOL cci_f(LPCTSTR fIn,LPCTSTR fOut,DWORD shift){
        HANDLE hIn,hOut;
        DWORD nIn,nOut,iCopy;
        CHAR aBuffer[BUF_SIZE],ccBuffer[BUF_SIZE];
        BOOL writeOK=TRUE;

        hIn=CreateFile(fIn,GENERIC_READ,0,NULL,OPEN_EXISTING,
            FILE_ATTRIBUTE_NORMAL,NULL);
        if(hIn==INVALID_HANDLE_VALUE){
            return FALSE;
        }
        hOut=CreateFile(fOut,GENERIC_WRITE,0,NULL,CREATE_ALWAYS,
            FILE_ATTRIBUTE_NORMAL,NULL);
        if(hOut==INVALID_HANDLE_VALUE) return FALSE;

        while(ReadFile(hIn,aBuffer,BUF_SIZE,&nIn,NULL)&&
            nIn>0 && writeOK){
            for(iCopy=0;iCopy<nIn;iCopy++)
                ccBuffer[iCopy]=(aBuffer[iCopy]+shift) % 256;
            //printf("%d",nIn);
            writeOK=WriteFile(hOut,ccBuffer,nIn,&nOut,NULL);
        }
        CloseHandle(hIn);
        CloseHandle(hOut);
        return writeOK;
    }

    效果如下:

  • 相关阅读:
    内存分析利器purify简介
    ldd 的一个安全问题
    Purify检测的代码错误类型
    Purify命令大全
    用GDB调试程序(三)
    寒假Day5:蓝桥杯模拟赛
    寒假Day1:莫队算法+暴力分块
    HDU4578Transformation线段树的加、乘、变、次方操作
    二叉树的相关知识点
    CodeForces 841BGodsend思维
  • 原文地址:https://www.cnblogs.com/duyy/p/3600573.html
Copyright © 2020-2023  润新知