Smartyでescapeができなくなる

PHP+Smarty環境のこと.

通常通りSmartyで {$hoge|escape} を書いたらwarningが出るように.

PHP Warning: htmlspecialchars() expects at most 3 parameters, 4 given

おそらくエラーを表示しないようにしてる場合はescape修飾子がついたところで文字が出力されなくなるはず.

Smartyは3.1.7,PHPは…あれこのサーバ5.1じゃないの.
SmartyのほうでPHP5.2以降対応って書いてあるし,htmlspecialcharsのパラメータが4つになったのは5.2.3からみたいです.

PHP: htmlspecialchars – Manual

そんなわけでPHPの入れ替えをして解決.
まだPHP5.1.xのサーバは多いですからね…要注意.

CentOS6でYour BIOS is brokenと言われる

NEC Express5800 GT110bにCentOS6を導入.
色々とテスト.

・haltしてもリブートしちゃう.
→Wake On LANを切ればいいらしいが,どうせ電源入れっぱなしで落とすことは無いしどっちでもいいやー

・Your BIOS is brokenとか言われる
→起動時に intel_iommu=off をつけると回避できるっぽい.Intel VTとIO関連か.
しかしこれも特に実害はないような?(仮想化使ってないし)
続きを読む

webサーバをlighttpdにしてみる

他のサーバで pound + thttpd + apache という組み合わせを試していましたが
・なんかthttpdが落ちる
・thttpdが落ちるとpoundも引きずられて落ちる(これは設定で回避できそうだけど)
という状況だったので,まぁ実験だしpoundとthttpdをやめてapacheのみにしようかと思いましたが,どうせなのでlighttpdにしてみました.

中身はwordpressのサイトなので,それ用に設定を追加します.

【Lighttpd】WordPressやDooPHPを動かす設定 | SOLAT -DEV- 開発ブログ

CentOS5にrpmforgeリポジトリを追加してあるのでlighttpdとlighttpd-fastcgiをインストール
modules.confで必要なものを有効に.fastcgiも追加.
virtualhostの設定内にurl.rewrite-onceを追加.

$HTTP[“host”] == “example.com”{
server.document-root = “/path/to/www/example.com/wordpress”
url.rewrite-once = (
“^/(wp-.+).*/?” => “$0″,
“^/(sitemap.xml)” => “$0″,
“^/(xmlrpc.php)” => “$0″,
“^/(.+)/?$” => “/index.php/$1″,
)
}

他のサーバでもlighttpdを採用してみたいですが…既にあるapacheの設定を移植するのが面倒だなぁ…
フロントをlighttpd,バックをapacheにして,全体的にlighttpdをリバースプロキシ動作にしたあと,移行できるサイトから順次lighttpdにしていく手もあるか.
多分やらないな…w

SELECTの結果でUPDATEをかける(pgsql/mysql)

DB内で他のテーブルからSELECTした内容でUPDATEを行いたいときがある.
SELECTした内容をINSERTに使うINSERT~SELECT構文みたいなのもあるので,どうかなーと思ったら各DBMS毎に文法が違うのね…

PostgreSQLの場合
オデの日記@WEB系: postgresqlでSELECTした結果でUPDATEをかける
PostgreSQL/SQL/SELECT結果でUPDATE – yanor.net/wiki

UPDATE target_table
SET target_column = s.value
FROM (SELECT * FROM source_table) AS s
WHERE target_table.id = s.id

個人的にはSETとWHEREの間にFROMが入るのが直感的でない…と思う.

MySQLの場合
MySQL/SELECT結果でUPDATEする – 俺の基地
yoko_net Blog : 結合したSELECT結果でUPDATEするTips(for MySQL)

UPDATE target_table,source_table
SET target_table.taraget_column = source_table.source_column
WHERE target_table.id = source_table.id

個人的にはUPDATEの後に両方のテーブル名を並べるのがまぎらわしい…と思う.

NexusOneにCyanogenModとS2E導入

NexusOneは/dataの下が小さい!
何か入れるとすぐ容量低下とか言われる!

そんなわけでapp2sdしてみたい,ということでCyanogenMod7を入れました.
RootedなのでROM Managerから導入してすぐ完了…ではなかった

自分のポイントメモ
・最新のClockworkModRecoveryが入っているように表示されても,直前に再導入したほうが良い
 …なぜかRecoveryが起動できなかった
・cacheとかdataとかwipeしないと起動しない
 …CyanogenModの起動画面がずーっとループしつづけた>Recoveryからwipeしたら起動した
・gappsを導入しないとGoogle系アプリが入らない
 …チェックしてたつもりだけど抜けていた.後から導入でもOK.
 入れておかないとマーケットがないのでいろいろ困る.

[Script/APK] S2E (simple2ext): app2sd for CyanogenMod7 – xda-developers
・ROM ManagerでもSDカードのパーティションを切れるが,最大512MBだったのでヤメ
・ClockworkModRecoveryのAdvancedから操作.2024MB切れる!
・起動後,マーケットからS2Eを導入して設定,再起動で有効になる.

flashだのadobe airだのadobe readerだの入れても内部ストレージの空き容量が100MB以上あります.
microSDHCカードは16GB,class10のものを入れてみましたが,特に問題はなさそうです.