模拟登陆一个页面,用html写一个表单post过去能够登陆,但是用curl就登陆不了。这是什么情况

解决方案 »

  1.   

    看你curl的post过去的数据是否正确
      

  2.   

    <?php 
    //登陆认证 
    $url = "http://211.67.32.144/edu/login!checkLogin.action"; 
    $post_data = array( "user_account" => "031140107","user_password" => "02185758","user_roleId"=>"2" ); 
    $cookie_jar = tempnam('./temp','cookie');//存放COOKIE的文件 
    $ch = curl_init(); 
    curl_setopt($ch, CURLOPT_URL, $url); 
    curl_setopt($ch, CURLOPT_POST, 1); 
    curl_setopt($ch, CURLOPT_HEADER, 0); 
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 0); 
    curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data);   
    curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie_jar);  //保存cookie信息 
    $output1 = curl_exec($ch); 
    curl_close($ch); 
    ?>
      

  3.   

    你的错误时只执行了一次 curl_exec($ch)
    按现在登录页的设计,用户登录的流程是:
    1、进入表单页 在这里sessionid已经传过来了,或与还有token
    2、填写表单并提交
    3、验证用户是否合法 验证通过后重新设置cookie你只从第二步开始,那么 CURLOPT_COOKIEJAR 得到的只是第三步产生的cookie
    由于缺少第一步的cookie,所以验证不会通过所以你需要
    1、进入表单页,通过 CURLOPT_COOKIEJAR 记录下 cookie
    2、进入表单处理页,通过 CURLOPT_COOKIEFILE 传递第一步保存的 cookie
      

  4.   

    但是我用自己写的html界面,只要保证name相同,我还是可以登录成功啊,我也没有执行第一步啊代码如下<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
     <head>
      <title> 仿民院登录 </title>
     <meta http-equiv="content-type" content="text/html;charset=utf-8"/>
      <meta name="Author" content="">
      <meta name="Keywords" content="">
      <meta name="Description" content="">
     </head> <body>
      <form action="http://211.67.32.144/edu/login!checkLogin.action" method="post">
      <table>
      <tr><td><input type="hidden" name="user.roleId" value="2"/></td></tr>
      <tr><td>学号:</td><td><input type="text" name="user.account"/></td></tr>
      <tr><td>密码:</td><td><input type="password" name="user.password"/></td></tr>
      <tr><td><input type="submit" value="提交"/></td><td><input type="reset" value="重置"/></td></tr>
      </table>
      </form>
     </body>
    </html>