如何在Greasemonkey中处理__doPostBack()?

时间:2012-06-12 19:16:31

标签: javascript asp.net function greasemonkey dopostback

该功能处理了一系列链接,其中包含我需要的内容,并且我尝试使用Greasemonkey将内容保存在这些链接中。

以下是我尝试的内容:

var content;
var viewstate;
var crystalstate;

$(document).ready(function() {

viewstate = $("#__VIEWSTATE").val();
crystalstate = $("#__CRYSTALSTATEctl00$main$CrystalReportViewer1").val();

$.post("CautarePolite.aspx", { 
__EVENTTARGET: 'ctl00$main$gvPolite$ctl02$lbDetaliiPolita', 
__EVENTARGUMENT: '', 
__CRYSTALSTATEctl00$main$CrystalReportViewer1: crystalstate,
__VIEWSTATE: viewstate
}, 
function( data ) {
      content = data;
  } );

alert('');

$.post("script_url.php", { data: content } );

});

这给了我一个页面,其中包含以下错误消息:

" viewstate MAC验证失败。如果此应用程序由Web场或群集托管,请确保配置指定相同的validationKey和验证算法。 AutoGenerate不能在群集中使用。"

以下是页面上可能感兴趣的一些代码:

<form method="post" action="CautarePolite.aspx" id="aspnetForm" class="wrap">
<div class="aspNetHidden">
<input type="hidden" name="__EVENTTARGET" id="__EVENTTARGET" value="" />
<input type="hidden" name="__EVENTARGUMENT" id="__EVENTARGUMENT" value="" />
<input type="hidden" name="__CRYSTALSTATEctl00$main$CrystalReportViewer1" id="long value*" />
<input type="hidden" name="__VIEWSTATE" id="__VIEWSTATE" value="*very long value*" />
</div>

<script type="text/javascript">
//<![CDATA[
var theForm = document.forms['aspnetForm'];
if (!theForm) {
    theForm = document.aspnetForm;
}
function __doPostBack(eventTarget, eventArgument) {
    if (!theForm.onsubmit || (theForm.onsubmit() != false)) {
        theForm.__EVENTTARGET.value = eventTarget;
        theForm.__EVENTARGUMENT.value = eventArgument;
        theForm.submit();
    }
}
//]]>
</script>

1 个答案:

答案 0 :(得分:0)

缺少__VIEWSTATEENCRYPTED

输入字段在源代码中进一步下降,但这解决了它。我得到了我需要的东西。