博客列表 >基于PHP实现发微博动态代码实例

基于PHP实现发微博动态代码实例

P粉896289085
P粉896289085原创
2022年03月27日 11:42:51861浏览

这篇文章主要介绍了基于PHP实现发微博动态代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

首先,肯定是注册成为开发者新浪微博开放平台
选择网站应用,填写一些基本信息
填完后在‘我的应用’中,会看到刚创建的应用信息,我们只是简单的测试一下,所以其他复杂的注册信息都不用填写,有这些就够了
很重要的一点,回调地址填写↓,回调地址是微博返回数据的地址,一定要填写完全一致
接下来,就是代码部分了:
随便创建一个页面,可以是一个a标签,或者自己找一个新浪的图标,随你喜欢
<a href='https://api.weibo.com/oauth2/authorize?client_id=2259374069&redirect_uri=http://www.huazi.com/good/login.php'>微博登录</a>
client_id 就是填写完应用信息后获得的App Key
redirect_uri 就是高级信息里面的回调地址
浏览器输入这个页面的地址,点击,会跳转到授权页面,点击授权并登陆
到回调地址页面,这是,回调地址会返回一个临时code,我们可以用code来换取token

  1. <?php
  2. header('content-type:text/html;charset=utf-8');
  3. $code = $_GET['code']; //获取code
  4. $url = 'https://api.weibo.com/oauth2/access_token'; //获取token的地址
  5. $client_id = '2259374069'; //App Key
  6. $client_secret = '你的App Secret'; //App Secret
  7. $grant_type = 'authorization_code'; //获取类型
  8. $redirect_uri = 'http://www.huazi.com/good/login.php'; //回调地址
  9. // echo $code;die;
  10. //模拟登陆数据
  11. $vars['client_id'] = $client_id;
  12. $vars['client_secret'] = $client_secret;
  13. $vars['grant_type'] = $grant_type;
  14. $vars['code'] = $code;
  15. $vars['redirect_uri'] = $redirect_uri;
  16. //使用CURL模拟登录信息
  17. $method_post = true;
  18. $ch =curl_init();
  19. $params[CURLOPT_URL] = $url;
  20. $params[CURLOPT_HEADER] = false;
  21. $params[CURLOPT_RETURNTRANSFER] = true;
  22. $params[CURLOPT_FOLLOWLOCATION] = true;
  23. $params[CURLOPT_USERAGENT] = 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:39.0) Gecko/20100101 Firefox/39.0';
  24. $params[CURLOPT_SSL_VERIFYPEER] = false;
  25. $params[CURLOPT_SSL_VERIFYHOST] = false;
  26. //格式化地址信息
  27. $postfields = '';
  28. foreach ($vars as $key => $value) {
  29. $postfields .= urlencode($key) . '=' . urlencode($value) . '&';
  30. }
  31. $params[CURLOPT_POST] = true;
  32. $params[CURLOPT_POSTFIELDS] =$postfields;
  33. curl_setopt_array($ch, $params);
  34. $content = curl_exec($ch);
  35. //如果发生curl错误可以使用curl_error查看错误信息
  36. // var_dump(curl_error($ch));
  37. echo $content;
  38. // echo "<br>";
  39. // echo "<pre>";
  40. // print_r(json_decode($content,true));

至此,就获取到了我们需要的token信息,已经实现了新浪第三方登录
把token取出来,通过token可以操作很多东西,传不同的参数和URL就可以,我以发微博为例

  1. <?php
  2. header('content-type:text/html;charset=utf-8');
  3. $url = 'https://api.weibo.com/2/statuses/update.json';
  4. $access_token = '刚才获取的token';
  5. $status = '我的测试微博'; //你要发的微博内容
  6. //模拟登陆数据
  7. $vars['access_token'] = $access_token;
  8. $vars['status'] = $status;
  9. $method_post = true;
  10. $ch =curl_init();
  11. $params[CURLOPT_URL] = $url;
  12. $params[CURLOPT_HEADER] = false;
  13. $params[CURLOPT_RETURNTRANSFER] = true;
  14. $params[CURLOPT_FOLLOWLOCATION] = true;
  15. $params[CURLOPT_USERAGENT] = 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:39.0) Gecko/20100101 Firefox/39.0';
  16. $params[CURLOPT_SSL_VERIFYPEER] = false;
  17. $params[CURLOPT_SSL_VERIFYHOST] = false;
  18. $postfields = '';
  19. foreach ($vars as $key => $value) {
  20. $postfields .= urlencode($key) . '=' . urlencode($value) . '&';
  21. }
  22. $params[CURLOPT_POST] = true;
  23. $params[CURLOPT_POSTFIELDS] =$postfields;
  24. curl_setopt_array($ch, $params);
  25. $content = curl_exec($ch);
  26. // var_dump(curl_error($ch));
  27. echo $content;
  28. echo "<br>";
  29. echo "<pre>";
  30. print_r(json_decode($content,true));

我们发现,这段代码下面的部分跟上段代码一样,没错,就是这样的
在浏览起输入这个页面的地址,再去看看你的微博,是不是成功发了一条微博?
以上就是本文的全部内容,希望对大家的学习有所帮助。

声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议