1

我正在尝试将从文件的每一行获取的加密字符串与 AAAA-ZZZZ 进行比较,直到找到与密码匹配的字符串。我保证用户密码为 4 个字符。我想要做的是使用 LowLevel IO 获取文件并使用每行的解密密码输出到一个新文件。我还不是最擅长 C 编程的,所以请保持温和。我需要指导如何创建从 AAAA 一直到 ZZZZ 的数组或列表,然后将每个数组或列表与文件行的解密版本进行比较。

  1. 如何逐行解密文件并将其保存到char []
  2. 如何将每一行与另一个 char [] 进行比较,直到找到密码

例如:

如果该行是 $1$6gMKIopE$I.zkP2EvrXHDmApzYoV.B。下一行是 $1$pkMKIcvE$WQfqzTNmcQr7fqsNq7K2p0。假设解密后得到的密码是 ABSZ 和 TAZE,新文件将在第一行得到 ABSZ,在第二行得到 TAZE。

这是我到目前为止所拥有的:

#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>

void pdie(const char *);
void die(const char *);

#define BUFFER_SIZE 1024 

int main(void)
{
   char *pass;
   int rfd;   
   int wfd;   
   char buffer[BUFFER_SIZE];   
   char *bp;   
   int bufferChars;   
   int writtenChars;  

   if ((rfd = open("pass.txt", O_RDONLY, 0)) < 0)
      pdie("Open failed");

   if ((wfd = open("passout.txt", O_WRONLY | O_CREAT | O_TRUNC,
                   S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH)) < 0)
      pdie("Open failed");

   while (1)
   {   
      if ((bufferChars = read(rfd, buffer, BUFFER_SIZE)) > 0)
      {
         printf("%s", buffer);

         bp = buffer; 
         pass = crypt(getpass(all(4,4,'a','z')), *bp);  

         printf(pass);
         while (bufferChars > 0)
         {
            if ((writtenChars = write(wfd, bp, bufferChars)) < 0)
               pdie("Write failed");

            bufferChars -= writtenChars;
            bp += writtenChars;
         }
      }
      else if (bufferChars == 0)  
         break;
      else   
         pdie("Read failed");
   }
   close(rfd);
   close(wfd);

   return 0;
}


void pdie(const char *mesg) {

   perror(mesg);
   exit(1);
}

void die(const char *mesg) {

   fputs(mesg, stderr);
   fputc('\n', stderr);
   exit(1);
}

int inc(char *c,char begin, char end){
    if(c[0]==0) return 0;
    if(c[0] == end){   // This make the algorithm to stop at char 'f'
        c[0]=begin;     // but you can put any other char            
        return inc(c+sizeof(char), begin, end);
    }   
    c[0]++;
    return 1;
}

int all(int a, int n,char begin, char end){
    int i,j;
    char *c = malloc((n+1)*sizeof(char));
    for(i=a;i<=n;i++){
        for(j=0;j<i;j++) c[j]=begin;
        c[i]=0;
        do {
            printf("%s\n",c);
        } while(inc(c,begin,end));
    }
    free(c);
}

这是文件:

$1$6gMKIopE$I.zkP2EvrXHDmApzYoV.B.
$1$pkMKIcvE$WQfqzTNmcQr7fqsNq7K2p0
$1$0lMKIuvE$7mOnlu6RZ/cUFRBidK7PK.
4

0 回答 0