网站调用新浪微博内容(一条微博审核之后,希望能提取摘要,自动同步发布)

优采云 发布时间: 2022-02-25 20:10

  网站调用新浪微博内容(一条微博审核之后,希望能提取摘要,自动同步发布)

  任务

  发完博客,希望提取摘要,自动同步发一条微博;

  准备好工作了

  作为新浪微博的开发者,需要进行身份验证;

  个人身份认证审核一般需要1个工作日;

  下一步是提交网站的review,国内是提交备案号。海外投稿,网站的海外证明即可;也是一个工作日左右;

  通过个人身份审核后,可以创建应用和调用接口,此时获得的权限比较低;

  网站不提交审核或审核不通过,不影响微博发帖;它只会在已发布的微博下显示“未审核的申请”;

  网站审核后显示的应用名称:

  调用接口

  微博开放平台提供测试工具;

  在开发接入之前,首先要保证测试微博可以通过这个测试工具发出;

  %E5%BE%AE%E5%8D%9A%E6%9D%A5%E8%87%AAAI%E6%B5%8B%E8%AF%95%E5%B7%A5%E5%85%B7

  发送微博的api参考文档为:

  所有发送微博的接口都需要授权认证;认证通过后,会得到一个access_token(访问密钥);密钥的有效期根据用户级别而有所不同;

  网络审查不合格者1天;审核通过的普通用户7天;

  在有效期内,无需与新浪服务器交互进行授权认证。只要这个token存储在本地,就可以用来调用各种微博API(读、写、获取受众信息等)

  权威认证

  授权认证的三种方式:

  通过用户名和密码;

  这个最容易理解,在程序中写下微博账号的用户名和密码,使用api调用进行认证;但需要注意的是,这个接口是为app的开发提供的,不能使用web应用;

  通过web回调方法;

  需要与新浪服务器交互并提供回调地址;获取回调地址中的access_token;

  第三种方法是代码方法,不仔细看,略过;

  web应用只支持第二种授权方式;下面详细介绍第二种方法的使用:

  下载新浪提供的SDK,收录demo和api封装类;

  访问页面:

  调用.php:

  1include_once( 'sina_config.php' );

2include_once( 'saetv2.ex.class.php' );

3

4//获取到授权的url

5$o = new SaeTOAuthV2( WB_AKEY , WB_SKEY );

6$code_url = $o->getAuthorizeURL( WB_CALLBACK_URL );

7

8//post或get方式调用该url,取得授权;授权完成后,新浪会调用我们这边传过去的回调地址:WB_CALLBACK_URL

9request()->redirect($code_url);

10

  回调地址页(WB_CALLBACK_URL):

  回调.php

  博客的抽象提取

  微博字数140字;汉字为1个字符;我们使用计数功能来选择;对于一个汉字,strlen()算3个字符,而多字节统计函数mb_strlen()算1个字符,符合我们的使用要求;

  最后,需要清除已发布微博中的html标签等

  1 //获取当前微博内容(140字)

2 public function getWeibo()

3 {

4 $titleLen = mb_strlen($this->title, 'UTF-8');

5 //140字除去链接的20个字和省略符;剩115字左右,需要说明的是链接:无论文章的链接多长,在微博里都会被替换成短链接,按短链接的长度来计算字数;

6 $summaryLen = 115 - $titleLen ;

7

8 $pubPaper = cutstr_html($this->summary);

9 if(mb_strlen($pubPaper, 'UTF-8') >= $summaryLen)

10 $pubPaper = mb_substr($pubPaper,0,$summaryLen,'UTF-8');

11

12 $pubPaper = sprintf('【%s】%s...%s', $this->title , $pubPaper , aurl('post/show', array('id' => $this->id)));

13

14 return $pubPaper;

15 }

16

17//完全的去除html标记

18function cutstr_html($string)

19{

20 $string = strip_tags($string);

21 $string = preg_replace ('/n/is', '', $string);

22 $string = preg_replace ('/ | /is', '', $string);

23 $string = preg_replace ('/ /is', '', $string);

24

25 return $string;

26}

27

  超过。

  发布者:大CC | 2013 年 11 月 30 日

  博客:

  微博:新浪微博

0 个评论

要回复文章请先登录注册


官方客服QQ群

微信人工客服

QQ人工客服


线