是否应该对服务堆栈元数据页面上的链接进行编码



我们使用的扫描程序工具报告了安全问题。它监测了ServiceStack.Metadata.IndexOperationsControl.Render()GET /metadata的响应,并在未经验证或编码的情况下报告了响应。具体来说,抱怨网址。这是它关注的代码片段:

<h3>Plugin Links:</h3><ul><li><a href="https://mysitedomain/swagger-ui/">Swagger UI</a></li></ul> </div> <p>&nbsp;</p>

我可能概括得太多了。看起来问题是,最终,ServiceStack调用System.Web.UI.HtmlTextWriter.Write()而不是System.Web.UI.HtmlTextWriter.WriteEncodedText()这里的插件链接

            var pluginLinks = metadata != null && metadata.PluginLinks.Count > 0
            ? new ListTemplate
            {
                Title = metadata.PluginLinksTitle,
                ListItemsMap = ToAbsoluteUrls(metadata.PluginLinks),
                ListItemTemplate = @"<li><a href=""{0}"">{1}</a></li>"
            }.ToString()
            : "";

URL 应该在这里编码吗?

没有安全问题,元数据页面上的链接由编译时静态已知的插件定义,即它们从不嵌入未知的用户定义链接。

最新更新