繁体   English   中英

Python / 请求:登录网站 Javascript

[英]Python / Requests: Log In to Website Javascript

我正在尝试创建一个脚本来登录网站,但我很难让它在这个特定页面上工作。 仅供参考,我对使用 python 请求很陌生。 我可以在 selenium 中执行该功能,我可以使用其他网站上的请求登录,但我相信这个网站使用的是 javascript,这很可能是我的问题。

代码:

while (FoundItem == "Nope"):


    SignIn = "https://www.bestbuy.ca/profile/signin.aspx"


    Email = "ctl00$CP$SignInUC1$UserNameContainer$txtUserName"
    Password= "ctl00$CP$SignInUC1$PasswordContainer$txtPassword"

    payload = {
    'ctl00$CP$SignInUC1$UserNameContainer$txtUserName': 'MYEMAIL',
    'ctl00$CP$SignInUC1$PasswordContainer$txtPassword': 'MYPASSWORD'
}

    with requests.Session() as s:
        p = s.post(SignIn, data=payload)

        print(p.content)

来自站点登录表单的 HTML:

<div class="chkout-fieldbox std-half-cln signinblock checkout-form" id="sign-in">
    <div class="std-half-cln-wrapper">

        <h2 class="module-title"><span id="ctl00_CP_SignInUC1_lblSinginHeader">Returning Customer?</span></h2>
        <p class="std-bottomspace">Please sign in to Your Account</p>




        <fieldset class="checkout-fieldset">
            <legend>Sign in for fast and easy checkout</legend>
            <ul class="clearfix">
                <li class="large">
                    <label for="ctl00_CP_SignInUC1_UserNameContainer_txtUserName">Email Address</label>


                    <span id="ctl00_CP_SignInUC1_UserNameContainer"><span id="ctl00_CP_SignInUC1_UserNameContainer_proxyValidator" style="color:Red;display:none;"></span><input name="ctl00$CP$SignInUC1$UserNameContainer$txtUserName" type="email" maxlength="80" id="ctl00_CP_SignInUC1_UserNameContainer_txtUserName" tabindex="1" class="txtbox" autocomplete="off" placeholder="example@example.com" onblur="if (this.onchange!=null)this.onchange();"><span id="ctl00_CP_SignInUC1_UserNameContainer_ctl00" style="display:none;">
                            <img id="ctl00_CP_SignInUC1_UserNameContainer_ctl00_imgUserName" src="https://images.bbycastatic.ca/sf/images/common/pictures/warningiconsmall.gif" alt=" ">
                        </span></span>            
                </li>
                <li class="large">
                    <label for="ctl00_CP_SignInUC1_PasswordContainer_txtPassword">Password</label>
                    <span id="ctl00_CP_SignInUC1_PasswordContainer"><span id="ctl00_CP_SignInUC1_PasswordContainer_proxyValidator" style="color:Red;display:none;"></span><input name="ctl00$CP$SignInUC1$PasswordContainer$txtPassword" type="password" id="ctl00_CP_SignInUC1_PasswordContainer_txtPassword" tabindex="2" class="txtbox" autocomplete="off" onblur="if (this.onchange!=null)this.onchange();"><span id="ctl00_CP_SignInUC1_PasswordContainer_ctl00" style="display:none;">
                            <img id="ctl00_CP_SignInUC1_PasswordContainer_ctl00_imgPassword" src="https://images.bbycastatic.ca/sf/images/common/pictures/warningiconsmall.gif" alt=" ">
                        </span></span>
                    <span class="subtext-wrapper">
                        <p class="subtext-notification">
                            <a id="ctl00_CP_SignInUC1_lnkForgotPassword" href="javascript:__doPostBack('ctl00$CP$SignInUC1$lnkForgotPassword','')">I forgot my password</a> 
                        </p>


                    </span>
                </li>
            </ul>              
            <div id="CaptchaContainer" class="clearfix btm-margin2x">



            </div>


         </fieldset>
        <a id="ctl00_CP_SignInUC1_BtnLoginButton" tabindex="4" type="submit" class="button-left btn-primary btn btn-lock" href='javascript:WebForm_DoPostBackWithOptions(new WebForm_PostBackOptions("ctl00$CP$SignInUC1$BtnLoginButton", "", true, "signin", "", false, true))'>Sign In</a>
    </div> 
</div>

我没有给你一个完整的答案,但也许我可以帮助指导。


首先,你是对的,正在调用 javascript。 在您发布的 html 中,登录按钮是ctl00_CP_SignInUC1_BtnLoginButton并且它的 href 属性中隐藏了一些 javascript:

href='javascript:WebForm_DoPostBackWithOptions(new WebForm_PostBackOptions("ctl00$CP$SignInUC1$BtnLoginButton", "", true, "signin", "", false, true))

单击该按钮时,您的浏览器会向服务器发送 发,其中包含登录页面的状态。

不幸的是,我以前从未处理过回发。 但似乎确实有一些关于该主题的帖子。 这是一个看起来很有用的。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM