(一部の)携帯などでcookieを使えない場合にセッションIDをURIに埋め込んで使用する方法が一般的です。
そこで
・cookieを受け付けるときはcookieを使用したセッション。
・cookieを受け付けないときはURI埋め込みを使用したセッション。
を実現します。
php.ini の設定
session.use_cookies = 1 session.use_only_cookies = 0
としてapache をリスタート
apachectl graceful
で準備OK。
後はPHPスクリプト内で
定数SID が存在するブラウザの場合 → cookie使用不可(携帯など)
定数SID が存在しないブラウザの場合 → 通常のWEBブラウザ
で判別できます。
session_start(); if (SID){ // cookieを使えないブラウザの処理 } else { // cookieを使えるブラウザの処理 }
セッションは通常cookieを通してやりとりしますが、cookieを使えないブラウザ
(携帯端末 Docomo Softbank )等でセッション機能を実現させたい場合はセッションIDを
URIに埋め込んで使用することになります。
■ セッションをURLに埋め込んで使用するには以下の記述を行います。
session.use_trans_sid = 1
php_flag session.use_trans_sid On
ini_set('session.use_trans_sid', '1');
ただし
注意: 相対URLでないURLは外部サイトを指していると仮定され、SIDが追加 されません。これは、SIDを外部のサーバに開示することはセキュリティ 上のリスクとなる可能性があるためです。
なので注意
■ セッションに関するパラメータを変更するには phpコード内に以下の記述を行います。
が、通常書き換えなくてもOKです。
//一文字あたりのビット数(4,5,6)数値が大きいほどセッションIDを短くすることが出来る ini_set('session.hash_bits_per_character', 6); //セッションパラメーター名 デフォルト値:PHPSESSID ini_set('session.name', '_SESSID'); //ハッシュ関数 0:MD5(128bits) 1:SHA(160bit) デフォルト値:0 ini_set('session.hash_function', 1);
参考:
http://labs.scyphus.co.jp/memos/php/session
http://www.yc.musashi-tech.ac.jp/~yamada/doc/php/0802.html
http://ke-tai.org/blog/2007/12/12/php_session_new/