<tfoot id='ZviOL'></tfoot>
<i id='ZviOL'><tr id='ZviOL'><dt id='ZviOL'><q id='ZviOL'><span id='ZviOL'><b id='ZviOL'><form id='ZviOL'><ins id='ZviOL'></ins><ul id='ZviOL'></ul><sub id='ZviOL'></sub></form><legend id='ZviOL'></legend><bdo id='ZviOL'><pre id='ZviOL'><center id='ZviOL'></center></pre></bdo></b><th id='ZviOL'></th></span></q></dt></tr></i><div id='ZviOL'><tfoot id='ZviOL'></tfoot><dl id='ZviOL'><fieldset id='ZviOL'></fieldset></dl></div>

  • <small id='ZviOL'></small><noframes id='ZviOL'>

    1. <legend id='ZviOL'><style id='ZviOL'><dir id='ZviOL'><q id='ZviOL'></q></dir></style></legend>
      • <bdo id='ZviOL'></bdo><ul id='ZviOL'></ul>

      1. 使用 curl 登录 Joomla 2.5

        时间:2023-10-16

          <tbody id='N1i6S'></tbody>

      2. <legend id='N1i6S'><style id='N1i6S'><dir id='N1i6S'><q id='N1i6S'></q></dir></style></legend>

        <small id='N1i6S'></small><noframes id='N1i6S'>

          • <bdo id='N1i6S'></bdo><ul id='N1i6S'></ul>
            <tfoot id='N1i6S'></tfoot>
            <i id='N1i6S'><tr id='N1i6S'><dt id='N1i6S'><q id='N1i6S'><span id='N1i6S'><b id='N1i6S'><form id='N1i6S'><ins id='N1i6S'></ins><ul id='N1i6S'></ul><sub id='N1i6S'></sub></form><legend id='N1i6S'></legend><bdo id='N1i6S'><pre id='N1i6S'><center id='N1i6S'></center></pre></bdo></b><th id='N1i6S'></th></span></q></dt></tr></i><div id='N1i6S'><tfoot id='N1i6S'></tfoot><dl id='N1i6S'><fieldset id='N1i6S'></fieldset></dl></div>

                • 本文介绍了使用 curl 登录 Joomla 2.5的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  我正在尝试使用 php 中的 curl 远程访问 joomla 2.5.后来我也想创建新内容,但现在我在登录时遇到了麻烦.对我来说是 curl 新的所以我不知道我做错了什么.我收到此消息:您的会话已过期.请重新登录.".到目前为止,这是我的代码:

                  I'm trying remotely access joomla 2.5 with curl in php. Later I want to create new content too, but for now i have troubles with login. For me is curl new so I don't know what am I doing wrong. I get this message: "Your session has expired. Please log in again.". Here is my code so far:

                  $url = "http://localhost/joomla25/administrator/";
                  $cookie = "tmp/cookie".time().".txt";
                  
                  $ch = curl_init();
                  curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);
                  curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie);
                  curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie);
                  curl_setopt($ch, CURLOPT_USERAGENT, "Mozilla/4.0 (compatible; MSIE 5.01; Windows NT 5.0)");
                  curl_setopt($ch, CURLOPT_URL, $url);
                  ob_start(); 
                  $page = curl_exec ($ch);
                  curl_close ($ch);
                  unset($ch);
                  
                  //get hidden inputs
                  preg_match_all("(<input type="hidden" name="return" value="(.*)" />)siU", $page,                     $matches1);
                  preg_match_all("(<input type="hidden" name="(.*)" value="1" />)iU", $page,     $matches2);
                  $return = trim($matches1[1][0]);
                  $key = trim($matches2[1][0]);
                  
                  $param = 'username='.urlencode("admin")."&passwd=".urlencode("admin")."&lang=&option=com_login&task=login&return=".urlencode($return)."&".urlencode($key)."=1";
                  
                  $fp = fopen($cookie,"w");
                  fclose($fp);
                  
                  //login
                  $ch = curl_init();
                  curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie);
                  curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie);
                  curl_setopt($ch, CURLOPT_USERAGENT, "Mozilla/4.0 (compatible; MSIE 5.01; Windows NT 5.0)");
                  curl_setopt($ch, CURLOPT_TIMEOUT, 40);
                  curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);
                  
                  curl_setopt($ch, CURLOPT_URL, $url);
                  curl_setopt($ch, CURLOPT_HEADER, TRUE);
                  curl_setopt($ch, CURLOPT_USERAGENT, $_SERVER['HTTP_USER_AGENT']);
                  curl_setopt($ch, CURLOPT_FOLLOWLOCATION, TRUE);
                  curl_setopt($ch, CURLOPT_POST, TRUE);
                  curl_setopt($ch, CURLOPT_POSTFIELDS, $param);
                  ob_start();      
                  $page2 = curl_exec ($ch);
                  ob_end_clean();
                  curl_close ($ch);
                  unset($ch);
                  
                  echo $page2;
                  

                  知道出了什么问题吗?感谢帮助!

                  Any idea what is wrong? Thanks for help!

                  推荐答案

                  在站点根目录上创建 cookie 文件.将其命名为 cookie.txt我不在 joomle 上编码,但我认为有表单标记.这意味着,你不能在没有获得令牌哈希的情况下提交表单.

                  Create cookie file on site root. Name it as cookie.txt I dont code on joomle, but i think there is form token. Whitch means, you cant submit form without getting token hash.

                  当您手动登录并登录时,url 中的内容类似于哈希?

                  When you login manualy and you are logged in, in url is something like hash?

                  这篇关于使用 curl 登录 Joomla 2.5的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  上一篇:如何在 Joomla 模板中包含 PHP 函数文件 下一篇:如何向 <title> 添加额外的文本Joomla 中的标签

                  相关文章

                    <small id='AX371'></small><noframes id='AX371'>

                      <legend id='AX371'><style id='AX371'><dir id='AX371'><q id='AX371'></q></dir></style></legend>
                        <bdo id='AX371'></bdo><ul id='AX371'></ul>
                      <tfoot id='AX371'></tfoot>
                      <i id='AX371'><tr id='AX371'><dt id='AX371'><q id='AX371'><span id='AX371'><b id='AX371'><form id='AX371'><ins id='AX371'></ins><ul id='AX371'></ul><sub id='AX371'></sub></form><legend id='AX371'></legend><bdo id='AX371'><pre id='AX371'><center id='AX371'></center></pre></bdo></b><th id='AX371'></th></span></q></dt></tr></i><div id='AX371'><tfoot id='AX371'></tfoot><dl id='AX371'><fieldset id='AX371'></fieldset></dl></div>