ふたりはララベル (Laravel PHP Framework)

PHPフレームワークのLaravelの体験記を書いていきます。こんなタイトルのブログですが萌え系アニメは一秒たりとも観たことがありません。

WindowsのXAMPP環境にMonicaをインストールする

WindowsのXAMPP環境にMonicaをインストールする。 phpが7.1以前の場合 https://pecl.php.net/package/libsodiumからdllをダウンロードする。 php.iniにextension=php_sodiumを追記する。 phpが7.2以降の場合 sodiumが入らないので、諦めてcomposer.jsonから…

xampp環境でLaravel Backup

「spatie/laravel-backup」をxampp環境で使うときには、config/database.phpも編集する。 'mysql' => [ 'driver' => 'mysql', 'url' => env('DATABASE_URL'), 'host' => env('DB_HOST', '127.0.0.1'), 'port' => env('DB_PORT', '3306'), 'database' => env(…

Laravel Excelでエクスポート時にヘッダをつける

Laravel Excelでエクスポート時にヘッダをつけることができる。「WithHeadings」を追加してから、「headings()」メソッドに配列でヘッダの内容を書くだけです。

HumhubをSafariで使ったときの漢字確定のバグを解消する

HumhubをSafariで使うと、日本語入力でEnterキーを押すと必ず改行になる。これを解消するためにkeyCode = 229のチェックを追加した。 function inOrNearComposition(view, event) { if (view.composing) { return true } // See https://www.stum.de/2016/06…

Humhubで日本語入力ができない件を解決する

HumhubのrichtextエディターはWebブラウザから日本語入力ができないんだけど、解決方法があった。ファイル「protected\humhub\modules\content\resources\js\humhub.ui.richtext.prosemirror.js」の RichTextEditor.prototype.focus = function() { this.edi…

Laravelで定数を使う

「constants.php」を適当な場所に置く。 #app/constants.php

Humhubの「ハンドラが見つかりません」エラー

こういうエラーがたまにでる。 最後の操作を処理中にエラーが発生しました。 (ハンドラが見つかりません)。これは「設定→Advanced→キャッシュ→保存してキャッシュクリア」で解決する。

HumHubの操作マニュアル(随時更新)

「いいね!」してくれた人を調べる 「いいね!」の人数をクリックしてください。パソコンの場合はマウスオーバーだけでもわかります。

HumHub 1.3リリース

HumHubが1.3になったんだけど、Cron設定がちょっと変わった。yii cronは一つになり、yii queueが増えた。 * * * * * /usr/bin/php /path/to/humhub/protected/yii queue/run >/dev/null 2>&1 * * * * * /usr/bin/php /path/to/humhub/protected/yii cron/run…

HumHubに投稿する画像のサイズを小さくする

HumHubは投稿画像を小さくしてくれないので、5MBの写真をアップするとそのままアップロードされる。まず画像を小さくする関数を作って tempName; $options = [ 'width' => 400, 'height' => …

HumHubでプロフィールを非表示にする

HumHubでは管理者画面で一個ずつプロフィールを非表示にできるんだけど、それを一挙にやる。このコードをどこかで実行すればいい。 $fields = \humhub\modules\user\models\ProfileField::find()->all(); $visibles = ['firstname', 'title']; # 非表示にし…

Humhubメモ

設定ファイルの場所 「protected\config\dynamic.php」になる。これとDBを消せば初期化となる。 推奨モジュール 「Humhub Updater」は入れて置いたほうがいい。アップデート作業を自動化してくれる。

humhubでCSSを追記する

humhubでオリジナルなCSSを追加したい。編集するファイルは humhub\protected\humhub\assets\AppAsset.php

Humhubでダッシュボードに書き込みを置く

Humhubでダッシュボードに書き込みを置いてみた。 編集するのは humhub\modules\dashboard\views\dashboard\index.php

環境変数を使わずにopenssl_pkey_newを使う

Windows+Xampp環境だと、openssl_pkey_newが動かない。いろいろ設定頑張れば出来そうだけど、下記のようにソースコードにフルパス書けば成功することに気がついた。 $res = openssl_pkey_new([ 'config' => 'D:\xampp\apache\conf\openssl.cnf', 'digest_al…

xserverでは、shell_execの一部が動かない

謎の仕様。Xserverではshell_execは使える。ところが shell_exec('php -v')を使うとプロセスが返ってこないし、 shell_exec('python -V')だと結果がNULLになる。この仕様のせいで、friendicaが使えなくて困った。

Xserverにgitをインストールする

ググった情報のコピペだけでは出来なかったよ。まず wget https://github.com/git/git/archive/master.zipはOpenSSLのバージョンの関係で失敗するので wget https://www.kernel.org/pub/software/scm/git/git-2.17.0.tar.gzにした。ところがmakeが出来なかっ…

CentOSの構築メモ

yum install --enablerepo=remi,remi-php71 php-mysqlnd yum install --enablerepo=remi,remi-php71 php-posix

Excelの書式を全て削除するマクロ

Excelで書式が増えすぎた場合は手で削除するのはムリ。マクロで一気に消しましょう。 Sub Excelの書式を全て削除() Dim myStyle As style On Error Resume Next For Each myStyle In ActiveWorkbook.Styles If Not myStyle.BuiltIn Then myStyle.Delete End …

PHPがThread Safeなのか?x86なのか64なのか?

こうすりゃわかるのか。 >php -i|find "Thread Safety" Thread Safety => enabled >php -i|find "Architecture" Architecture => x86

humhubをWindowsにインストールする

PHP

PHPのSNS、どれを使うか悩んでいる。OXWALLは実際に運用したけど、すごく使いにくかった。Minds、Movimもイマイチ。Elggはバージョン3が中々出ない。というわけでhumhubにチャレンジ。Yiiフレームワークはあまり好きじゃないんだが…。 バージョンの注意事項…

LaravelでPHPUnitを使ってNo tests executed!

Laravel5.4でPHPUnit6を使ったときに「No tests executed!」が出る。Laravel5.4はPhpunit6に対応していないので、vendor内にあるphpunitを使うと解決できる。 php vendor\phpunit\phpunit\phpunit

Image source not readableの対処

大きな画像を送って「Image source not readable」が出た場合はphp.iniの「upload_max_filesize」の値を大きくすれば対処できる。

storeとupdateで共通で使えるバリデーション

storeとupdateでバリデーションを共通化したいけど、updateの時だけユニークチェックしたい。という時の書き方。あまりキレイじゃないね。。。 public function valid() { $validator = \Validator::make($this->toArray(), [ 'code' => 'required|max:255',…

Requestに値を入れてテストする

コントローラーをテストする時にRequestの変数に値を入れる。 $request = new Request; $request->merge([ 'name' => 'testname', ]); $controller = new \Lb\Http\Controllers\TitleController($request); $controller->update($request, 100); $title = Ti…

長くなったLaravelのModelを分割

長くなったLaravelのModelを分割する方法の一つとして、私は上位モデルを使うときがある。 Titleモデルのうち、Updateに関する機能を独立させるときはこんな感じ。テーブル名を指定するのがポイント。 class TitleUpdate extends Title { protected $table =…

PostgreSQLで大文字小文字検索

「iLIKE」を使えば、PostgreSQLで大文字小文字関係なく検索できる。 Mymodel::where('name', 'iLIKE', $name)->first();

Laravel5.3のログインをメールアドレス以外にする

Laravel5.3で、またやり方が変わったみたい。編集対象のファイルは App\Http\Controllers\Auth\LoginController.php public function username() { return 'username'; }

XserverではOwncloud9以降がインストールできない

XserverではOwncloud9以降がインストールできなかった。libxml2のバージョンが低いから。これは困った。しょうがいないからOwncloud8を使うしかないんだけど、Owncloud8だとPHP7に対応していない。つまりXserverのPHPが7以上にあげられないのだ。

Laravel5.2からコンテナ登録方法が変わった

古い書き方 $this->app['myapp'] = $this->app->share(function($app) { return new Myapp; }); 新しい書き方 $this->app->singleton('myapp',function($app) { return new Myapp; });