curl模拟post数据问题 模拟登陆一个页面,用html写一个表单post过去能够登陆,但是用curl就登陆不了。这是什么情况 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 看你curl的post过去的数据是否正确 <?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); ?> 你的错误时只执行了一次 curl_exec($ch)按现在登录页的设计,用户登录的流程是:1、进入表单页 在这里sessionid已经传过来了,或与还有token2、填写表单并提交3、验证用户是否合法 验证通过后重新设置cookie你只从第二步开始,那么 CURLOPT_COOKIEJAR 得到的只是第三步产生的cookie由于缺少第一步的cookie,所以验证不会通过所以你需要1、进入表单页,通过 CURLOPT_COOKIEJAR 记录下 cookie2、进入表单处理页,通过 CURLOPT_COOKIEFILE 传递第一步保存的 cookie 但是我用自己写的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> 请问 RTApiReqGetRow(),RTApiReqOpen()是什么函数? 项目中的 图片路径 你们是怎么解决的呢? 问:我用的appserv的环境require后的语句不执行 十万火急:为什么我写的上传图片函数在本机测试正常,到服务器上不行? 用过PHP内容管理系统的人进来看看! PHP中怎么样调试比较方便啊. PHP如何访问ORACLE的数据集,用存储过程 那位高手知道NT+APACHE+PHP+MODSSL+OPENSSL怎么配置呢? 关于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);
?>
按现在登录页的设计,用户登录的流程是:
1、进入表单页 在这里sessionid已经传过来了,或与还有token
2、填写表单并提交
3、验证用户是否合法 验证通过后重新设置cookie你只从第二步开始,那么 CURLOPT_COOKIEJAR 得到的只是第三步产生的cookie
由于缺少第一步的cookie,所以验证不会通过所以你需要
1、进入表单页,通过 CURLOPT_COOKIEJAR 记录下 cookie
2、进入表单处理页,通过 CURLOPT_COOKIEFILE 传递第一步保存的 cookie
<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>