PHPバージョンアップの際に削除された関数(MySQL関数等)を使う方法
PHP5系で制作されたシステムを8系でも動くようにリプレイスしてほしいという案件があった。ざっとソースコードを見てみると7系で削除されたMySQL関数が使われているように見受けられた。ただ何故か8系の環境に各種ファイルをアップロードすると正常に動作した。削除された筈の関数が使えている方法を以下にメモ。
ソースコード
<?php if( !function_exists('mysql_connect') ){ function mysql_connect(string $host, string $user, string $pass, bool $new_link = false, int $clinet_flags = 0){ $mysqli_connect = mysqli_connect($host, $user, $pass); return $mysqli_connect; } } if( !function_exists('mysql_set_charset') ){ function mysql_set_charset(string $charset, mysqli $link_identifier = NULL){ return mysqli_set_charset($link_identifier, $charset); } } if( !function_exists('mysql_select_db') ){ function mysql_select_db(string $dbname, mysqli $mysqli_connect){ return mysqli_select_db($mysqli_connect, $dbname); } } if( !function_exists('mysql_query') ){ function mysql_query(string $sql, mysqli $mysqli_connect){ $result = mysqli_query($mysqli_connect, $sql); if( !$result ){ //エラー処理 die(); } return $result; } }
function_existsで関数が定義されているかチェックし、定義されていない場合は独自関数という形でMySQL関数を定義する形を取っていた。
所感
上記のような形で対応するといった発想は自分には無かったので勉強になった。
あんまり無いケースだとは思うけど似たようなリプレイス案件があった時のために覚えておきたいところ。
関連記事
-
PHP5.4系でAPCが上手く動かなかったので5.5にアップデート&Zend OPcache導入
PHP5.3系から5.4系にアップデートしてから、WordPressがちょっと重 ...
-
file_get_contentsを使用する際にタイムアウト設定
20秒に1回自動でリロードするページにて file_get_contentsを使 ...
-
PHPでソーシャル(SNS)ログインする方法2018
久しぶりにソーシャル(SNS)ログインを実装する機会があった。以前に対応方法を書 ...
-
MySQLでランダムにデータを取得しつつページング機能も実装する方法
MySQLからデータを持ってくる際にランダムな表示を行ってほしいと言われた。ただ ...
-
CodeIgniter4でコントローラ実行の前後に指定したイベントを実行する方法
CodeIgniter4で特定の条件の場合は指定したページにリダイレクトさせたい ...