微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

ASP.NET - 下载文件时的路径遍历漏洞

如何解决ASP.NET - 下载文件时的路径遍历漏洞

我怎样才能在那个代码解决这个问题。我尝试了一些方法,但我无法通过 checkmarx 测试(用于执行扫描的系统)

FinalUploadFolder 来自 WebConfig 文件,这是文件的保存位置

public FileResult Index(string attachedFile)
   {
       string rootPath = System.Configuration.ConfigurationManager.AppSettings.Get("FinalUploadFolder");
       byte[] file= System.IO.File.ReadAllBytes(string.Format(Path.Combine(rootPath,attachedFile.ToString())));
       return File(file,System.Net.Mime.MediaTypeNames.Application.Octet,attachedFile.ToString());         
   }

解决方法

验证和清理输入是安全编码的最佳实践。 Checkmarx 会寻找很多“消毒剂”,Path.GetFilename 就是其中之一。

另外,我认为Checkmarx更可能关注的是attachedFile,恶意输入可能会传入参数中。因此,请尝试使用以下内容更改您的代码:

public FileResult Index(string attachedFile)
   {
       attachedFile = Path.GetFileName(attachedFile);
       string rootPath = System.Configuration.ConfigurationManager.AppSettings.Get("FinalUploadFolder");
       byte[] file= System.IO.File.ReadAllBytes(string.Format(Path.Combine(rootPath,attachedFile.ToString())));
       return File(file,System.Net.Mime.MediaTypeNames.Application.Octet,attachedFile.ToString());         
   }
 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。