勉強したことのメモ

Webエンジニア / プログラマが勉強したことのメモ。

PHPバージョンアップの際に削除された関数(MySQL関数等)を使う方法

  PHP

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関数を定義する形を取っていた。

 

所感

上記のような形で対応するといった発想は自分には無かったので勉強になった。

あんまり無いケースだとは思うけど似たようなリプレイス案件があった時のために覚えておきたいところ。

 - PHP

  関連記事

PHPでファイル書き込み時に「failed to open stream: HTTP~~」エラー

PHPでファイルを書き込む際に「failed to open stream: H ...

PHP8系で「Uncaught TypeError: Unsupported operand types」エラー対応方法

PHP8系で「Fatal error: Uncaught TypeError: ...

PHPでbool値(true / false)を文字列として出力する方法

PHPにてbool値(true / false)をechoで出力するとtrueは ...

PHPにてサイトにPayPay決済システム及び決済キャンセル機能を実装する方法

ここのところクレジットカード決済関連のメモを書いているが、他の決済方法についても ...

PHPで引数の先頭に&(アンパサンド)をつける参照渡し(リファレンス渡し)について

他社が作成されたPHPのソースコードを拝見していると関数の引数の頭に&( ...