原创,转载请注明
这可能是目前博客里技术含量比较高的一篇了
打算写个小工具集成一下这些接口
起因
为了给博客带来流量,我在CSDN,博客园,简书上开通了账号并且把博客里的一些可以发布的文章也在这些平台发布。
但是同时维护三个博客平台实在太麻烦了,一旦有个地方要修改,三个博客平台全部要修改。所以现在也基本没有同步发布了,但是我始终想实现博客平台同步发布,同步修改。
CSDN:https://blog.csdn.net/weixin_42680039
简书:https://www.jianshu.com/u/273f296c557c
博客园:https://www.cnblogs.com/ljysblog/
欢迎来访~
于是开始研究博客园的发布文章接口,一开始自己抓包分析,发现实在麻烦。于是谷歌之,发现了Metaweblog这个非常好用的API
介绍
XML-RPC是一个远程过程调用(远程过程调用)(remote procedure call,RPC)的分布式计算协议,通过XML将调用函数封装,并使用HTTP协议作为发送机制。
XML-RPC发表于1998年,由UserLand Software(UserLand Software)的Dave Winer及Microsoft共同发表。后来在新的功能不断被引入下,这个标准慢慢演变成为今日的SOAP协议。
可见这个协议发布的非常早,它的官网停留在了2004年。关于这方面的资料非常少,只有在MSDN和博客园很早的文章中才能寻得一点蛛丝马迹。
可我们讲的是Metaweblog,为什么还要介绍XMLPRC?
MetaWeblog API(MWA)是一个编程接口,允许外部程序获取和设置weblog帖子的文本和属性。它建立在流行的XML-RPC通信协议之上,在许多流行的编程环境中都可以使用实现。
在2003年之际,很多的博客平台开始支持MetaWeblog API,允许第三方编辑器和内容管理器对博客进行编辑管理。
在现在,比如MWeb
,Windows Live Writer
的文章发布都是以这个API为基础的!
而这个API,就是9102年博客同步的关键所在!
接口介绍
折腾了两天,被博客园的一篇有小错误的文章搞得心态全崩,后来查了MSDN才可以成功请求。
以博客园为例,有这些接口
blogger.deletePost —— 删除文章
blogger.getUsersBlogs —— 获取用户博客信息
metaWeblog.editPost —— 编辑文章
metaWeblog.getCategories —— 获取用户博客分类
metaWeblog.getPost —— 获取文章
metaWeblog.getRecentPosts —— 获取最近的文章
metaWeblog.newMediaObject —— 添加媒体对象(图片等)
metaWeblog.newPost —— 添加文章
wp.newCategory —— 添加目录
我们主要用到的接口是getUsersBlogs
;editPost
;getRecentPosts
;newPost
.
通过newPost循环多平台发布文章,editPost和getRecentPosts作为后续管理和编辑的方法。
而getUsersBlogs可用可不用,在一些平台上要通过此方法获取blogid才可以实现下面方法,但是博客园只要账号密码就可以实现。
不过这个方法可以获取用户名,对于工具的用户体验有帮助
实现过程
调试工具:精易网页助手
API接口地址:https://rpc.cnblogs.com/metaweblog/博客名
访问方法:POST
编码:UTF-8
1.blogger.getUsersBlogs
参数:
1)[string]xmlrpc_url(即上述API接口地址)
2)[string]username(博客园账号)
3)[string]pwd(博客园密码)
这一步为获取博主信息,上面说到这步其实可以省略,但是为了下面的工具编写,我们依旧演示。
可见我们成功获取了blogid和用户名(非博客名)
2.metaWeblog.newPost
参数:
1)[string]blogid(经过测试,此项被忽略但是不能删去对应标签)
2)[string]username
3)[string]pwd
4)[struct]Post(此项是一个结构,具体参考文末的博客园文档)
5)[bool]publish(是否发布.1为发布,0为不发布)
这里吐槽两句,博客园的一篇文章给了这个方法的示例,但是我请求时总是显示Request from client does not contain valid XML.
但是我提交的XML没有错误,直到找到了MSDN上的一个示例,猛地看到encoding。
没错,post提交信息必须以UTF-8编码,之前一直以gb2312提交,永远提示错误。当然,如果不提交中文,编码随意~
演示:
显示的字符串说明发布成功,字符串为该文章的postid
博客页面:
发布成功,URL地址的最后就是刚刚获取到的postid,内容也是刚刚提交的内容。
最重要的一步,也是坑我最久的一步搞定~
3.metaWeblog.getRecentPosts
参数:
1)[string]blogid(ignored)
2)[string]username
3)[string]pwd
4)[int]numberOfPosts(获取文章的数量)
这个是接下来我做工具想要的一个功能,用于查看是否同步到最新文章
演示(解析树很长,截不完整,是对的):
4.metaWeblog.editPost
用法同newPost只是要加一个postid的参数,这个在getRecentPost中可以获取到~
一点总结
这是一个非常有用的接口,已知国内CTO,博客园,开源中国都支持此方法发布文章。那么就可以写出一个博客同步发表工具,作为独立博客流量的入口,提高了同步效率!
参考文章
这次参考的文章感觉都是2000年时代的,自己一点点查文档研究也是不容易了……