| @WWW

最近、”Product Advertising API PHP4” みたいなキーワードで検索してくる人が多いです。みなさん対応にてんやわんやのようですね。ちょっとググったところ、レンタルサーバーでPHPのバージョンが4の場合、HMACエンコードする方法は見つけられないですね。自宅サーバーならいろいろ手はありそうなんですが。Amazonの仕様変更が原因でPHP 5に移行する人とかもいそうですね。

ところでこういう記事を読みました。

AmazonのAPIは去年、ECS 3.0からECS 4.0に完全移行したばかりなのに、なぜまた一年で仕様を変更するのか不思議だったんですけど、上の記事では

 ブログパーツを使ったクライアント(ブラウザで見てるユーザー)からのリクエストがめちゃくちゃ多いので、対応してらんないよ、というのがほんとのところのような気がしてた。

 もともとは、プログラムを知ってる人が、サイトの構築に役立てるように、という目的が、そうでない一般ユーザーにも使われるようになったのは想定外で、ここまでリクエストが増えると、おいらもやってらんないよ。

 っていうことなんだろうなあ。とか。

 なるべくハードルあげて、リクエストを減らしたい、っていうのが本音なんだろうなあ。とか。

って書かれてました。いままで面倒くさいサーバー側での処理はAmazonがやってたんだけど、これからはクライアント側でも下処理(署名を暗号化して送る)っていう作業が必要になるってことらしい。(あ、JavaScriptとかでアフィリエイトリンク作るツールがダメならectoのAmazon Helperも使えなくなりそうな悪寒。)

リクエスト減らしたらAmazonの売り上げにも響くと思うんですけど、これどうなんだろう。アクセスを綿密に解析した結果、「Webから直で買う人が多いからAPIにかかる負荷を減らしたい、だから負荷ばかりかかるAWSはProduct Advertising APIへ移行!」ってことなんでしょうか。Amazonてスゲー頭のいい人が集まってやってそうなイメージなんで凡人には分からない背景があるのでしょう。

でもAPIの変更でこの手のツール類で使えなくなるものが増えるのは事実です。P_BLOGのISBN変換プラグインについても、今回はAmazonのサンプルコードが公開されてて、コードを数行追加するだけだったので僕でも対応できましたが、これがもっと面倒くさい作業が必要なんだだったらPlug-inの配布やめちゃいそう。レンタルサーバーでPHP 4を使ってる人とかはPHP 5にアップデートするかPHPを使うのやめるかアフィリエイトを諦めるかの三択ですもんね。Amazon、思い切ったことするなーと思った次第です。

| @ブログ

Tribe Called Questの人のことじゃないよ(古)

ToolTip系のPlug-inはブログを作ったばかりの結構最初の頃から長いことArekorePopupを使ってました。透過やtext-shadowが美しいのでいまでも好きなんですけど、SafariがVersion 3.xになってからポップアップの位置がずれるようになった。誰か解決方法をブログに書いてないかなーってずーっと探してたんだけど、なかなか見つからない。

さらに先日、Googleの(Googleとは直接関係ないらしい)Chromiumを試してみたところこちらでもArekorePopupの表示位置がずれる。どうやらこれはSafariに固有の問題じゃなくてWebKit系全般の問題のようだ。

ArekorePopupは長らくバージョンアップとかされてないし、jQueryのプラグインに似たようなやつがあったので思い切って外してみることにした。それがこのqTipってやつです。

qTip jQuery plug-in qTip - The jQuery tooltip plugin - Home -

qTipの特徴はと言いますと、

  • スタイルを簡単にカスタマイズできる
  • 透過pngとか画像を使ってなくて完全にCSSとHTMLだけでスタイリングされてる
  • クロスブラウザなのでIEのこととかなんも考えずに使える
  • ファイルサイズが小さい
  • APIとかが充実しててカスタマイズ魂を刺激する
  • 画像とかHTMLもポップアップで表示できるらしい

text-shadowとか背景の透過表示はできないところがArekorePopupに負けてますが、ToolTip自体の表示位置だとか矢印の表示位置を激しくカスタマイズできるのが結構良い感じです。

ちなみにこのブログでは以下のように記述して使ってます。

$("a[title], img[alt]").qtip( {
	style: {
		padding: 5,
		background: '#191919',
		color: '#FFFFFF',
		title: {
			'font-size': 10
		},
		border: {
			width: 7,
			radius: 5,
			color: '#191919'
		},
		tip: 'topLeft',
		name: 'dark' // Inherit the rest of the attributes from the preset dark style
	},
	position: {
		target: 'mouse'
	}
});

| @技術/プログラミング

クリックした後にしばらく経ってから続きの部分が表示されるだけだとつまらないから、クリックしてから続きが読み込まれるまでの間にローディングgifが表示されるようにしてみた。参考にさせてもらったのはhysyskさんのブログ。

ローディングgifはこちらで作った。

コードはこんな感じ。よかったらどなたか添削してください。

function readMore(x) {  
  
	// format vars
	var id = x.replace("#", "");
	var loadPath = '/article.php?id=' + id + ' div#wrapper div[class=comment entry-content]';
	var rm = x + ' p.read-more a';  
  
	// hide read-more  
	$(rm).hide();  
  
	// write ajax-loader.gif
	$(x).append('<div id="loading" style="text-align: right; position: relative; top: -28px;"><img src="./images/ajax-loader.gif" width="28" height="28" /></div>');  
  
	// show and hide ajax-loader.gif
	$("#loading").bind("ajaxSend", function() {
		$(this).show();
	}).bind("ajaxComplete", function() {
		$(this).fadeOut("slow");
	});  
  
	// load rest of content
	$(x).load(loadPath);  
  
}

| @ブログ

実は密かに別のサブドメインにMovable Typeを設置して、映画の感想をぼちぼち書いてました。このブログのアクセスログを見ると映画の感想はほとんどアクセスがないので、今後は別の場所に分けることにしました。映画専用ブログの方では劇場公開だけでなくDVDで見た映画の感想もわしわし書いていこうと思います。人に見せるためのものっていうより自分で後から「あー、あの映画何だったっけ?」ってときの記憶の引き出しのとっかかりにするために。

そんなブログに興味のある酔狂な方はこちら。

| @技術/プログラミング

はてなダイアリーとかはカテゴリーごとにフィードを生成してて便利だと思ったので真似してみました。たとえば category.php?k=映画 にアクセスしたら、映画のフィードだけにアクセスできる。もう金輪際、僕のチラシの裏的雑記で精神的苦痛を被ることはありません! =-o 読みたいカテゴリーのフィードを選択して時間を有効活用してください。

| @技術/プログラミング

P_BLOGをわさわさいじって、Tagを付けられるようにしました。いや正確には前からTag付けられるようになってたんだけど、P_BLOGのTagは「CategoryをTagっぽく使う」っていうコンセプトなので、WordPressとか他のブログツールのTagの概念とちょっと違った。もともとP_BLOGにはTagはなくて、SafariStandのhetimaさんのハックを取り入れてCategoryをTag代わりに使えるようになっていたわけでした。

Tagはいっぱい付けといた方がいいとは思うんだけど、いままでTagをいっぱい付けまくったので数が260個ちかくになってしまって、こうなると逆に目当ての情報にたどり着くのが難しくなった。そういうわけでTagとは別にCategoryによって記事を大まかに分類しておくと便利だなーと思って、ちょちょっといじってみました。

データベースの `p_blog_log` テーブルのこれまでTagとして使っていた `category` フィールドを `tag` という名前にしてしまい、新たに `category` フィールドを作ってphpMyAdminでテキトーに記事にカテゴリーを割り振りました。その後P_BLOG本体のカテゴリーにまつわる部分をごにょごにょと改造して、TagとCategoryの機能を明確に分けました。要するにコピペして変数名や関数名を書き換えただけなんですけどね。

P_BLOGの後継プロジェクトのLoggix含め世の中には優れたブログツールが沢山ありますが、「自分で欲しい機能をどんどん拡張できる」のはオレオレ仕様のこのP_BLOGだけなわけでして、もう開発は終了していますがオレオレ仕様でどんどん進化して行っております :-) なんかもう主客転倒で、P_BLOGをいじる片手間でブログ書いてるような感じです :-P

| @ブログ

インターネットで文章読んでると、読点の打ちどころが変な人の文章に出会うことありませんか? 僕は結構ある。なんつーか、必要以上に読点打ちまくってる感じの文章。例えばこんなの。

今日は、とてもとても、良い天気でした。

明日も、きっと、晴れるのではないでしょうか?

晴れたら、お弁当をもって、出かけたいものですね。

こういうのすごく冗長に感じる。格助詞や副詞のあとに必ず読点が入れてあるんだけど、必要なくないですか? 読点は本来文章を読みやすくするためのものなのに、逆に読みにくくなってる。

考えてみると、自分自身も子どもの頃は読点を打つのが苦手だった。読書感想文の時間とかマジで憂鬱で、書き出しを

「僕は、『ちび黒サンボ』を読みました」

にすべきか

「僕は『ちび黒サンボ』を読みました」

にすべきかで延々悩んでいたことを思い出します。大学ノートとか、文字の詰め方が自由な用紙に文章を書くときはそんなに悩まないんだけど、原稿用紙の場合は明示的に読点を打たなければならないのでプレッシャーがかかるのだ。

Continue reading...