DEVELOPERS BLOGデベロッパーズブログ
- HOME >
- 加藤 正人のデベロッパーズブログ >
- 駅データ.jp のデータを CakePHP から使う
加藤 正人のデベロッパーズブログ
- 氏名
- 加藤 正人
- 役職
- 多分SE
- 血液型
- 秘密
- 出没
- 美味しいもののあるところ
- 特色
- タヒチ大好き。ちょいメタボ。
- 2020/12/15
- CakePHP3 のリダイレクトがうまく行かない例
- 2020/11/12
- Apache Bench
- 2020/10/05
- PhpSpreadsheet でExcel ファイルを読み込む (CakePHP3)
鉄道路線と駅のデータを無償提供してくれている「駅データ.jp」さんのデータを、CakePHP からなるべく簡単に使う方法を考えてみた。
折角だから、CakePHP のキャッシュを使って駅データサーバへのアクセスを減らすようにした。
// // 駅データ.jp API をアクセスするためのクラスとメソッド群 // class EkiDataAccess extends Object { const CacheKey = 'EkiData'; public function __construct() { // 駅データ.jp 用キャッシュキー設定 if ( !Cache::config(self::CacheKey) ) { // EkiData キャッシュが設定されていない場合のみ既定値で設定する。 Cache::config(self::CacheKey, array( 'engine' => 'File', 'duration' => '+7 days', // キャッシュの有効期限は7日 'path' => CACHE . self::CacheKey . DS, 'prefix' => 'ekidata_', )); } parent::__construct(); } // 都道府県 ID で指定された都道府県に所属する路線の一覧を配列形式で返す // 第2パラメータ $full が true の場合は、取得したデータをそのまま配列化して返す。 // false の場合は {路線コード} => {路線名} の連想リストとして返す public function getLinesByPrefId($id, $full=TRUE) { if ( !($result=Cache::read("p_{$id}", self::CacheKey)) ) { $result = Xml::toArray(Xml::build("http://www.ekidata.jp/api/p/{$id}.xml")); if ( !@$result['ekidata']['line'][0] ) { // line 構造が1つしかない場合の処理 $result['ekidata']['line'] = array($result['ekidata']['line']); } Cache::write("p_{$id}", $result, self::CacheKey); } if ( !$full ) { $tmp = array(); foreach ( $result['ekidata']['line'] as $l ) { $tmp[$l['line_cd']] = $l['line_name']; } $result = $tmp; } return $result; } // 路線 ID で指定された路線に所属する駅の一覧を配列形式で返す // 第2パラメータ $full が true の場合は、取得したデータをそのまま配列化して返す。フルデータには路線名情報も含まれている。 // false の場合は {駅コード} => {駅名} の連想リストとして返す public function getStationsByLineId($id, $full=TRUE) { if ( !($result=Cache::read("l_{$id}", self::CacheKey)) ) { $result = Xml::toArray(Xml::build("http://www.ekidata.jp/api/l/{$id}.xml")); if ( !@$result['ekidata']['station'][0] ) { // station 構造が1つしかない場合の処理 $result['ekidata']['station'] = array($result['ekidata']['line']); } Cache::write("l_{$id}", $result, self::CacheKey); } if ( !$full ) { $tmp = array(); foreach ( $result['ekidata']['station'] as $s ) { $tmp[$s['station_cd']] = $s['station_name']; } $result = $tmp; } return $result; } // 駅 ID で指定された駅情報を返す public function getStationDetailByStationId($id) { if ( !($result=Cache::read("s_{$id}", self::CacheKey)) ) { $result = Xml::toArray(Xml::build("http://www.ekidata.jp/api/s/{$id}.xml")); Cache::write("s_{$id}", $result, self::CacheKey); } return $result; } }
使用する場合は CakePHP のコード中で以下のようにする。
App::uses('EkiDataAccess', {配置した場所}); // EkiDataAccess クラスをロードする $ekidata = new EkiDataAccess(); // EkiDataAccess クラスのインスタンスを生成する // 都道府県番号 (1~47) で指定された都道府県に所属する路線の簡易一覧を取得する $line_list = $this->ekidata->getLinesByPrefId({都道府県番号}, FALSE); // 駅データ.jp の路線番号で指定された路線の所属駅の簡易一覧を取得する $station_list = $this->ekidata->getStationsByLineId({駅データ.jp の路線番号}, FALSE);
以上で CakePHP から「駅データ.jp」の路線駅情報をアクセスできる。
2020/12/15
2020/11/12
2020/10/05
2020/09/11
2020/08/03