【Laravel】migrateで『Class ‘CreateFoooTable’ not found』が発生する

■環境

Laravel 5.1


Laravelの「migrate:rollback」や「migrate:refresh」をしようとして
『Class ‘CreateFoooTable’ not found』というエラーが発生した際の解決方法です。

この事象はmigrateで利用する「/database/migrations」ディレクトリに配置されているファイルが
autoloadされていない事が原因のようです。

解決するにはプロジェクトのrootディレクトリにて以下コマンドを実行し、autoloadを再編成します。

composer dump-autoload

※composerインストールについてはコチラ

もしサーバにcomposerを入れられない場合は作業PCにて上記コマンドを実行すると
「/vendor」ディレクトリ配下が更新されるのでサーバにアップロードしてください。

以上。

Share

【PHP】Laravel5でカスタムバリデーションを追加する

Laravel5でカスタムバリデーションを追加した際の手順です。

■環境
Laravel 5.1

まず、サービスプロバイダーを作成して、バリデーションルールを記載します。
例えば以下のルールの社員番号があったとします。
・頭文字は「A」または「Z」
・2文字目以降は数字6桁

このバリデーションルールを『shainbangou』という名前のルールで登録するとこうなります。
【/app/providers/ValidatorServiceProvider.php】

namespace App\Providers;

use Illuminate\Support\ServiceProvider;
use Validator;

class ValidatorServiceProvider extends ServiceProvider
{
    public function boot()
    {
        Validator::extend('shainbangou', function($attr, $value, $param) {
            return preg_match('/^[A|Z][0-9]{6}$/', $value);
        });
    }
}

次にエラー文言の設定をします。
viewにて社員番号はempIdという変数名で設定されているとします。
【/resources/lang/ja/validation.php】

return [
〜〜 省略 〜〜
    'custom' => [
        'empId' => [
            'shainbangou' => '社員番号が間違っています。(A/Z + 数字6桁).',
        ],
    ],
〜〜 省略 〜〜
    'attributes' => [
        'empId' => '社員番号',
    ],
];

これで、コントローラなどのバリデーション処理で新ルール「shainbangou」が使えるようになります。

Share

zabbixでPHPの警告が出る場合の対処

■環境
zabbix 3.2
PHP 7.1

PHP7.1でzabbixを動かすと、以下の警告が出ました。

A non well formed numeric value encountered [zabbix.php:21 → require_once() → ZBase->run() → ZBase->processRequest() → CView->getOutput() → include() → make_status_of_zbx() → CFrontendSetup->checkRequirements() → CFrontendSetup->checkPhpMemoryLimit() → str2mem() in include/func.inc.php:410]
A non well formed numeric value encountered [zabbix.php:21 → require_once() → ZBase->run() → ZBase->processRequest() → CView->getOutput() → include() → make_status_of_zbx() → CFrontendSetup->checkRequirements() → CFrontendSetup->checkPhpPostMaxSize() → str2mem() in include/func.inc.php:410]
A non well formed numeric value encountered [zabbix.php:21 → require_once() → ZBase->run() → ZBase->processRequest() → CView->getOutput() → include() → make_status_of_zbx() → CFrontendSetup->checkRequirements() → CFrontendSetup->checkPhpUploadMaxFilesize() → str2mem() in include/func.inc.php:410]

警告が出ている箇所は以下のようになっています。
[/usr/share/zabbix/include/func.inc.php]

 394 /**
 395  * Converts strings like 2M or 5k to bytes
 396  *
 397  * @param string $val
 398  *
 399  * @return int
 400  */
 401 function str2mem($val) {
 402         $val = trim($val);
 403         $last = strtolower(substr($val, -1));
 404
 405         switch ($last) {
 406                 case 'g':
 407                         $val *= 1024;
 408                         /* falls through */
 409                 case 'm':
 410                         $val *= 1024;
 411                         /* falls through */
 412                 case 'k':
 413                         $val *= 1024;
 414         }
 415
 416         return $val;
 417 }

この引数の「$val」には『256M』のように単位付きの数字が入ってくるようで、
それを『$val *= 1024』と数字のように扱っているので警告が出ているようです。
(警告は出ているが、処理自体は正常に行なわれている)

解決策は色々あると思いますが、とりあえず以下のように修正したら
警告は表示されなくなりました。(404行目を追加しています)

 401 function str2mem($val) {
 402         $val = trim($val);
 403         $last = strtolower(substr($val, -1));
 404         $val = intval($val);
 405         switch ($last) {
 406                 case 'g':
 407                         $val *= 1024;
 408                         /* falls through */
 409                 case 'm':
 410                         $val *= 1024;
 411                         /* falls through */
 412                 case 'k':
 413                         $val *= 1024;
 414         }
 415
 416         return $val;
 417 }
Share

PHPExcelの使い方メモ

PHPでExcelを生成できる『PHPExcel』の使い方メモ
※実際に私が使ったものをメモしているだけなので、機能を網羅している訳ではないです。かしこ。

インストールはcomposerを使うか、圧縮ファイルをダウンロードしてきて
適当なディレクトリに解凍します。
あとは以下をrequireするだけ。
/格納したパス/PHPExcel/Classes/PHPExcel.php
/格納したパス/PHPExcel/Classes/PHPExcel/IOFactory.php

実際のソースコードは以下の通り

/**
 * PHPExcelの新規オブジェクト作成
 */
$excel = new PHPExcel();

/**
 * シートを作成してシート名を変える
 */
$sheetIndex = 0; // シート番号は0から
$excel->setActiveSheetIndex($sheetIndex);
$sheet = $excel->getActiveSheet();
$sheet->setTitle('SampleSheet01');

/**
 * セルにデータを入力する
 */
// 基本的な入力
$rowCnt = 1; // 行番号は1から
$clmCnt = 0; // 列番号は0から
$text = 'セルに書き込む内容だよ';
$sheet->setCellValueByColumnAndRow($clmCnt, $rowCnt, $val);

// 文字列型で入力
$rowCnt++; // 1行下に移動
$clmCnt++; // 1列右に移動
$text = '000001'; // 文字列型にしないと、左記は「00001」ではなく「1」になってしまう
$sheet->setCellValueExplicitByColumnAndRow($clmCnt, $rowCnt, $val, PHPExcel_Cell_DataType::TYPE_STRING);

/**
 * セルの書式設定
 */
// シートのデフォルトフォントを設定する
$sheet->getDefaultStyle()->getFont()->setName('MS Pゴシック')->setSize(11);

// 背景色を設定
$bgcolor = '000000'; // 16進数で指定
$sheet->getStyleByColumnAndRow($clmCnt, $rowCnt)->getFill()->setFillType(PHPExcel_Style_Fill::FILL_SOLID);
$sheet->getStyleByColumnAndRow($clmCnt, $rowCnt)->getFill()->getStartColor()->setRGB($bgcolor);

// 文字色を設定
$fontcolor = 'FFFFFF'; // 16進数で指定
$sheet->getStyleByColumnAndRow($clmCnt, $rowCnt)->getFont()->getColor()->setARGB($fontcolor);

// 太字にする
$sheet->getStyleByColumnAndRow($clmCnt, $rowCnt)->getFont()->setBold(true);

// セル(行列番号指定)の上だけに罫線(二重線)を引く
$sheet->getStyleByColumnAndRow($clmCnt, $rowCnt)->getBorders()->getTop()->setBorderStyle(PHPExcel_Style_Border::BORDER_DOUBLE);
// セル(レンジ指定)の周り全てに罫線(単一線)を引く
$sheet->getStyle('A1:B3')->getBorders()->getAllBorders()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);


// 列の幅を指定する
$sheet->getColumnDimension('A')->setWidth(14.5);
// 列の幅を自動調整する(※これで効くはずなんですが、効かない事が多々ある)
$sheet->getColumnDimension( PHPExcel_Cell::stringFromColumnIndex($clmCnt))->setAutoSize(true);

以上

Share

brewインストールでphp-mcryptがインストールできない

■環境
OS X El Capitan(10.11.6)
Homebrew 0.9.9

brewインストールでphp-mcryptをインストールした際にエラーが出たので
エラー内容と、その対応をメモしておきます。

まず、エラー内容について
# brew install homebrew/php/php70-mcrypt
〜中略〜
/usr/local/opt/php70/bin/phpize: line 61: /usr/local/Library/Homebrew/shims/super/sed: No such file or directory
/usr/local/opt/php70/bin/phpize: line 62: /usr/local/Library/Homebrew/shims/super/sed: No such file or directory
/usr/local/opt/php70/bin/phpize: line 63: /usr/local/Library/Homebrew/shims/super/sed: No such file or directory
Configuring for:
PHP Api Version:
Zend Module Api No:
Zend Extension Api No:
/usr/local/opt/php70/bin/phpize: line 155: /usr/local/Library/Homebrew/shims/super/sed: No such file or directory
autoheader: error: AC_CONFIG_HEADERS not found in configure.in
〜中略〜

つまり、phpizeで利用している『/usr/local/Library/Homebrew/shims/super/sed』が無いそうです。
色々調べた結果、私の環境ではそもそもHomebrewのパスが
『/usr/local/Library/Homebrew』
ではなく
『/usr/local/Homebrew/Library/Homebrew』
となっていました。(なんだこの階層)

対応としては、phpize内にて$SEDという変数に上記パスを指定していたので、
自分の環境に合わせてパスを書き換えました。
SED="/usr/local/Homebrew/Library/Homebrew/shims/super/sed"

Share