c#散列和php MD5文件/文件夹散列不一样
我必须在客户端(C#)和服务器(PHP)文件结构上对文件/文件夹进行MD5哈希。(服务器端是PHP,客户端是c。)问题是它们工作时不匹配。任何想法都将不胜感激 这是我的两个算法 C# PHP 编辑。c#散列和php MD5文件/文件夹散列不一样,c#,php,md5sum,C#,Php,Md5sum,我必须在客户端(C#)和服务器(PHP)文件结构上对文件/文件夹进行MD5哈希。(服务器端是PHP,客户端是c。)问题是它们工作时不匹配。任何想法都将不胜感激 这是我的两个算法 C# PHP 编辑。 我已经决定,c#必须改变PHP现在就可以了。第一个100%有效的代码获得赏金您的PHP代码正在汇编十六进制数(根据md5_文件()文档) 您的C#代码正在汇编非0填充的十进制数。 您需要y.ToString(“x2”)才能将格式设置为十六进制 另外,返回sb.ToString().GetHashCo
我已经决定,c#必须改变PHP现在就可以了。第一个100%有效的代码获得赏金您的PHP代码正在汇编十六进制数(根据
md5_文件()
文档)
您的C#代码正在汇编非0填充的十进制数。您需要
y.ToString(“x2”)
才能将格式设置为十六进制
另外,
返回sb.ToString().GetHashCode().ToString()代码>是非常错误的。不要调用GetHashCode()
;这不是你想要的。我最终自己解决了这个问题,我为未来的后代提供了答案-这个解决方案的关键是指定linux和windows使用的不同默认目录顺序。这仅在linux服务器(Cent OS6.3)和Windows 7客户端上进行了测试
C#
这两个函数将遍历C#Windows和或PHP linux文件夹,并返回Linuxland和Windowsland中所有目录(递归,因此它包括子目录)的相同哈希值。我将这些建议添加到C#(我同意,C#是错误的)-但是现在它没有返回任何东西好的,只是为了确认这个答案可能部分在正确的轨道上,非常感谢它,但是,老实说,它无论如何都不起作用
using System;
using System.IO;
using System.Security.Cryptography;
using System.Text;
namespace nofolder
{
public class classHasher
{
/**********
* recursive folder MD5 hash of a dir
*/
MD5 hashAlgo = null;
StringBuilder sb;
public classHasher()
{
hashAlgo = new MD5CryptoServiceProvider();
}
public string getHash(String path)
{
// get the file attributes for file or directory
if (File.Exists(path)) return getHashOverFile(path);
if (Directory.Exists(path)) return getHashOverFolder(path);
return "";
}
public string getHashOverFolder(String path)
{
sb = new StringBuilder();
getFolderContents(path);
return sb.ToString().GetHashCode().ToString();
}
public string getHashOverFile(String filename)
{
sb = new StringBuilder();
getFileHash(filename);
return sb.ToString().GetHashCode().ToString();
}
private void getFolderContents(string fold)
{
foreach (var d in Directory.GetDirectories(fold))
{
getFolderContents(d);
}
foreach (var f in Directory.GetFiles(fold))
{
getFileHash(f);
}
}
private void getFileHash(String f)
{
using (FileStream file = new FileStream(f, FileMode.Open, FileAccess.Read))
{
byte[] retVal = hashAlgo.ComputeHash(file);
file.Close();
foreach (var y in retVal)
{
sb.Append(y.ToString());
}
}
}
}
}
function include__md5_dir($dir){
/**********
* recursive folder MD5 hash of a dir
*/
if (!is_dir($dir)){
return md5_file($dir);
}
$filemd5s = array();
$d = dir($dir);
while (false !== ($entry = $d->read())){
if ($entry != '.' && $entry != '..'){
if (is_dir($dir.'/'.$entry)){
$filemd5s[] = include__md5_dir($dir.'/'.$entry);
}
else{
$filemd5s[] = md5_file($dir.'/'.$entry);
}
}
}
$d->close();
return md5(implode('', $filemd5s));
}
public class classHasher
{
/**********
* recursive folder MD5 hash of a dir
*/
MD5 hashAlgo = null;
StringBuilder sb;
public classHasher()
{
hashAlgo = new MD5CryptoServiceProvider();
}
public string UltraHasher(String path)
{
/**********
* recursive folder MD5 hash of a dir
*/
if (!Directory.Exists(path))
{
return getHashOverFile(path);
}
List<string> filemd5s = new List<string>();
List<string> dir = new List<string>();
if (Directory.GetDirectories(path) != null) foreach (var d in Directory.GetDirectories(path))
{
dir.Add(d);
}
if (Directory.GetFiles(path) != null) foreach (var f in Directory.GetFiles(path))
{
dir.Add(f);
}
dir.Sort();
foreach (string entry in dir)
{
if (Directory.Exists(entry))
{
string rtn = UltraHasher(entry.ToString());
//Debug.WriteLine(" ULTRRAAHASHER:! " + entry.ToString() + ":" + rtn);
filemd5s.Add(rtn);
}
if (File.Exists(entry))
{
string rtn = getHashOverFile(entry.ToString());
//Debug.WriteLine(" FILEEEEHASHER:! " + entry.ToString() + ":" + rtn);
filemd5s.Add(rtn);
}
}
//Debug.WriteLine(" ULTRRAASUMMMM:! " + String.Join("", filemd5s.ToArray()));
string tosend = CalculateMD5Hash(String.Join("", filemd5s.ToArray()));
//Debug.WriteLine(" YEAHHAHHAHHAH:! " + tosend);
return tosend;
}
public string getHashOverFile(String filename)
{
sb = new StringBuilder();
getFileHash(filename);
return sb.ToString();
}
private void getFileHash(String f)
{
using (FileStream file = new FileStream(f, FileMode.Open, FileAccess.Read))
{
byte[] retVal = hashAlgo.ComputeHash(file);
file.Close();
foreach (var y in retVal)
{
sb.Append(y.ToString("x2"));
}
}
}
public string CalculateMD5Hash(string input)
{
byte[] inputBytes = System.Text.Encoding.ASCII.GetBytes(input);
byte[] hash = hashAlgo.ComputeHash(inputBytes);
StringBuilder sz = new StringBuilder();
for (int i = 0; i < hash.Length; i++)
{
sz.Append(hash[i].ToString("x2"));
}
return sz.ToString();
}
}
function md5_dir($dir){
/**********
* recursive folder MD5 hash of a dir
*/
if (!is_dir($dir)){
return md5_file($dir);
}
$filemd5s = array();
$bit = array();
$d = scandir($dir);
foreach($d as $entry){
if ($entry != '.' && $entry != '..'){
$bit[] = $entry;
}
}
asort($bit);
foreach($bit as $entry){
if (is_dir($dir.'/'.$entry)){
$sz = md5_dir($dir.'/'.$entry);
//echo "\n ULTRRAAHASHER:! ".$dir.'/'.$entry.":$sz";
$filemd5s[] = $sz;
}
else{
$sz = md5_file($dir.'/'.$entry);
$filemd5s[] = $sz;
//echo "\n FILEEEEHASHER:! ".$dir.'/'.$entry.":$sz";
}
}
//echo "\n ULTRRAASUMMMM:! ".implode('', $filemd5s)."";
//echo "\n YEAHHAHHAHHAH:! ".md5(implode('', $filemd5s))."";
return md5(implode('', $filemd5s));
}