PHP实现模拟登录签到功能

?php date_default_timezone_set(Asia/Shanghai); echo 执行开始:-----.date(Y-m-d H:i:s, time()).-----; $user = 13*****2014; //用户名$pwd = 12****67; //密码 $url = https://www.********/actlogin; //登录地址指定到网站的登录地址 $signin = https:/
<?php 
 
date_default_timezone_set('Asia/Shanghai'); 
 
echo "执行开始:-----".date("Y-m-d H:i:s", time())."-----";
 
$user = '13*****2014'; //用户名
$pwd = '12****67';   //密码
 
$url = 'https://www.********/actlogin'; //登录地址指定到网站的登录地址
 
$signin = 'https://www*************dd'; //签到触发地址指定操作的触发地址
 
$postFields = 'sUserName='.$user.'&sPassword='.$pwd; //需要传递的参数
 
$path = './cookie.log'; //cookie.log 存储文件必须
 
if(is_file($path)){
    file_put_contents($path,''); //把字符串写入文件中
    $login = curl_init($url);  //创建一个curl资源
    curl_setopt($login,CURLOPT_HEADER,0);   //
    curl_setopt($login,CURLOPT_RETURNTRANSFER,1);  //当CURLOPT_RETURNTRANSFER设置为1时 $head 有请求的返回值
    curl_setopt($login,CURLOPT_POST,1);
    curl_setopt($login,CURLOPT_POSTFIELDS,$postFields);  //传输数据
    curl_setopt($login,CURLOPT_COOKIEJAR,$path); //链接时获取cookie存为文件
    $res = curl_exec($login);  //抓取url传递给浏览器
    // var_dump($res.PHP_EOL);
    curl_close($login);  //关闭curl资源 并释放系统资源
}else{
    echo '不存在文件cookie';
}
 
if (is_file($path)) {
    $sign = curl_init($signin);
    // curl_setopt($sign,CURLOPT_HTTPHEADER, $header);
    curl_setopt($sign,CURLOPT_HEADER,0);
    curl_setopt($sign,CURLOPT_POST,1);
    //curl_setopt($sign,CURLOPT_POSTFIELDS,'');
    curl_setopt($sign,CURLOPT_RETURNTRANSFER,1);  //当设置为0是$head没有返回值,直接输出请求的内容
    curl_setopt($sign,CURLOPT_COOKIEFILE,$path); //带着这个cookie文件访问
    $result = curl_exec($sign);
    
    curl_close($sign);
}else{
    echo '丢失文件cookie';
}
 
echo $result."-----执行结束:-----".date("Y-m-d H:i:s", time())."-----</br>";

demo代码如上,写好做一个定时任务执行就行了。
本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

今天在用php进行图片保存输出时候,图片一直显示错误,后面用调试模式下提示:Warning: Cannot modify header information - headers already sent by... 看了一些网上的方法也没解决,最后在php.ini配置output_buffering默认为4096就没有遇到这个错误了: o
ob_start()函数用于打开缓冲区,比如header()函数之前如果就有输出,包括回车/空格/换行/都会有Header had all ready send by的错误,这时可以先用ob_start()打开缓冲区PHP代码的数据块和echo()输出都会进入缓冲区而不会立刻输出.当然打开缓冲区的作用很多,只要
第一种方法:用php的strpos() 函数判断字符串中是否包含某字符串的方法 if(strpos(www.genban.org,genban) !== false){ echo 包含genban; }else{ echo 不包含genban; } 第二种 使用了explode 用explode进行判断PHP判断字符串的包含代码如下: ?php $name = 00
/u 表示按unicode(utf-8)匹配(主要针对多字节比如汉字) /i 表示不区分大小写(如果表达式里面有 a, 那么 A 也是匹配对象) /s 表示将字符串视为单行来匹配
随机生成难点是在于如何避免碰撞,有人说用md5,GUID这些机制啊,当然可以,但是做为账号,看着有乱,而且生成位数也过长。 本方法只需要解决1秒内的并发碰撞就可以,因为固定头部采用的是unixtime时间,精确到秒,超过1秒,这个头部的时间肯定变化了。同时
此段代码只支持主流浏览器,一些浏览器可能会不支持,比如:百度 代码如下: function openWx(){ locatUrl = weixin://; if(/ipad|iphone|mac/i.test(navigator.userAgent)) { var ifr =document.createElement(iframe); ifr.src = locatUrl; ifr.style.disp