JavaMetaweblogClient,Metaweblog的java實現-從此上傳部落格實現全平台
不知你是否會遇到下面這樣的情況:想要通過java上傳部落格,結果卻發現api的使用有些複雜。沒關係,這裡幫你解決了api的問題。在使用Metaweblog的時候,只需要調用網頁上同名的方法就好了,一鍵發送命令,感受調用api的快感。
1. 什麼是Metaweblog?
Metaweblog是一個webservice,也就是在網路上使用的api。它基於xml-rpc實現。對於現存的部落格平台,例如部落格園、開源中國、wordpress等都實現了metaweblog。通過這個api,你可以不登錄網頁,直接通過一些程式來增刪查改你的部落格,上傳媒體文件。
2. Metaweblog的應用
metaweblog的適用範圍不太廣,但是絕對能滿足於部落格管理的需要。通常,面對下面情況,你就可以使用metaweblog:
- 你已經編輯好了一篇部落格,保存為markdown文件,想要快速上傳部落格;
- 你想刪除一篇部落格;
- 你想更新一篇部落格,但又不想複製並粘貼全部;
- 你用離線編輯器寫部落格,但是圖片又不想保存在本地,想直接把圖片上傳到部落格伺服器裡面;
因此,metaweblog可以滿足你的需要
3. 如何使用Metaweblog
在使用本項目前,你首先需要了解一下metaweblog的原理以及如何使用。
目前,有關metaweblog的官網已經崩了,但是你仍然可以在這裡查到它的api。

如圖所示,有很多的方法(函數)可供調用。顯然,你可以按照它的指示調用方法,實現部落格的增刪查改和媒體文件的上傳。
在這張圖裡,我們看到的是部落格園的api調用介面,而別的網站則不一定有這樣的介面,但是你可以自己嘗試它們的api是否開放。下面是各大部落格網站的api地址
-
部落格園://rpc.cnblogs.com/metaweblog/你的用戶名,你可以在你的後台設置里查看有關設置
-
網易(163)://os.blog.163.com/word/
-
typecho 部落格://xx.com/action/xmlrpc,其中 xx.com 為你的部落格網址。如果 typecho 還沒有進行 urlrewrite,則為 //xx.com/index.php/action/xmlrpc
-
新浪部落格: //upload.move.blog.sina.com.cn/blog_rebuild/blog/xmlrpc.php 新浪部落格的 API 已關閉了
-
CSDN: //write.blog.csdn.net/xmlrpc/index,可惜CSDN的api也關閉了
-
自建wordpress部落格: //www.example.com/xmlrpc.php,其中
www.example.com是你的網站地址域名.
4. 本項目介紹
然而, 對於各種語言, metaweblog的實現也不一樣.因此,你需要去尋找各種語言的實現方法.在網上,你可以查到python如何實現metaweblog,C#更是有專門的api,極大地方便了使用者調用。那麼,java呢?很抱歉,網上有關java實現metaweblog的文章少之又少。為了解決這種情況,筆者做出了名為JavaMetaweblogClient的api,方便java愛好者去調用,去實現。
4.1 metaweblog與java之間的關係映射
如果你看了api的介紹,你就會知道,這個api是給多個語言使用的,所以很多的數據類型java都沒有。那麼我們就需要一個映射表。本項目通過apache 的xmlrpc實現,所以我們可以查看他的官方文檔

這些就是你要去了解的。其中,struct的類型對應到java裡面是Map<String,Object>。但是你並不需要如此,在本項目中,我已經將struct打包成了一個類對象,例如Post,裡面的成員變數就是dateTime description title categories四個.需要用的時候就依次把變數填入即可。
這時,你在使用這些方法時就會更加的得心應手。
4.2 使用JavaMetaweblogClient
本項目本質上只實現了Client,但是很明顯我們只需要client,伺服器的事由部落格方來干。那麼我們就要來了解一下如何使用api。
打開本項目的java文檔,你會看見Client類上有教程,但是在這裡我還是會再打一遍。
使用方法大致分為以下三步:(以新建一個部落格文章為例)
- 你要創建一個Client對象
- 準備好參數
- 上傳命令,並處理異常
這裡我們以newPost方法為例:
public static void newPostTest() {
// 準備好命令所需參數(新建Post對象)
Post post = new Post(new Date(), "# This is a post\n> You can see the Post\n", "Test");
// 準備好返回值(自己看方法注釋的返回類型)
String result = null;
// 創建連接客戶端
try { // 自己解決拋出的異常
Client client = new Client("//www.cycode.club/xmlrpc.php");
result = client.newPost("default", "S*******u", "******", post, false);
} catch (MalformedURLException e) {
e.printStackTrace(); // 一般為URL格式錯誤
} catch (XmlRpcException e) {
e.printStackTrace(); // 一般為參數不全、伺服器錯誤、URL輸入錯誤
}
// 輸出結果
System.out.println(result);
}
其中的核心程式碼只有一條:
result = client.newPost("default", "S*****u", "*****", post, false);
至於其他的程式碼,通常IDE會自己生成,以及提醒你參數的填入。其中Post參數需要直接填入本項目已創建好的Post類,而不是自己寫一個Map<String,Object>.
5. 最後的話
作為新手程式設計師和他的第一個api,有很多的資訊都在javadoc文檔里。如果有什麼問題,盡量去查看docs文檔,有很多位置都可以查看文檔。
FAQ
-
Q:目前程式有什麼已知的問題嗎?
A:本項目就是apache的xmlrpc實現的套殼,如果有什麼問題,大多是xmlrpc的問題,畢竟現在用xmlrpc的人已經很少了。
不過,我依舊發現了如下問題:
- getPost方法與wordpress上的editor.md插件衝突
-
Q:我想知道哪裡有詳細的教程。
A:本人是新手程式設計師,管理教程會非常的麻煩,但我大量的幫助文檔都寫死在程式里了,查看javadoc文檔獲得的資訊會比在這裡大得多。可以查看本文檔第五項查看javadoc地址。
聯繫我
- email: [email protected]
- QQ: 1914913486
- 部落格園: //www.cnblogs.com/sxrhhh
- github: //github.com/cycode0527
- 個人網站: //www.sxrhhh.top(還在實驗中)


