您现在的位置是:网站首页> 编程资料编程资料
PHP实现发送微博消息功能完整示例_php技巧_
2023-05-25
324人已围观
简介 PHP实现发送微博消息功能完整示例_php技巧_
本文实例讲述了PHP实现发送微博消息功能。分享给大家供大家参考,具体如下:
$value){ $tmp .= $key."=".$value."&"; } $post = trim($tmp,"&"); $header = array( 'Host:weibo.com', 'Accept: */*', 'Accept-Language: zh-cn,zh;q=0.8,en-us;q=0.5,en;q=0.3', 'Content-Type:application/x-www-form-urlencoded', 'X-Requested-With:XMLHttpRequest', 'Referer: '.$userCenter, ); //var_dump($header);exit; $ch = curl_init(); curl_setopt($ch,CURLOPT_URL,$posturl); curl_setopt($ch,CURLOPT_RETURNTRANSFER,1); curl_setopt($ch,CURLOPT_COOKIEFILE, $cookie_file); curl_setopt($ch,CURLOPT_USERAGENT,'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:30.0) Gecko/20100101 Firefox/30.0'); curl_setopt($ch,CURLOPT_HTTPHEADER,$header); curl_setopt($ch,CURLOPT_POST,1); curl_setopt($ch,CURLOPT_POSTFIELDS,$post); $str = curl_exec($ch); curl_close($ch); return $str; } function loginWeibo($u,$p){ global $cookie_file ; //$password = sha1(sha1(sha1($p)).$encryption['servertime'].$encryption['nonce']); $password = $p; $username = base64_encode($u); $loginUrl = 'https://login.sina.com.cn/sso/login.php?client=ssologin.js(v1.4.15)&_=1403138799543'; $loginData['entry'] = 'sso'; $loginData['gateway'] = '1'; $loginData['from'] = 'null'; $loginData['savestate'] = '30'; $loginData['useticket'] = '0'; $loginData['pagerefer'] = ''; $loginData['vsnf'] = '1'; $loginData['su'] = base64_encode($u); $loginData['service'] = 'sso'; $loginData['sp'] = $password; $loginData['sr'] = '1920*1080'; $loginData['encoding'] = 'UTF-8'; $loginData['cdult'] = '3'; $loginData['domain'] = 'sina.com.cn'; $loginData['prelt'] = '0'; $loginData['returntype'] = 'TEXT'; //var_dump($loginData);exit; $login = json_decode(loginPost($loginUrl,$loginData),true); //获取微博 get($login['crossDomainUrlList'][0]); $ch = curl_init(); curl_setopt($ch,CURLOPT_URL,"http://weibo.com"); curl_setopt($ch,CURLOPT_RETURNTRANSFER,1); curl_setopt($ch,CURLOPT_COOKIEFILE, $cookie_file); curl_setopt($ch,CURLOPT_COOKIEJAR,$cookie_file); $return = curl_exec($ch); $info = curl_getinfo($ch); curl_close($ch); $ch = curl_init(); curl_setopt($ch,CURLOPT_URL,$info['redirect_url']); curl_setopt($ch,CURLOPT_RETURNTRANSFER,1); curl_setopt($ch,CURLOPT_COOKIEFILE, $cookie_file); curl_setopt($ch,CURLOPT_COOKIEJAR,$cookie_file); curl_exec($ch); curl_close($ch); return $info['redirect_url']; } function loginPost($url,$data){ global $cookie_file ; //echo $cookie_file ;exit; $tmp = ''; if(is_array($data)){ foreach($data as $key =>$value){ $tmp .= $key."=".$value."&"; } $post = trim($tmp,"&"); }else{ $post = $data; } $ch = curl_init(); curl_setopt($ch,CURLOPT_URL,$url); curl_setopt($ch,CURLOPT_RETURNTRANSFER,1); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); curl_setopt($ch,CURLOPT_POST,1); curl_setopt($ch,CURLOPT_POSTFIELDS,$post); curl_setopt($ch,CURLOPT_COOKIEJAR,$cookie_file); curl_setopt($ch,CURLOPT_COOKIEJAR,$cookie_file); $return = curl_exec($ch); $info = curl_getinfo($ch); curl_close($ch); return $return; } function post($url,$data){ global $cookie_file; $tmp = ''; if(is_array($data)){ foreach($data as $key =>$value){ $tmp .= $key."=".$value."&"; } $post = trim($tmp,"&"); }else{ $post = $data; } $ch = curl_init(); curl_setopt($ch,CURLOPT_URL,$url); curl_setopt($ch,CURLOPT_RETURNTRANSFER,1); curl_setopt($ch,CURLOPT_POST,1); curl_setopt($ch,CURLOPT_COOKIEFILE, $cookie_file); curl_setopt($ch,CURLOPT_POSTFIELDS,$post); $return = curl_exec($ch); $info = curl_getinfo($ch); curl_close($ch); return $return; } function get($url,$getInfo=false){ global $cookie_file; $ch = curl_init(); curl_setopt($ch,CURLOPT_URL,$url); curl_setopt($ch,CURLOPT_RETURNTRANSFER,1); curl_setopt($ch,CURLOPT_COOKIEFILE, $cookie_file); curl_setopt($ch,CURLOPT_COOKIEJAR,$cookie_file); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); $return = curl_exec($ch); $info = curl_getinfo($ch); if($getInfo)return $info; curl_close($ch); return $return; } function mp(){ $getRndCode = "http://login.sina.com.cn/sso/prelogin.php?entry=weibo&callback=sinaSSOController.preloginCallBack&su=&rsakt=mod&client=ssologin.js(v1.4.15)&_=1403081692608"; @preg_match_all('/\((.*?)\)/is',get($getRndCode,$data),$data); $encryption = json_decode($data[1][0],true); return $encryption; } 更多关于PHP相关内容感兴趣的读者可查看本站专题:《php curl用法总结》、《PHP网络编程技巧总结》、《PHP数组(Array)操作技巧大全》、《php字符串(string)用法总结》、《PHP数据结构与算法教程》及《PHP中json格式数据操作技巧汇总》
希望本文所述对大家PHP程序设计有所帮助。
您可能感兴趣的文章:
相关内容
- PHP连续签到功能实现方法详解_php技巧_
- Laravel框架Eloquent ORM修改数据操作示例_php实例_
- Laravel框架Eloquent ORM删除数据操作示例_php实例_
- Laravel框架基础语法与知识点整理【模板变量、输出、include引入子视图等】_php实例_
- Laravel框架Blade模板简介及模板继承用法分析_php实例_
- 在phpstudy集成环境下的nginx服务器下配置url重写_php实例_
- php 实现简单的登录功能示例【基于thinkPHP框架】_php实例_
- 关于Yii2框架跑脚本时内存泄漏问题的分析与解决_php实例_
- 详解no input file specified 三种解决方法_php实例_
- 设定php简写功能的方法_php技巧_
