如何使用HttpWebRequest向JSF发送POST请求

时间:2015-10-16 23:12:36

标签: c# jsf

我发送身体login=login&login:loginName={0}&login:password={1}&login:clientCode=&login:j_idt171=&javax.faces.ViewState=stateless的帖子请求 帮助HttpWebRequest。在此之前,我正在执行GET请求,以获取JSESSIONID。 Web表单看起来像这样:

<form id="login" name="login" method="post" action="/csologin/login.jsf">
<input type="hidden" name="login" value="login">
<div id="login:j_idt122" class="ui-messages ui-widget" aria-live="polite"></div><table border="0" cellpadding="2" cellspacing="0" width="580px">
    <tbody>
        <tr>
            <td class="ecol1"><label id="login:j_idt125" class="ui-outputlabel ui-widget fbold" for="login:loginName">Username<span class="ui-outputlabel-rfi">*</span></label></td>
            <td class="ecol2"><input id="login:loginName" name="login:loginName" type="text" autocomplete="off" size="40" class="ui-inputfield ui-inputtext ui-widget ui-state-default ui-corner-all" role="textbox" aria-disabled="false" aria-readonly="false" aria-multiline="false"></td>
            <td class="ecol3"><div id="login:j_idt126" aria-live="polite" class="ui-message"></div></td>
        </tr>
    </tbody>
</table>
<table border="0" cellpadding="2" cellspacing="0" width="580px">
    <tbody>
        <tr>
            <td class="ecol1"><label id="login:j_idt132" class="ui-outputlabel ui-widget fbold" for="login:password">Password<span class="ui-outputlabel-rfi">*</span></label></td>
            <td class="ecol2"><input id="login:password" name="login:password" type="password" class="ui-inputfield ui-password ui-widget ui-state-default ui-corner-all ui-state-hover" autocomplete="off" size="40" role="textbox" aria-disabled="false" aria-readonly="false" aria-multiline="false"></td>
            <td class="ecol3"><div id="login:j_idt133" aria-live="polite" class="ui-message"></div></td>
        </tr>
    </tbody>
</table>
<table border="0" cellpadding="2" cellspacing="0" width="580px">
    <tbody>
        <tr>
            <td class="ecol1"><label id="login:j_idt135" class="ui-outputlabel ui-widget fbold" for="login:clientCode">Client Code</label></td>
            <td class="ecol2"><input id="login:clientCode" name="login:clientCode" type="text" maxlength="32" size="40" class="ui-inputfield ui-inputtext ui-widget ui-state-default ui-corner-all" role="textbox" aria-disabled="false" aria-readonly="false" aria-multiline="false"></td>
            <td class="ecol3"><div id="login:j_idt136" aria-live="polite" class="ui-message"></div></td>
        </tr>
    </tbody>
</table>
<br><div class="text-center">
    <button id="login:j_idt139" name="login:j_idt139" class="ui-button ui-widget ui-state-default ui-corner-all ui-button-text-only" onclick="barWaitDialog.show();" type="submit" role="button" aria-disabled="false"><span class="ui-button-text ui-c">Login</span></button>
    <!-- &lt;p:commandButton value="Clear" onclick="clearVisibleTextFields();" /&gt;  --><button id="login:j_idt141" name="login:j_idt141" class="ui-button ui-widget ui-state-default ui-corner-all ui-button-text-only" onclick="PrimeFaces.ab({source:'login:j_idt141',oncomplete:function(xhr,status,args){clearVisibleTextFields();;}});return false;" type="submit" role="button" aria-disabled="false"><span class="ui-button-text ui-c">Clear</span></button><button id="login:j_idt142" name="login:j_idt142" class="ui-button ui-widget ui-state-default ui-corner-all ui-button-text-only" type="submit" role="button" aria-disabled="false"><span class="ui-button-text ui-c">Cancel</span></button>
</div><input type="hidden" name="javax.faces.ViewState" id="javax.faces.ViewState" value="stateless" autocomplete="off">

未经过身份验证,它会返回重定向到登录页面。我做错了什么?

1 个答案:

答案 0 :(得分:2)

基本上,你没有按下所需的按钮。您需要添加name=value对提交按钮,然后按&#34;按&#34;编程。通常在服务器端用于区分是否按下按钮,如果是,则按哪一个。

HTML表单中似乎有三个提交按钮,简化如下:

<button name="login:j_idt139" type="submit">Login</button>
<button name="login:j_idt141" type="submit">Clear</button>
<button name="login:j_idt142" type="submit">Cancel</button>

似乎JSF开发人员没有为这些按钮提供显式ID,因此正在使用自动生成的ID。此自动生成的ID取决于JSF组件树中按钮组件的位置。因此,如果JSF开发人员更改视图组合(添加/移动/删除组件),那么HTML标记中按钮的最终ID也可能会更改。您需要更改您的查询字符串。查询字符串中的参数login:j_idt171=可能需要更改为login:j_idt139=

为了使其更加强大,您可以尝试联系网站管理员/开发人员,并要求为这些按钮提供<p:commandButton id="login">中的明确ID,以便您始终可以使用参数login:login=而无需担心关于自动生成的ID。如果这不是一个选项,那么您基本上需要使用HTML解析器来查找登录按钮的ID。