【发布时间】:2017-06-09 15:38:50
【问题描述】:
在我的网站上实现 CSP 标头时,我遇到了 webforms 添加到页面的自动生成的回发 JavaScript 的问题:
<script type="text/javascript">
//<![CDATA[
var theForm = document.forms['form1'];
if (!theForm) {
theForm = document.form1;
}
function __doPostBack(eventTarget, eventArgument) {
if (!theForm.onsubmit || (theForm.onsubmit() != false)) {
theForm.__EVENTTARGET.value = eventTarget;
theForm.__EVENTARGUMENT.value = eventArgument;
theForm.submit();
}
}
//]]>
</script>
为了支持其他一些内联脚本标签,我已经成功添加了nonce 属性;但是我找不到任何方法来修改这段生成的代码来做同样的事情。我已经探索了ClientScript.GetPostBackEventReference,但这似乎控制了其中的 JavaScript,与 <script> 标记本身的呈现无关。
解决方案不一定需要添加nonce 属性——只要符合要求即可。例如,如果有一个 ASP.NET 设置可以配置为将此脚本作为文件加载(我可以将其列入白名单),那很好。
【问题讨论】:
-
我遇到了同样的问题,你有没有找到解决方案或解决这个问题
-
@Standage 恐怕我没有。
标签: asp.net webforms content-security-policy