- 1. Laravel ExcelのCSVインポートで、日本語のカラム名を取得できない問題。
- 2. HackTheBox Clicker WriteUp
- 3. PHPStan どうしても解消できない静的解析エラーをPHPStanの設定で見なかったことにする
- 4. MAMPを使用して、wordpressの環境構築を行う
- 5. 【PHP】HPサーバーにあるCSVへ書き込む。
- 6. Macの環境構築、PHP用環境構築
- 7. Next.js × Laravel でページネーションの実装
- 8. 素数判定関数を使って簡単なゲームを作った話④
- 9. laravelを使った自分が作った料理を投稿できるWebアプリの作成手順
- 10. PHPフレームワーク「Flow」のリフレクションがPHP標準のリフレクションよりも速いワケ
- 11. 素数判定関数を使って簡単なゲームを作った話③
- 12. 素数判定関数を使って簡単なゲームを作った話②
- 13. 素数判定関数を使って簡単なゲームを作った話①
- 14. 素数判定関数を使って簡単なゲームを作った話(目次用)
- 15. UbuntuでphpとApacheを連携させる
- 16. Homebrew経由でサポートが終了したPHPをインストールする
- 17. Postmanで連想配列を送る方法
- 18. paizaレベルアップ問題集 標準出力メニュー【行によって長さが違う二次元配列の表示】FINAL問題 すべての行の長さと値が不定な 2 次元配列の出力 (paizaランク B 相当) 解答例
- 19. PHPの静的コード解析ツールPHPMDの使い方
- 20. 【Laravel】マルチパートアップロードを使って動画をS3へアップロードする
Laravel ExcelのCSVインポートで、日本語のカラム名を取得できない問題。
# ヘッダーのカラム名を取得
エンコーディングの問題以前に、そもそもヘッダーの行を正常に取得できていなかった。
以下設定でformatterをnoneにすれば解決する。“`config/excel.php
‘imports’ => [
‘heading_row’ => [
‘formatter’ => ‘none’,
],
],
“`クラス毎に設定する場合は以下。
“`Imports/TestImport.php
use Maatwebsite\Excel\Imports\HeadingRowFormatter;HeadingRowFormatter::default(‘none’);
class TestImport implements ToModel
{
}
“`# シフトJISの文字化け
先程のconfig/excel.phpでも設定できるが、
クラスに設定する場合は、getCsvSettings()を追記する。
WithCustomeCsvSettingsをimplementsすることも忘れずに。“`Impo
HackTheBox Clicker WriteUp
今回は、HackTheBoxのMediumマシン「Clicker」のWriteUpです。
名前から連想できる脆弱性はなさそうですね。どのようなマシンなのでしょうか。![スクリーンショット 2024-01-28 23.34.20.png](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/1664764/0eccca6b-7d0a-28d1-ca19-8449e73d143d.png)
グラフは普通のMediumという感じですね。
評価は高そうなので、楽しみです。攻略目指してがんばります!HackTheBoxってなに?という方はこちらの記事を見てみてください。一緒にハッキングしましょう!
https://qiita.com/WhizOwl/items/165783694cb4791cff34
また、HackTheBoxで学習する上で役にたつサイトやツールをまとめている記事もあるので、合わせてみてみてください!
https://qiita.com/Perplex/items/30f949fe261f56a
PHPStan どうしても解消できない静的解析エラーをPHPStanの設定で見なかったことにする
## 概要
PHPStanを使っていてどうやっても解消できない静的解析エラーをエラーとして扱わないようにする方法を簡単にまとめる。
## 注意
本方法は多用してはいけません。多用するとPHPStanを入れている意味がなくなります。
コード上でどうにかして対処し、それでもどうしても解消できない場合に使いましょう。## お願い
なるべくエラーを許容する方法で解決したくありません。もっと良い解決方法がございましたらぜひ教えてほしいです。。!
## 方法
phpstan.neonというファイルに見過ごしたいエラーを指定することでそのエラーをなかったことにする事ができる。
具体的には`ignoreErrors:`のあとに正規表現を使って見過ごしたいエラーを指定する。エラーとは下記のように行数とエラー内容で表示されるヤツのことである。
“`
—— ————————————————————————————-
Line ファイルパス
——
MAMPを使用して、wordpressの環境構築を行う
### はじめに
wordpressがPHPで動いていることから、MAMPを使用してwordpressの環境構築を行なってみたので備忘録として残します。
### 今回使用するプロジェクトディレクトリを作成する
任意の場所に、あらかじめプロジェクトディレクトリを作成しておきます。
### MAMPのインストール
公式からダウンロードする。
※M1チップのAppleを使用しています。
https://www.mamp.info/en/mamp/mac/![スクリーンショット 2024-01-27 13.00.40.png](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/3513569/44fffd5f-eb95-7928-5125-3584515dd677.png)
ダウンロード→ダウンロードしたファイルをクリック→上記のようなインストーラーが立ち上がります。
同意やインストール先を聞かれるので「続ける」をクリックし、インストールは完了です。あらかじめ作成しておいた、プロジェクトディレクトリにMA
【PHP】HPサーバーにあるCSVへ書き込む。
# 目的
あるデータをHPにて使用するため、CSVへ書き込む。今回の内容はURLを見られても問題ないデータ。
セキュリティ等はあまり得意ではないため、不備があればご教示頂ければ幸いです。
クライアントPC→HPサーバー→HPに表示# 環境等
* クライアントPCでもサーバーPCでもPHPを使用
* サーバーの権限がある# 方法
## クライアントPCの設定
変数$outoput.dataにサーバーへ送信したい情報が含まれている(一行の文字列)。“`php:get_data.php
//送信先の文字コードへ変換
$output_euc = mb_convert_encoding($output_data, “EUC-JP”, “UTF-8”);//HPサーバーへデータ送信
$url = “https://www.test.com/get_data.php?data=” . “$output_euc”;
$conn = curl_init(); // cURLセッションの初期化
curl_setopt($conn, CURLOPT_URL, $url); // 取得するU
Macの環境構築、PHP用環境構築
# 前提
## 対象
* web系エンジニア(特にPHPバックエンド)## 環境
以下の環境で確認しました。
Appleシリコンmacなら同様にできると思います。
* macos Sonoma
* MacBook Pro – Apple M3 Pro## 前置き
* intel MacからM3 Macに移行するにあたって移行ツールを使用せずに手動移行したのでその備忘
* 一緒に働く人に環境構築方法を共有したいのでついでにわかりやすく書こうと思った
* PHP開発はDockerで行うがローカルにもPHPが必要な場面があるので入れている
* ~~phpstan以外の静的解析~~、~~Laravel向けのVS Code拡張~~、AI系のVS Code拡張、node jsとそのバージョン管理については追記したい気持ちがある
* phpcs、Laravel向け拡張機能について追記しました# はじめに
## システム設定
システム設定アプリから行う内容です* トラックパッドによるポインタの移動速度
* トラックパッド > 軌跡の速さ > 最も速くする
* トラックパッド
Next.js × Laravel でページネーションの実装
# 1. はじめに
Next.js × Laravel でブログ投稿サイトを作成していました。
その際にページネーションの実装で詰まったので突破した解決策を記しておこうと思います。# 目次
[1.はじめに](#1-はじめに)
[2.使用環境](#2-使用環境)
[3.背景](#3-背景)
[4.ページネーション実装前の状況](#4-ページネーション実装前の状況)
[5.ページネーション実装](#5-ページネーション実装)
[6.ページネーション完成時のコード](#6-ページネーション完成時のコード)
[7.最後に](#7-最後に)# 2. 使用環境
– MacBook Air : M2チップ / 16 GB
– Next.js : 14.1.0
– React : 18.2.0
– PHP : 8.2.14
– Laravel Framework : 10.39.0
– My SQL : 8.0.32
– PHP My Admin : 5.2.1
– Docker :
“`
Client:
Cloud integration: v1.0.35+de
素数判定関数を使って簡単なゲームを作った話④
ご覧いただきありがとうございます。
この内容は、複数に分けて投稿しています。全体をご覧になりたい方は、以下のリンク先よりご確認ください。https://qiita.com/hitoki_univ/items/8e3feab0add17befc700
前回の内容については、こちらからどうぞ。
https://qiita.com/hitoki_univ/items/96e45db86abc4dae71d7
# 今回やること
第3回までで、ゲームをプレイする人数の選択、プレイヤー名と制限時間の設定に関する部分を実装しました。
今回は満を持して、ゲームの動作部分を実装していきます。# ゲームの実行画面
前回作成したプレイヤー名などの入力画面と同様、ゲームのプレイ人数に応じて異なるページを作成する必要があります。しかし、基本構造はどのページも共通ですので、今回は2人用のページを主に確認していきます。### HTML
“` php
laravelを使った自分が作った料理を投稿できるWebアプリの作成手順
今回はプライベートでPHPフレームワークのLaravelを使ったWebアプリケーションの開発をするので、その設計書を書いていきます。
## サービスを作ろうと思った背景
僕は大学生なので家族と離れて暮らしています。自分の生存確認のための連絡がよく入ってきます。Lineなどのアプリを使っても連絡ができますが、せっかく大学でプログラミングを学んでいるので自分でWebアプリを作ってみようと思いました。具体的には自分の生活ぶりが家族に伝わるようなWebアプリを作ってみようと考えています。
## どんなサービスか
利用者に会員登録してログインしてもらい自分が作った料理の写真を投稿したり、他の人の投稿を見れるようなサービスにしてみようと思ってます。
## サービスに使うスキル
– HTML
– CSS
– jQuery
– PHP
– Laravel
– MySQL
これらを使いたいと考えています。## サービスの仕様
### 利用者の認証のために
– ログイン
– ログアウト
– 会員登録
– 退会処理
マイページ画面を作り
– メールアドレス変更
–
PHPフレームワーク「Flow」のリフレクションがPHP標準のリフレクションよりも速いワケ
# はじめに
PHPにはクラスやメソッドの構造を取得できるリフレクションという機能があります。PHPフレームワークのFlowではPHP標準のリフレクション処理を用いた独自のリフレクション処理が定義されており、様々な機能を追加で使えるようになっています。そんなFlowのリフレクション処理ですが、公式ドキュメントを読んでいると以下のような記載がありました。
> Flow provides a powerful extension to PHP’s own basic reflection functionality, not only adding more capabilities, but also speeding up reflection massively.
“**speeding up reflection massively…**”
どうやら、**FlowのリフレクションはPHP標準のものよりも速い**とのこと。
FlowもPHP標準のリフレクションを利用しているのになぜ差が出るのか気になったので調べてみました。# TL;DR
* Flowは実行前にコン
素数判定関数を使って簡単なゲームを作った話③
ご覧いただきありがとうございます。
この内容は、複数に分けて投稿しています。全体をご覧になりたい方は、以下のリンク先よりご確認ください。https://qiita.com/hitoki_univ/items/8e3feab0add17befc700
前回の内容については、こちらからどうぞ。
https://qiita.com/hitoki_univ/items/5893785797243794d33a
# 今回やること
第2回では、ゲームのタイトル画面を作成しました。
今回は、タイトル画面からのリダイレクト先である、プレイヤー名と制限時間を設定する画面を作成します。# プレイヤー名、制限時間の設定画面
前回作成したページでは、選択したプレイヤー人数に応じて異なるページにリダイレクトするようにしました。
今回はそのリダイレクト先のページを作成するので、複数のページを作成します。しかし、基本構造はどのページも同じなので、今回は2人用のページを主に確認していきます。### HTML
“` html
素数判定関数を使って簡単なゲームを作った話②ご覧いただきありがとうございます。
この内容は、複数に分けて投稿しています。全体をご覧になりたい方は、以下のリンク先よりご確認ください。https://qiita.com/hitoki_univ/items/8e3feab0add17befc700
前回の内容については、こちらからどうぞ。
https://qiita.com/hitoki_univ/items/e1b8ec9e6c7c39d5e761
# 今回やること
前回は、これから作成するゲームの概要などについて説明しました。
今回は、そのタイトル画面を作成していきます。# ゲームのタイトル画面
タイトル画面では、プレイヤー人数を選択し、人数に対応したプレイヤー名入力画面に遷移する機能を実装します
1. プレイヤー人数を選択し、人数に対応したプレイヤー名入力画面に遷移する機能
2. 過去のランキングを表示する画面に遷移する機能具体的なコードは以下の通りです。
### HTML
“` html
素数判定関数を使って簡単なゲームを作った話①ご覧いただきありがとうございます。
この内容は、複数に分けて投稿しています。全体をご覧になりたい方は、以下のリンク先よりご確認くださいhttps://qiita.com/hitoki_univ/items/8e3feab0add17befc700
# ゲームの概要
このゲームは、複数人による対戦形式を想定して作成しています。
動作の概要は以下の通りです。①プレイヤーの人数を選択
②プレイヤーの名称を入力
③順番に素数を入力していく。この時、前回より大きな素数を入力する必要がある。制限時間内に前の人より大きな素数を見つけられないとゲームオーバー今回は、生徒たちにより楽しみながらプレイしてもらえるように、ランキング機能も作成します。
ちなみに、前の人より大きな素数を入力していく、という遊び方は、学習支援事業で会った生徒さんの発案です。# 次の投稿について
次回(第2回)は、このゲームのタイトル画面を作成します。
~~投稿次第、リンクを追加するので、ぜひご覧ください~~
以下のリンク先から、是非ご覧ください。https://qiita.com/hitoki_univ/i
素数判定関数を使って簡単なゲームを作った話(目次用)
こんにちは。
私は、週に何度か某市の学習支援事業の指導員として活動しています。そこでは中学生に指導を行っているのですが、その休憩時間に、生徒たちに多少なり頭を使いながら遊んでもらえるものを作れないかと思い、今回のゲームの開発に至りました。
以前の大学の授業で、JavaScriptで素数判定を行うプログラムを作成していたので、今回はそれを活用して、Webアプリケーションの形式でゲームを作っています。# この投稿の構成
一度にすべての内容を書くと長くなりそうなので、何回かに分けて投稿します。このページは、その目次のような形で使っていければと思います。# 第1回
1回目は、作成したゲームの概要等について簡単に説明しています。
詳しくは、↓のリンク先をご参照ください。https://qiita.com/hitoki_univ/items/e1b8ec9e6c7c39d5e761
# 第2回
2回目は、ゲームのタイトル画面を作成します。
詳しくは、↓のリンク先をご参照ください。https://qiita.com/hitoki_univ/items/589378579724379
UbuntuでphpとApacheを連携させる
# 概要
UbuntuでphpとApacheを連携させるのメモ。# 現象
index.phpでechoしてもブラウザ上になにも表示されなかったので調べたところ、phpとApacheを必要があるらしい。# 環境
Ubuntu
“`
$ cat /etc/issue
Ubuntu 22.04.3 LTS \n \l
“`
php
“`
$ php -v
PHP 8.3.2 (cli) (built: Jan 25 2024 15:18:05) (NTS)
Copyright (c) The PHP Group
Zend Engine v4.3.2, Copyright (c) Zend Technologies
“`
Apache
“`
$ apachectl -v
Server version: Apache/2.4.52 (Ubuntu)
Server built: 2023-10-26T13:44:44
“`
# 試したこと
1. 下記コマンドでphpモジュールを有効化する
“sudo a2enmod php“
下記エラーが出る
“ERROR: Mod
Homebrew経由でサポートが終了したPHPをインストールする
# バージョン情報
Homebrew:4.2.5
# 事象
HomebrewでPHP8.0をインストールしようとしたら2023年11月でサポート期間が終了していたため、下記のエラーが発生してインストールできなかった。
今回は8.0をインストールする。
“` terminal
$ brew install php@8.0
Error: php@8.0 has been disabled because it is a versioned formula!
“`2023/01/25時点でインストールできるのは8.1と8.2
# 対応策
①下記コマンドを叩く
“` terminal
$ brew tap shivammathur/php
“`2024/01/25時点では5.6〜8.4がインストールできるっぽい。
“` terminal
$ brew search php
brew-php-switcher phpmd shivammathur/php
Postmanで連想配列を送る方法
# はじめに
Web APIの設計・開発、テストをサポートするツールとして有名なPostmanhttps://www.postman.com
何となくGETで値を受け取ったり、POSTしてDBに値を保存したり、、、といった基本的な使い方はわかっているがある時
**「あれ??連想配列ってどうやって送るんだ???」**
と詰まったので、ここに記録します:persevere:
またLaravel + Open APIという開発環境の例で進めます
# どうやって配列をPOST送信するか
画像とともに手順を以下に記載していきます!## まずはRequest内のBodyセクションを開きましょう
![Screenshot 2024-01-25 at 21.42.33.png](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/167220/a4f36d83-19ab-1a1a-f261-6538571d588e.png)今まではパラメーターで送ってばかりでParamsしか開いたことがありませんでした・・・
👇
paizaレベルアップ問題集 標準出力メニュー【行によって長さが違う二次元配列の表示】FINAL問題 すべての行の長さと値が不定な 2 次元配列の出力 (paizaランク B 相当) 解答例
PHPで回答。コード公開可とのことなので復習も兼ねて共有します。
[問題文](https://paiza.jp/works/mondai/stdout_primer/stdout_primer__variable_array_boss “paiza.jp/works/mondai/stdout_primer/stdout_primer__variable_array_boss”)
## 解答例1
“`php
PHPの静的コード解析ツールPHPMDの使い方
## まずは本家ドキュメント
### ルールの内容
https://phpmd.org/rules/index.html### ルールセットの作り方
https://phpmd.org/documentation/creating-a-ruleset.html英語だけど翻訳機能を使えば割りと良い感じで読める。
## 大枠の構成と方針
* ルールセットがあって、それらに単品のチェックルールが入っている構成
* ルールセットも、xmlで定義されている
* ルールのパラメータ上書きもできる(メソッド名は最低3文字など)
* ルールセットの複数指定もできる今回は、ルールセットを指定して、セットの中の都合の悪いものだけ、無効化する方針とした。
## install
“`bash
composer require –dev “phpmd/phpmd=@stable”
“`## help見る
“`bash
composer –help
“`
使えるrulesetとか、出力フォーマットの種類とか、cacheオプションなど色々書いてある## 単品ファイルなど、手動
【Laravel】マルチパートアップロードを使って動画をS3へアップロードする
## はじめに
この記事が私の初投稿になります。
アウトプットの機会を増やしていくため、継続的に記事を書いていこうと思います。今回は実際の業務で苦戦した「マルチパートアップロードを使用したAWS S3へのファイル保存」についてです。
この辺のトピックはネットの情報が古かったり有益な情報に出会えなかったため、私と同じような状況の方の手助けになれば幸いです。また間違いなどがございましたら、ご指摘のほどよろしくお願い致します。
## 背景
私が業務でS3を使用した背景ですが、以下のような理由から採用することにしました。
※S3の詳細は割愛しますが、サーバーとは別のところにファイルを保存したい場合に使用するドライブみたいなものですかね!(ざっくりしすぎかな、、、)* 容量が1GBを超える動画コンテンツを扱うため
* S3に置いたコンテンツはCloudFront(詳細は[公式](https://aws.amazon.com/jp/cloudfront/)を参照してください)経由で高速でアクセスできるため## 実行環境など
* PHP8.2
* Laravel10
* MySQL