1

我们一直致力于为上传到我们系统的文件实施病毒扫描程序 - 这是一个 C# Web 应用程序,我们在其中使用 nClam 插件与ClamAV 服务器对话。在一个非常基本的设置中(从 nClam 帮助中复制),它看起来像这样

     string filePath = "C:\\test\\jp TEST 昨夜のコンサート.txt";

        var clam = new ClamClient("localhost", 3310);
        var scanResult = clam.ScanFileOnServer(filePath);  //any file you would like!

        Console.WriteLine("Japan test");
        switch (scanResult.Result)
        {
            case ClamScanResults.Clean:
                Console.WriteLine("The file is clean!");
                break;
            case ClamScanResults.VirusDetected:
                Console.WriteLine("Virus Found!");
                Console.WriteLine("Virus name: {0}", scanResult.InfectedFiles.First().VirusName);
                break;
            case ClamScanResults.Error:
                Console.WriteLine("Woah an error occured! Error: {0}", scanResult.RawResult);
                break;
        }

现在当我尝试运行它时,我总是会从扫描中得到一个错误 - 文件本身只是一个包含一些随机字符的文本文件。我得到的错误是“没有这样的文件或目录。错误”

如果我运行 ClamAV 控制台命令来扫描文件夹中的文件,它似乎工作正常。我认为这是解码路径的问题,但我尝试了各种编码方案,但似乎不起作用。

在 nClam 方法中,有一些代码将文件路径解析为 ClamAV 服务器的命令

var commandText = String.Format("z{0}\0", command);
var commandBytes = Encoding.UTF8.GetBytes(commandText);

这会影响日语字符吗?

4

1 回答 1

0

我得到的解决方案是只替换文件名中的所有日文(和其他不支持的)字符,并在病毒扫描后使用真实的文件名,即

private string ReplaceUnsupportedCharacters(string fileName)
{
  const int MaxAnsiCode = 255;
  foreach (var illegalChar in fileName.Where(c => c > MaxAnsiCode))
  {
    fileName = fileName.Replace(illegalChar, '-');
  }
  return fileName;
}

我宁愿不必这样做,但现在我看不到更好的方法!

于 2017-04-21T08:50:33.980 回答