使用JQuery和javascript在Ajax调用后保存cookie

Saving down a cookie after an Ajax call using JQuery and javascript

本文关键字:调用 保存 cookie Ajax JQuery javascript 使用      更新时间:2023-09-26

使用相同的凭据,我试图从一个表单登录到两个不同的位置。原因是第二次登录(CRM门户)可以加载到iframe中,而无需再次登录。我认为最好的解决方案是使用Ajax调用来处理一次登录,然后在得到响应后,再处理第二次登录。我使用客户端进行两次调用,因为我需要将cookie保存到客户端的浏览器中。我使用Ajax进行调用。我知道cookie正在被返回(我使用一个名为Fiddler的应用程序来查看活动),但我不知道如何获取这些cookie并将其保存到客户端浏览器?

我使用的Javascript/JQuery:

<script type="text/javascript">
    $(document).ready(function() {
        $(".login_btn").click(function() {
            $.ajax({
                type: "POST",
                url: "http://development/crm/processlogin.php",
                data:"username="+ "email@email.email" + "&password="+ "password" + "&rememberme="+ "on",
                success: function(data, textStatus){
                    alert("success: "+ JSON.stringify(data));
                },
                error: function(data, textStatus){
                    alert("error: "+ JSON.stringify(data));
                }
            });
        });
    });
</script>

我得到的Cookie响应,使用"Fiddler"查看信息:

Response sent 44 bytes of Cookie data:
    Set-Cookie: PHPSESSID=4a30p9g6mh5tm93a94o7bh7r74; path=/
Response sent 50 bytes of Cookie data:
    Set-Cookie: WHMCSUID=75; expires=Thu, 07-Feb-2013 10:48:49 GMT
Response sent 79 bytes of Cookie data:
    Set-Cookie: WHMCSPW=54512414f2e6aef246445abf341a05e9; expires=Thu, 07-Feb-2013 10:48:49 GMT

我从firebug控制台窗口得到的消息:

POST http://development/crm/processlogin.php 302 Moved Temporarily 5.04s

输出:

error: {"readyState":0,"responseText":"","status":0,"statusText":"error"}

我相信302错误消息是因为服务器在登录后试图重定向。我实际上不需要重定向,但我确实需要将cookie保存到浏览器中,以便用户登录,我希望你们能告诉我如何做到这一点?

谢谢!!!

我相信cdm9002说它不起作用的原因是由于不同的域。我在同一个域上测试了该功能,它起了作用,但是,这不是我需要的功能。我想出了一个破解方法,让它发挥作用,但这不是正确的做事方式:(.如果有人知道正确的方式,我仍然感兴趣,但我已经解决了我眼前的困境。

解决方案是先处理登录的应用程序。然后将下一个登录凭据加载到下一页的隐藏iframe中。然后我使用javascript提交隐藏的表单。

我知道这是一种非常糟糕的方式,但我无法想出另一种解决方案。