1

我正在搜索或使用两个 POST 参数打开 URL 的方法。我现在唯一的选择是编写一个小 exe,它在 WebBrowser 控件中创建一个表单,然后自动单击一个按钮,这太可怕了。有没有更好的方法可以做到这一点?

4

3 回答 3

2

您可以使用以下 javascript 创建一个 HTML 文件:

<script type="text/javascript">
<!-- The function below does a post without requiring a form or the click of a button -->
function postwith (to,p) {
    var myForm = document.createElement("form");
    myForm.method="post" ;
    myForm.action = to ;
    for (var k in p) {
        var myInput = document.createElement("input") ;
        myInput.setAttribute("name", k) ;
        myInput.setAttribute("value", p[k]);
        myForm.appendChild(myInput) ;
    }
    document.body.appendChild(myForm) ;
    myForm.submit() ;
    document.body.removeChild(myForm) ;
}
</script>

示例用法:

    <script type="text/javascript">
    function delconfirm(id){
        if(confirm('Are you sure?'))
        {
            postwith('http://somesite.com/webpagetorecievepost.php',{KEY:VALUE,KEY:'STRING VALUE'});
        }
    }
   </script>

您可以拥有任意数量的KEY:VALUE对。

一旦你有了这个 html 文件,你就可以在 Internet Explorer 中修改和打开它。

于 2012-07-26T13:58:30.803 回答
0

有可以驱动 IE 的网络浏览器自动化工具,例如Selenium。Selenium 是可编写脚本的,并且具有主要浏览器的驱动程序。我只将 selenium 用于这种由 java 代码驱动的事情;有替代品

还有一些 Windows GUI 自动化工具,例如AutoIT,可以打开给定的程序并操作 GUI 元素。

于 2012-07-26T13:38:09.043 回答
0

我得到了这个工作,所以你可以打开一个带有查询字符串的标准 .html 文件,以将参数转发到 URL。

function postFromQueryString(url) {
    // grab params from query string into KVP array
    var postParams = [], hash;
    var hashes = window.location.href.slice(window.location.href.indexOf('?') + 1).split('&');
    for(var i = 0; i < hashes.length; i++) {
        hash = hashes[i].split('=');
        postParams.push(hash[0]);
        postParams[hash[0]] = hash[1];
    }
    if(postParams.length === 0) {
        alert('No parameter was passed');
        window.close();
        return;
    }
    // create a form
    var formToPost = document.createElement("form");
    formToPost.method="post";
    formToPost.action = url;
    // add params to form
    for (var k in postParams) {
        var postInput = document.createElement("input");
        postInput.setAttribute("name", k);
        postInput.setAttribute("value", postParams[k]);
        formToPost.appendChild(postInput);
    }
    document.body.appendChild(formToPost);
    formToPost.submit();
    document.body.removeChild(formToPost);
}

将其称为 onLoad:

(function () {
    // build dynamic form and post
    postFromQueryString('http://yourUrlToPostTo.aspx');
})();
于 2012-07-27T11:12:00.550 回答