Latest Publications

charset=gb2312のメールをPHPで処理

中国在住の日本人の方から
charset=gb2312(中国語)で日本語のメールが来て
PHPの処理で文字化けが発生したので対応。

GB2312というコードで変換をしてみたけど一部の文字が化けてしまった。
GBKと指定すればOK。

//mb_convert_encoding($str, "UTF-8", "GB2312");
mb_convert_encoding($str, "UTF-8", "GBK");

手間取ったのが、メールの件名の文字化け。

mb_decode_mimeheader($headerList['Subject']);

の処理で既に文字化けが発生しているので
その後でmb_convert_encodingをしても直らない。

よく見ると、最初にGB2312でコンバートしていたのと同等の文字化けだった。
mb_decode_mimeheaderをかける前を見てみると、この時点でエンコード形式が指定されているよう。
=?GB2312?B?UmU6IM・・・

無理やりだけど、

$headerList['Subject'] = str_replace('GB2312', 'GBK', $headerList['Subject']);

としてエンコード形式の指定をGBKに置き換えたら直った。

tumblrのモバイルテーマ

tumblrで購入したテーマの相談を受けた。

PC向けはトップページがカスタマイズされているが
iPhoneなどで見ると最新記事がいくつか並んでいるだけの表示になるとのこと。

調べると、スマホからのアクエセスは
初期設定ではtumblrデフォルトの
モバイルテーマが適応されるようになっているとのこと。

テーマの詳細設定から「デフォルトのモバイルテーマを使用」がオンになっているのを
オフにすると、通常のテーマがスマホでも表示される。

ただ、そのテーマがスマホ対応していなければ
見にくい/崩れることになってしまう。

その場合、テーマのカスタマイズで「ページの追加」を選択し
「カスタムデザイン」びurlを「iphone-theme」に設定すると
iPhoneなどモバイルからのアクセスで適応されるテーマを設定できる。

テーマを新たに作ることになるが
下記でデフォルトテーマのソース(?)が提供されている。
ただし、どうも古いようなので最新バージョンではなさそう。

orangkucing/Default-iPhone-theme-for-Tumblr · GitHub

イチから作るのも難しいので、このテーマをベースに
カスタマイズして必要な表示にさせた。

tumblrのLoad Moreをjavascriptで動かす

Tumblrで作ったサイトの相談を受けた。

表示記事に対してjavascriptで絞込がされるテーマにおいて
特定のタグに対しては記事が表示されないとのこと。

確認すると、全記事からではなく表示記事中からの絞り込みのようで
「Load More」ボタンを押して
一旦記事を初期表示以上にロードしてからでないと表示されない。

ただ、初期表示の件数に上限があり
それ以上は設定できない。

ということで、
無理やり「Load More」を押したかのような動きを
javascriptでさせることに。

</body>タグの前に

<script type="text/javascript">
$('#more-projects').trigger("click");
</script>

で動いた。

各サーバーのバックアップをAmazon Glacier(S3)に保存する環境を作った

AWSのS3も初使用。

GlacierはS3の約10分の1の価格で使えるデータストレージ。1G・1円/月くらい。
安価な代わりにデータの取り出しには数時間かかる。
バックアップ向け。

AWS コマンドライン インターフェイス

まずはコマンドラインでAWSを操作できるように環境を作る。

AWS コマンドラインインターフェイス | アマゾン ウェブ サービス(AWS 日本語)

Python 2.6.3 or later

python --version

Pythonのパッケージ管理ツール、pipを準備。
まずはダウンロード
get-pip.py

python get-pip.py

pipが使えるようになったらaws cliをインストール

pip install awscli

確認。

aws --version

awsコマンドを試す

まずはAWSの管理画面でS3を使いバケットという大きい単位の入れ物を作る。
また、IDとシークレットキーも取得し、下記コマンドで設定。

aws configure

これでawsコマンドが使えるようになる。

lsやcpやmvなど使い慣れたコマンドが使える。
こんな感じ。

aws ls s3://
aws ls s3://yourbucketname/
aws cp /home/username/test.txt s3://yourbucketname/test.txt
aws mv /home/username/test.txt s3://yourbucketname/test.txt

Glacierの設定

これはAWSの管理画面から。

バケット単位でもフォルダ単位でもできるけど
特定のバケットをGlacier専用に設定。
そのバケットに入ったらすぐにS3からGlacierに移すようにできる。
保存に関してはS3に保存するのと同じ。

cronでの処理

超手間取った。
コマンドで入力したら動くのにcronだとどうしても動かなかった。
原因はconfigファイルが参照できていなかったこと。

シェルスクリプト内に下記を書いたら動いた。
cronの実行ユーザーと合わせる。

export AWS_CONFIG_FILE=/home/username/.aws/config

例えばこんな感じ

export AWS_CONFIG_FILE=/home/username/.aws/config
scp username@servername":~/backup/hoge.gz /home/username/backup/hoge.gz
/usr/local/bin/aws s3 cp /home/username/backup/hoge.gz s3://yourbacketname/hoge.gz

crontabが動かなかった

cronのテストをしていた時に何故か変更したものが反映されない。

タイミングが良くわからなかったので

sudo /etc/init.d/crond restart 

をするようにしたら動いた。

WordPressの新規投稿時のデフォルト設定

管理者権限のユーザーでも新規投稿時にステータスpost_statusをレビュー待ちpendingにしたかったので。

function.phpに追加。

//新規投稿のステータス初期値を「レビュー待ち」にする
function post_function($data){
	//処理
	$data['post_status'] = 'pending';
	return $data;
}
add_filter('wp_insert_post_data', 'post_function');

MacPortsのアップデートでphpエラー

MacPortsのアップデートしたらphpでエラーがでるようになった。

PHP Startup: Unable to load dynamic library '/opt/local/lib/php54/extensions/no-debug-non-zts-20100525/gd.so'

ということで調査開始。

php -ini

でiniファイルを探すと

/opt/local/var/db/php54/gd.ini

ができてた(元から??)ので開いてみると

extension=gd.so

とエラー部分の呼出しがあったので

;extension=gd.so

とコメントしたらエラーが消えた。

ただ、MacPortsが自動で更新するファイルだから
さわっちゃダメよ、と書いてあったファイルなので
また上書きされてしまうんだと思う。

とりあえず、の処置ということで。

iPhoneのSafariでサイト表示が崩れていたのを修正

iPhone5のSafariでサイトの表示確認をしたら
表示がかなり崩れていた。

CSSが適応されていないようだったが
完全にではなく、一部が適応されてにない様子。

MacとつないでWebインスペクタで確認したところ
CSSは読んでいるもののなぜか途中で切れていた。

他のiPhoneやiPadで見るとそんなことはなく
端末の問題として、設定からSafariの
「Cookieとデータを消去」をすると解決。

フレームワークなどでのPHPシステムが重い時の対処

CakePHPで、ローカルではサクサク動くシステムが
サーバーに載せたら対した処理でもない部分で異常に重い。
ページを開くだけで1分以上かかるなど遅すぎ。

原因は単純で、PHPのメモリ設定が小さすぎただけ。
フレームワークはそのページの処理自体は単純でも
共通部分の処理の読み込みなどでそこそこメモリが必要。

ちなみにいつも忘れるのでphp.iniの場所を探すには

php --ini

同じドメインで複数のCakePHP2を動かした時の500エラー

一時的に同じドメインの、メインとサブディレクトリで
別々のCakePHP2を動かす必要が出た。

過去のサーバーでは問題なく動いていたが
同じ構成でも特定のサーバーでだけ500エラーが出る。

それも、どちらか片方だけ。
debugを一度2にすると動くようになるが
そうすると他方がエラーになる。

結局、サブの方のcore.phpに

Configure::write('Cache.disable', true);

を追記して解決。

なぜかキャッシュに同じものを見に行っていたようで
それがエラーの原因だった模様。
片方を、キャッシュそのものをしないようにした。

PHPのバージョンなどが原因かも。