我有以下代码:
using (FileStream fs = new FileStream(path_to_xml, FileMode.Open))
{
using (XmlReader xr = XmlReader.Create(fs))
{
// Do something with xr
}
}
我收到警告
CA3075:不接受 XmlReaderSettings 参数的 XmlReader.Create 的不安全重载
如果我更改 Create 语句并添加一个 XmlReaderSettings,如下所示:
using (XmlReader xr = XmlReader.Create(fs, new XmlReaderSettings()))
我收到警告
CA3075:向 XmlReader.Create 方法提供了可能不安全的 XmlReaderSettings 实例。
这个警告的真正原因是什么?让它消失的正确方法是什么?
我正在使用 VS 2019 预览版 1.0
我以前从未见过这个警告,所以也许它是 VS 2019 的新警告?
更新:我已经看过这个页面https://docs.microsoft.com/en-us/visualstudio/code-quality/ca3075-insecure-dtd-processing?view=vs-2017并且大多数解决方案都说要设置'XmlReaderSettings(){ DtdProcessing = DtdProcessing.Prohibit }' 我仍然收到警告。