勉強したことのメモ

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で動画を出力する方法

Webページ上で動画ファイルを再生したい場合、通常だとブラウザのソースコード上に ...

PHPで土日祝日及び営業時間を考慮した上で翌○営業日を計算する方法

PHPで翌○営業日を計算したい。例えば本日が2021/04/15で翌5営業日を計 ...

PHP7.4でAPCuとOPcacheをインストールする方法

先日本ブログのサーバをCentOS6系から7系に移行し、その際にMySQLのバー ...

PHPとPAY.JPを用いてサイト内にクレカ決済及びキャンセル機能を実装する方法

先日PHPとStripeを用いてサイト内にクレカ決済及びキャンセル機能を実装する ...

PHPでURLを解析してクエリ(GETパラメータ)を抽出する方法

formからGETで送信したクエリ(パラメータ)を、受信した側で抽出し、キーと値 ...