3

Java で htmlunit を使用して Web ページのボタンを自動的にクリックするアプリケーションに取り組んでいます。唯一の問題は、そのボタンが JavaScript ボタンであるため、標準の getInputByName() が機能しないことです。これに対処するための提案はありますか?ボタンのコードは以下に含まれています。

<a class="vote_1" id="1537385" href="/javascript%3Avoid%280%29/index"><img src="/images/parts/btn-vote.gif" alt="Btn-vote" /></a> 

さらに、投票用の別のコードを次に示します。

<div id="content"><script type="text/javascript" src="/js/scriptFeeds/voteArticle.js"></script> 

これは、次の JavaScript につながります。

var pressed = new Array();

$j(document).ready(function() {
var nr = $j("input#number_of_articles").val();
for(var i=1; i<=nr; i++){
    $j("a.vote_"+i).click(function(){
        var article   = $j(this).attr("id");
        $j('#'+article).hide();
        if (!pressed[article]) {
            pressed[article] = "yes";
            jQuery.post('/vote-article', {
                _token: $j("#_token").val(),
                article_id: article
            },function(data) {
                $j("span.numberOfVotes_"+data.id).html(data.votes);
            }, "json");
        }
        return false;
    });
}
});
4

3 に答える 3

12

このアドオンをFirefoxに使用してみてください。アクションが記録され、同じHTMLUnitコードが生成されます。それが役立つかもしれません。 http://code.google.com/p/htmlunitscripter/

于 2010-10-11T09:22:41.223 に答える
9

クリック可能な画像について特別なことは何もありません。このようなものが動作するはずです:

button = page.getHtmlElementById( "1537385" ) ;
page = button.click() ;

HtmlUnit は Javascript を実行し、更新されたページを返します。

「a」タグの id 属性が一定でない場合は、XPath を使用して取得する必要がある場合があります。

于 2010-10-12T20:15:33.610 に答える
5

私のページの1つに非常によく似たリンクがあります。任意のHtmlElementで.click()を呼び出すことができれば、関連するJavascriptを実行できるはずです。これが私のコードです(HtmlUnitScripterから生成されます):

HtmlElement element4 = null;
Iterable<HtmlElement> iterable5 = page.getAllHtmlChildElements();
Iterator<HtmlElement> i6 = iterable5.iterator();
while(i6.hasNext())
{
    HtmlElement anElement = i6.next();
    if(anElement instanceof HtmlImage)
    {
        HtmlImage input = (HtmlImage) anElement;
        String[] elements = "http://example.com/pages/powerbutton.png".split( "/" );

        if(input.getSrcAttribute().indexOf(elements[elements.length-1] )> -1 )
        {
            element4 = input;
            break;
        }
    }
}

HtmlPage page = element4.click();
于 2010-10-21T05:07:51.280 に答える