以前、XML-RPC を使って wordpress に投稿するツールを作ったのですが、画像も投稿できないと意味がないですよね…ということで、画像の投稿(というか、ファイルアップロード)のツールを作成しています。
XML-RPC wp ≪ WordPress Codex
http://codex.wordpress.org/XML-RPC_wp#wp.uploadFile
を見ると、データ形式が base64 になっていて、一見 BASE64 でエンコードをしないと駄目なような気がしますが、実は違います。これは XML-RPC 内で作られるフォーマットなので、BASE64 形式の文字列を送るのではなくて、バイナリを BASE64 で送る(CDATA を使う)っていう意味なんですね。
ちょっとハマりました。
ソースは抜粋だけアップしておきます。後で整理して、
- 記事本体の投稿(WpPost)
- 画像ファイルの投稿(WpUpFile)
の2つのツールを公開します。
/// <summary>
/// 新しい画像を投稿する
/// </summary>
/// <param name="post">投稿記事</param>
/// <returns>投稿した記事のID</returns>
public RetUpFile NewImage(ImageFile post)
{
//プロキシクラスのインスタンスを作成
IBlogger proxy = (IBlogger)
CookComputing.XmlRpc.XmlRpcProxyGen.Create(
typeof(IBlogger));
//URLを指定
proxy.Url = this.Url;
// ファイル名を小文字に変換
post.Filename = post.Filename.ToLower();
// UpFile を生成
UpFile upfile = new UpFile();
upfile.name = post.Filename;
upfile.type = "image/jpeg";
upfile.bits = null;
upfile.overwrite = true;
// ファイルを読み込む
long len = new FileInfo(post.Filename).Length;
byte[] data = new byte[len];
BinaryReader rd = new BinaryReader(
File.OpenRead( post.Filename ));
rd.Read(data, 0, (int)len);
rd.Close();
// BASE64に変換しない
// upfile.bits = Convert.ToBase64String(data);
upfile.bits = data;
// ファイルタイプを変更
if ( upfile.name.EndsWith(".jpg") ||
upfile.name.EndsWith(".jpeg") ) {
upfile.type = "image/jpeg";
} else if ( upfile.name.EndsWith(".png") ) {
upfile.type = "image/png";
} else if ( upfile.name.EndsWith(".gif")) {
upfile.type = "image/gif";
}
RetUpFile ret;
try
{
//blogger.getRecentPostsを呼び出す
ret = proxy.uploadFile(
"1", // 念のため1にしておく
this.Username,
this.Password,
upfile );
}
catch (Exception ex)
{
Console.WriteLine("エラー:" + ex.Message);
return null;
}
return ret;
}
}
この手のツールを作っているのは、実は wordpress で 300 ページ位の記事をアップできないか?と考えたわけです。
ブログを適度に書くぐらいであれば、ブラウザ上でもいいのですが、ある程度まとまった記事であればオフラインで書きたい。
そこでオフラインエディタの BlogWrite や Windows Live Writer などを使っていたのですが、どうも記事本体の編集だけに集中できない。様々な装飾が邪魔なんですね。
記事を書くときには、2つのタイプがあって、
- 記事本体(本文)に集中するためにエディタで書く。
- 記事のレイアウトを整えるために GUI ベースのツールを使う。
例えば、書籍で云えば、最初のが「著者」、次のが「編集者」あるいは「DTP」ってことです。
BlogWrite なんかのツールは、文章を書くことと、レイアウトと整えることが同時にできる、のが非常に利点なのですが、逆に画像がどうのレイアウトがどうの、と気になってしまったときには「著者」の頭に切り替えづらいという欠点があります。
ま、どのようなタイプの本を書くのかというで別かもしれませんが、BlogWrite を使っているときの問題として、
コードを表示するプラグインのタグ [ code]…[/code] を非常に書きづらい、
という大きな欠点があります。今までブラウザ上でちまちま直したり、Windows Live Writer に切り替えてみたりとしたのですが、本来 HTML タグではないものは(当たり前ですが)オフラインのブログエディタが認識しないので、無理といえば無理な話ですよね。
という訳で、もう一度、エディタに立ち返ってみよう、という感じです。
そんな訳で、
1.QX エディタで文章を書く。
2.perl を使って HTML タグに変換([ code]タグなんかは残す)
3.WpPost, WpUpfile のようなツールで wordpress にアップロード
な流れで現在書いています。
ローテクですが、枯れた技術(テキストエディタ、perl)を使うとそれなりに作れますね。コマンドライン版ですがw
~~
wordpres の独自タグを使わずに、<code>…</code>で記述した後に、wordpress 側で Javascript で判別、なんてことでもいいんですけど、プラグイン作成時のお手軽さが失われるのが残念でして。
wordpress の拡張タグのプラグインは非常に簡単にできて、
function manabook_index($attss) {
...
return $links;
}
add_shortcode('manabook_index','manabook_index');
な感じでショートコードを作成して plugins に放り込んでおけば、
記事に [manabook_index] と書いておくだけで、目次に展開してくれるというプラグインが作れます。こっちは別の記事で紹介します。


同じところではまっていましたが、このページのお蔭で助かりました。
base64エンコードしなくてよかったんですね・・・またお邪魔します。