欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

详细介绍C#之文件校验工具的开发及问题

程序员文章站 2023-11-16 23:29:40
.加密算法的熟悉     目前校验文件使用最多的是md值和sha值,不外乎有些使用crc,前段时间微软发布了visualstudio正式版,...

.加密算法的熟悉
    目前校验文件使用最多的是md值和sha值,不外乎有些使用crc,前段时间微软发布了visualstudio正式版,win镜像,微软官方给出的校验方式都是校验文件的sha值。

       c#进行md加密与sha加密的实现总结在这里
.文件的加密计算
知道了如何进行普通字符串的加密还不够,我们要校验的文件的md值或sha值,接下来熟悉如何获取文件的md值和sha值
获取文件的md值 

public static string getfilemd(string filepath)
     {
       mdcryptoserviceprovider md = new mdcryptoserviceprovider();
       filestream fs = new filestream(filepath, filemode.open, fileaccess.read, fileshare.read);
       byte[] result = md.computehash(fs);
       md.clear();
       stringbuilder sb = new stringbuilder();
       for (int i = ; i < result.length; i++)
       {
         sb.append(result[i].tostring("x"));
       }
       return sb.tostring();
     }

 
获取文件的sha值
         

 public static string getfilesha(string filepath)
     {
       sha sha = new shacryptoserviceprovider();
       filestream fs = new filestream(filepath, filemode.open, fileaccess.read, fileshare.read);
       byte[] result = sha.computehash(fs);
       sha.clear();
       stringbuilder sb = new stringbuilder();
       for (int i = ; i < result.length; i++)
       {
         sb.append(result[i].tostring("x"));
       }
       return sb.tostring();
     }

.文件加密数据结构优化
这么多方法,有许多方法大多数代码还都是重复的,如何让代码更精简呢?重构,提高代码的复用率,最初想的是建一个基类,其他各种具体实现都在继承它,但又觉得好麻烦,要新建好几个类,最终决定,建一个类,用最简单的重构,封装方法。
最终加密帮助类实现代码如下:
public static class validhelper
   {
     public static string getfilehash(string filepath, hashalgorithm algorithm)
     {
       filestream fs = new filestream(filepath, filemode.open, fileaccess.read, fileshare.read);
       byte[] result = algorithm.computehash(fs);
       algorithm.clear();
       stringbuilder sb = new stringbuilder();
       for (int i = ; i < result.length; i++)
       {
         sb.append(result[i].tostring("x"));
       }
       return sb.tostring();
     }
 
     public static string getfilemd(string filepath)
     {
       mdcryptoserviceprovider md = new mdcryptoserviceprovider();
       return getfilehash(filepath, md);
     }
 
     public static string getfilesha(string filepath)
     {
       sha sha = new shacryptoserviceprovider();
       return getfilehash(filepath, sha);
     }
 
     public static string getfilesha(string filepath)
     {
       sha sha = sha.create();
       return getfilehash(filepath, sha);
     }
 
     public static string getfilesha(string filepath)
     {
       sha sha = sha.create();
       return getfilehash(filepath, sha);
     }
 
     public static string getfilesha(string filepath)
     {
       sha sha = sha.create();
       return getfilehash(filepath, sha);
     }
   }

.完成后测试与分析
代码完成之后便是测试,在网上找一个文件校验工具(使用的软媒魔方里的校验工具),进行比对,看自己的校验工具是否与软媒魔方的校验工具的校验结果是否一致,经校验,没有错误,最初测试的小文件,后来下载了一个win系统,使用自己的校验工具,校验是否和微软官方给出的sha值一致时,小工具直接卡死了,过了好长时间才出来结果,这说明这个小工具还待优化,尤其是处理大文件。
在网上查找资料,看到有这样的实现思路,将文件在内存中的位置分段,比如说分成段,分个线程同时开始计算,最后将个计算值再经过处理得到整个文件的sha值或md值。然而愚钝,不知道该如何实现,望大神看到之后能给予一些指导,万分感谢。

以上介绍就是本文的全部内容,希望大家喜欢。