PHP関連のことを調べてみた2021年11月27日

PHP関連のことを調べてみた2021年11月27日
目次

WSL2のubuntuにapacheとphpをインストールしてバージョン管理

この記事は、zennに書いた [WSL2のubuntuにapacheとphpをインストールしてバージョン管理](https://zenn.dev/sakots/articles/a4217c84e10a41) のコピーです。

さこつです。無事退職しました。

XAMPPのアップデートめんどくさい!でも自分のPC環境でphpのバージョン管理したい!!と試行錯誤した結果、
WSL2のubuntuにapacheとphpをインストールすることになったお話。

## ubuntuのapacheならラクそう

こういう記事があった。[ubuntu20.04.1 phpのバージョンを切り替える](https://mebee.info/2020/08/17/post-16891/)

## そうだ、WSL2のubuntuにapacheを入れて管理しよう

### 1.上記をもとにphpをインストール

ただし、2021年11月27日時点でphp8.1をインストールするとapacheが503エラーで動かなくなるので注意。
7.3、7.4、8.0くらいにしとく。

その後、apacheインスト

元記事を表示

PHP で .txt ファイルから文字列を読み取り、配列に変換し表示させる

プログラミング初心者の Qiita 初投稿なのでヘタクソな文面、ご了承ください。

PHP を習いたてで、下記のような流れで制作していて少しつまずいた点を書いていきます。
1. 「post.php」というファイルで form を作成し「write.php」へ送信
2. 「write.php」から「data.txt」へデータを書き込み
3. 「data.txt」のデータを「read.php」というデータで読み取り

今回詰まったところは上記 3 の手順です!
ということで自分が詰まって、解決まで数時間かかった超しょぼいオチをご覧ください。

まず、「data.txt」は以下のデータが入っております。

“`
2021-11-25 06:37:41,たけし,a@g.com,29
2024-6-09 12:08:26,まさる,aghf@aggaag.com,40
“`

左から順に「日付, 名前, メールアドレス, 年齢」です。
今回は 2 人がフォームを送ってくれたので、 2 行です。

はい、そして僕が最初に書いたのはこちら ↓

“`cpp

元記事を表示

【Laravel】画像保存処理実行時のエラー対処

###Laravelで画像保存処理を実行中、遭遇したエラーと対処法をまとめました。

##開発環境
* PHP7.4
* Laravel6
* Bootstrap4.4
* Docker20.10.8

##前提
* 画像保存処理は実装済み
* テーブル作成・マイグレーション実行済み
* バリデーション実装済み
* フォーム作成済み
* プレビュー表示処理実装済み(JavaScript)
* `Intervention Image` インストール済み
* `public artisan storage:link` 実行済み

##❗注意
:::note warn
コマンドをコピペして実行する際、コマンドの最後に余分なスペースが入らないよう注意しましょう。
コマンドが強制実行される場合があります。実行の際は慎重に。
:::

##目次
>1. 画像が正常に保存されない。
2. GD Library extension not available with this PHP installation.解決

##1. 画像が正常に保存されない。
* フォームをクリックして拡張子`.JPEG

元記事を表示

LaravelのEloquentに $fillable でなく $guarded を使う

# はじめに

今回はEloquentの **$fillable** 指定についてです。
基本的に **$guarded** を使う方が良いと思っているのでそれについて簡単に書いてみようと思います。

# **$fillable** と **$guarded**

## $fillable

**$fillable** は指定したカラムのみ、create()やfill()、update()で値が代入される、所謂ホワイトリストです。

“`php

元記事を表示

LaravelのAuth機能でログアウト後の遷移先を変更したい

# はじめに
LaravelのAuthを使用してログイン機能を実装。
ログアウト後の画面を”/home”ではなく”/”に変更したい。

# 実装内容
LoginControllerへ以下を追記しました。

“`PHP:loginController
protected function loggedOut(\Illuminate\Http\Request $request)
{
return redirect(“/”);
}
“`

# おわりに
すごく簡単でした。。
Laravel本当に便利すぎます。。
もともと、loggedoutは実装されてませんでしたが、/homeへリダイレクトされるようになってるんですね
どのような補完をおこなっているんでしょうか

元記事を表示

HumHubの検索にApacheSolrを使わせてみる(前編)

#はじめに
HumHubには標準で検索機能がついてはいるものの、検索はコンテンツ本文、タグ、トピックに対する単語の列記でのAND検索、可能なフィルタは情報ソースのタイプ(種類:スペース名かユーザー名かコンテンツか)とスペースの絞り込みの対応である。このままでも使えなくはないのだが、将来、ウェブサーバーの冗長化に対応できるようにすることをモクロミ、全文検索システムサーバーを別に立てて利用することを検討する。

#調査
HumHubでは、そのプロフェッショナルバージョン(有料)で、HumHub謹製Solrプラグインを追加利用できる。お金とHumHubを信じる心があるときはそれを使えばよいだろう。

いずれも持ち合わせない金銭的にも心も貧しい私のような人は、Solrに接続してクエリを投げて回答を得られる機能を持つプラグインを、自前で作ればよいのだ。その方向で調査を続行した。そう、私は心が貧しい・・・。

####HumHubの検索機能
HumHubはDBにMysqlを使っているので、Mysqlの全文検索機能を使っているのかと思ったが、違った。
(参考)
https://tech.bita.j

元記事を表示

11月25日の学習

本日はテックアカデミーの最初のメンタリングがありました。
その中でQiitaというサービスをメンターさんから教えてもらい、始めました。
現在はレッスン9のチャプター2まで進んでいます。

これから毎日学習報告をさせていただければと思います。
気づいたことや感じたことを逐一書いていきます。初心者ですが、よろしくお願いします。

本日の進捗
テックアカデミー
レッスン8の課題に取り組みクリア
My SQLの学習に入る。

今日はレッスン8の課題に取り組みましたが、nl2brの関数に手こずったり、h3タグをtableに入れてしまうというミスがありました。もう一度bootstrapのカリキュラムを見直ししたりしないといけないなと感じました。

これからひとまず25分のポモドーロ・テクニックで集中力を切らさないように学習していきたいです。

明日からMySQLの学習に入ります。また新しいことですが、一生懸命頑張りたいと思います。

元記事を表示

WordPressで記事のタグ名を取得するショートコードを作成

WordPressで記事のタグ名を取得するショートコードを作成しました。

## 目的

WordPressで全記事に共通して表示されるキャッチコピーやマイクロコピー、固定の文言をより具体化したいと考えたため。

例)
Pythonの解説記事、PHPの解説記事、Javaの解説記事といった風に言語ごとに記事のタグが設定されているサイト構造の場合。

>[タグ名(PHPなど)]に関して分からないことがありましたらお問い合わせフォームへ。
[タグ名(PHPなど)]で困ったらこちらのプログラミングスクールがおすすめです。

といた風に表記内容を具体化できる。

## 作成方法

### 1. タグ名を取得するPHPファイルをテーマ内に作成

まずはタグ名を取得するためのPHPファイルをWordPressテーマ内に作成します。

“`php:get_tag_name.php

元記事を表示

ポーリングによる状態チェックを軽量化した話

# はじめに

__注・最初っからそうしとけよ、という話です。__

研修で使うようなゲームっぽいプロダクト(ゲームマスター:プレーヤー=1:n)で、双方が行った操作(データ変更)をお互いにある程度リアルタイムで検知するために、ポーリングを用いて定期的にチェックすることで実現していました。

ポーリングを用いたのは下記の理由によります。

* push型が理想だがミドルウェア構成をシンプルにしたかった
* 仕組みも簡単だし確実
* DBの問い合わせも軽そうなので負荷もそれほどではないだろう(甘かった)

# 現実に全力で殴られる

さていざ実戦投入してみると、数十クライアント程度でCPUがパンパンになって、ロードアベレージが100近くまで行きました。

DBを外に出したり、ポーリング間隔をあけたりしましたが、劇的な効果は得られませんでした。

(php-fpmがアイドリングでもなぜかCPUを食いっぱなしになるという現象もあったのでそれも一因かもしれません。これはstraceで真面目に調べようと思ったら突如再現しなくなりました。)

# 反攻に出る

これは根本的に対策せねばなるまいとい

元記事を表示

いろいろな言語でAPIコールするよ!

## 導入
webAPIの叩き方を各言語でまとめました。
後で見返す用です。
2021年11月23日時点:Postリクエスト送信

### json リクエストのサンプルパラメータ

“`python
sample_endpoint = “http://localhost:8888/sample”
sample_parameter = {
“title”: “トマトスープ”,
“making_time”: “15分”,
“serves”: “5人”,
“ingredients”: “玉ねぎ, トマト, スパイス, 水”,
“cost”: “450”
}
“`
### Curl
“`terminal
curl –location –request POST ‘http://localhost:8888/recipes’ \
–header ‘Content-Type: application/json’ \
–data-raw ‘{
“title”: “トマトスープ”,
“making_time”: “15分”,

元記事を表示

ループ処理、switch文、break文、continue文の組み合わせには要注意(迷子になるから)

まずは以下のプログラムを見ていただきたい。
※このプログラム自体に意味はありません。参考用にサンプルで作ったものなので、ツッコミどころはいっぱいありますが、一応動きます。

“`php:sample.php
1, ‘type’ => 1, ‘col1’ => ‘1-col1’, ‘col2’ => ‘1-col2’, ‘col3’ => ‘1-col3’, ‘col4’ => ‘1-col4’],
[‘id’ => 2, ‘type’ => 0, ‘col1’ => null, ‘col2’ => null, ‘col3’ => ‘2-col3’, ‘col4’ => ‘2-col4’],
[‘id’ => 3, ‘type’ => 2, ‘col1’ => ‘2-col1’, ‘col2’ => ‘2-col2’, ‘col3’ => ‘2-col3’, ‘col4’ => ‘2-col4’]
];

function fileterData(array $data)
{
$res

元記事を表示

PHP 配列に値があるかチェックするメソッド

# 目的

– 配列に値があるかチェックする`in_array()`メソッドの使い方を簡単に紹介する。

# 情報

– 下記のサイトを用いてこちらに記載するソースの検証を実施した。
– [https://paiza.io/ja](https://paiza.io/ja)

# 方法

– 下記のように`in_array()`メソッドを用いて値があるかチェックする。(第三引数でtrueを渡すとデータ型も含めて評価してくれる。)

“`php
in_array(探したい値, 配列, true);
“`

# 例

– 下記のようにソースを記載して実行してみる。

“`php

元記事を表示

PHP 大文字 小文字を区別せずバイナリを使って文字列を比較するメソッド

# 目的

– PHPにてバイナリを用いて文字列を比較する方法をまとめる

# 情報

– 下記のサイトを用いてこちらに記載するソースの検証を実施した。
– [https://paiza.io/ja](https://paiza.io/ja)

# 方法

– `strcasecmp()`メソッドを使用して比較する。
– ASCII文字だけが、大文字小文字を区別せず比較されるらしい。
– `$str_1`と`$str_2`をそれぞれ比較してみる。
– `$str_1`には「aaa」を、`$str_2`には「AAA」を格納し下記のように比較してみる。

“`php

元記事を表示

Apacheで特定のディレクトリについてPHPを無効にする

以下の設定を\ディレクティブ内に記載する。

“`apache:httpd.conf

php_value engine off

“`

有効にしたい場合は

“`apache:httpd.conf

php_value engine on

“`

より深い階層の設定が有効になるので、上記の組み合わせで「全体で無効、特定のディレクトリで有効」という設定も可能。

ちなみに以下のように記載するという記事もあったが、自分の環境ではうまく動かなかった。

“`apache:httpd.conf

RemoveType .php

“`

元記事を表示

[500 server error]Mac再起動後にSQLに接続できず、Laravelのプロジェクトをローカル環境で確認できなくなった時

以前作成したLaravelのプロジェクトの修正を行おうとしていつも通りMAMPを起動してブラウザで表示しようとしたら、、、
![スクリーンショット 2021-11-24 16.23.21.png](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/2292175/3cc6c7e2-64a6-d982-1dd8-9d8dd8ee0c60.png)
~~もういやだ~~
独学者にはこういうのが一番効きます。

#開発環境

“`
$ sw_vers
ProductName: macOS
ProductVersion: 11.6
BuildVersion: 20G165
$ mysql –version
mysql Ver 14.14 Distrib 5.7.35, for osx10.16 (x86_64) using EditLine wrapper
$ php artisan –version
Laravel Framework 6.20.30
“`

#解決手順

とりあえず.envのデバッグ設定をオン

元記事を表示

CodeIgniter3でViewファイルをもとにHTMLファイルを出力する

こんなこと誰かがやってそうなもんですけど、全然記事が見つからないので
自分で実装することにしました。~~今更こんな枯れたフレームワーク使ってるとこないか~~
もっと良い方法あったら教えてちょ

“`bash
# ファイル出力テスト用のディレクトリを作成して書き込み権限を付与
mkdir /var/www/html/test/
sudo chmod -R 777 /var/www/html/test/
# ファイル出力テスト用のControllerを作成
touch /var/www/html/admin/application/controllers/tools/View.php
# ファイル出力テスト用のViewを作成(レンダリングにはTwigライブラリが必要です)
touch /var/www/html/admin/application/views/user/test/hello.twig.html
“`

“`php:/var/www/html/admin/application/controllers/tools/View.php

元記事を表示

【Laravel・PHP】preg_match(): Unknown modifier ‘�’ のエラー

## 状況
正規表現を用いて、文字の検索をかけたいのでpreg_matchを使ったところタイトルのエラーが発生。
## コード

“`php
$target = ‘/’ . $request->name . ‘/’;
$names = $collection->filter(function($value) use ($target){
return preg_match($value[‘name’], $target);
});
“`
## 原因
preg_matchの第一引数と第二引数を逆に記述したことによるエラー。
本来は第一引数に正規表現、第二引数に元データを記述しなくてはならない。

“`php
return preg_match($target, $value[‘name’]);
“`
とっても単純なエラーでした。

元記事を表示

【Laravel】多次元配列のデータにキーワード検索をかける方法

## 背景
キーワード検索でcontroller側でDBにアクセスしてデータを取得する処理はよく行われるが
今回は既に出来上がった多次元配列の変数にキーワード検索を行い、View側に返す処理を実行します。
## 処理概要
View側で部署検索フォームに文字を入れた際に部分検索で該当するデータを返すようにします。
## 処理内容
preg_matchとCollectionクラスのfilterメソッドを使用します。
【多次元配列のデータ】

“`php
$departments = [
[‘name’ => ‘佐藤’, ‘department’ => ‘営業部’],
[‘name’ => ‘鈴木’, ‘department’ => ‘総務部’],
[‘name’ => ‘田中’, ‘department’ => ‘人事部’],
];
“`
処理。検索キーワードは`$request->department`に入ってる事とします。

“`php
$collection = collect($departments);
$target = ‘/’ . $request->

元記事を表示

DatadogAgentとアプリケーションをCloud Runに同居させる

## 要約
– Cloud Runで動くPHPアプリケーションのAPMをDatadogに送信したい
– supervisordを使ってコンテナ内にDatadogAgentとApacheを同居させた
– supervisordのEventListener機能を使って、”Apacheの終了=コンテナの終了”を実現した

## 経緯
弊社のプラットフォーム事業本部ではDatadogの利用が進められています。
パフォーマンスの可視化を進めるために、私のいるチームが持っているPHPアプリケーションも、
Datadogに対応してAPMを送信できるようにしようとしています。
PHPアプリケーションはApacheモジュールとして動作する形になっていて、
GCPのフルマネージドなCloud Run上で稼働しています。

さて、Cloud Run上で動くアプリケーションのAPMを取るための方法としては、
[公式ドキュメント](https://docs.datadoghq.com/ja/integrations/google_cloud_run/)にこのような記述があります。

> 注: この機能は、Goo

元記事を表示

PHPフルスクラッチでWebアプリ作成

# はじめに
マイペースに開発を進める予定です。
記事を書き次第、追記予定となります。
また、デザインは全くと言ってもいいほどつけないと思いますので、ご理解いただけると嬉しいです。

# 経緯
気ままにWebアプリをフルスクラッチで実装しようと思ったので始めました。
また、どうせならアウトプットしようと記事にし始めました。
(MarkDownの勉強もできるし…)
# どんなものを作るか
詳しくは決めていないがバイトのシフト管理アプリを作ろうと考えています。
店長が管理者となり、従業員がシフトを提出して店長がシフトを作成する的な…

# 開発環境
* Ubuntu 20.04.3 LTS
* PHP 8.0
* MySQL 8.0
* Git

※今後随時更新予定

# 記事一覧
### COMMING SOON…

元記事を表示

OTHERカテゴリの最新記事