- 1. ワードプレスとStripe決済で決済完了後に会員権限を変える
- 2. OOPまとめ
- 3. Laravelのベストプラクティスを読んでみた
- 4. 今まで読んだ技術書の中で汎用的で印象に残っているものをまとめてみる
- 5. CentOS7でLAMP環境構築 Linux, Apache, MariaDB(MySQL), PHP(Laravel)
- 6. PHPUnitで「General error: 1 no such table」エラーの解決
- 7. As a web engineer intern at ielove GROUP
- 8. XSERVERにlaravelのwebアプリをgitからデプロイ
- 9. 実務4年目のWEBエンジニアが「PHP本格入門(下)」を読んで学んだこと 12選
- 10. Generatorを使って配列をコンソールに出す処理を書く
- 11. LaravelとMySQLの接続詰まったところ
- 12. 【メモ】Laravelのオートロードの仕組みについて学ぶ
- 13. Symbol(XYM) の価格表示をする WordPress プラグイン
- 14. ストラテジーパターンって何?
- 15. CakaPHP4でユーザ追加時に関連するテーブルも同時に追加を行う方法
- 16. 【Laravel】EloquentCollectionにてネスト先カラムをGroupByする
- 17. Laravelで特定のホストでリクエストが来た時しか発動しないrouteを作って管理画面の認証画面すらも隠蔽してみる
- 18. 【PHP】Google Analytics APIでレポートデータを取得したい!
- 19. [Drupal]PHPの設定を変更する
- 20. EC2にLaravel+MySQL環境構築
ワードプレスとStripe決済で決済完了後に会員権限を変える
ワードプレスで作った決済機能付き会員サイトで、決済後に会員ステータスを変更して権限レベルを上げるプログラムを考えました。
# 機能概要
・登録時は購読者で登録
・月額費用の決済が完了した会員の権限をアップして編集者や投稿者に“`php
//DB情報 $dsn='mysql:host=ホスト名;dbname=データベース名;charset=utf8'; $user='ユーザー名'; $password='パスワード'; //ログインユーザー情報取得 $userinfo = wp_get_current_user(); $user_id = $userinfo->ID;//ログインしているユーザーIDを取得try{
$pdo = new PDO($dsn,$user,$password,[PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION]);//dbに接続する
$sql1 = “SELECT `umeta_id` FROM `wp_usermeta` WHERE (`user_id`= ? AND `meta_key`LIKE
OOPまとめ
# interface
interfaceはただ戻りと引数だけが定義された写像を書いてるだけで写像の具体的な演算は定義されていない。
そのクラスに定義された写像の一覧を作っておくことでクラスを分類できるようにする。
interfaceはClassではないのでそれ単体ではインスタンスを生成できない。interfaceを使うには、あとでクラスを作るときにinterfaceをクラスに取り込み、interfaceで定義された写像の中身の演算を定義しなければならない。“` php:interface_ex.php
interface DataStrageAccessInterface
{
public function fetch($key);
public function save($key, $value);
}
class DbAccessor implements DataStrageAccessInterface
{
public function fetch($key)
{
return Database::fetch($key
Laravelのベストプラクティスを読んでみた
# なぜベストプラクティスが必要なのか?
### Laravelの自由度が高すぎるから
Laravelは便利ですが、記述やディレクトリなどの自由度が高すぎてしまうという悩みどころがあります。
プロジェクトが進むにつれて、多くの人が自由にコードを書いてしまってすごく複雑になってしまう前に、コード記述の指針を示しておく必要があります。### 初学者のために
巷にあふれているチュートリアルや本の通りに学習してしまうと、それに沿い過ぎた変な癖がついてしまう場合があります。
そこで、改めてベストプラクティスに目を通すことで、よりよいLaravelのコードを知ることができます。# Laravelのベストプラクティスとは?
[公式(英語版)](https://laravel.com/docs/9.x)は、ベストプラクティスというよりも、Laravelによって提供される機能のHow Toって感じですよね。
そこで、[alexeymezenin氏](https://github.com/alexeymezenin)や有志によって作成されている[laravel-best-practice
今まで読んだ技術書の中で汎用的で印象に残っているものをまとめてみる
30代半ばでWebエンジニアに転職者(≠転生者)のおぎです。
2020年のコロナ禍をきっかけに興味本位でWebプログラミングを学び始めたのが運の尽きで、あれよあれよという間に深みにハマり、気づけば30代半ば(妻子あり)で異業種から転職をし、今はPHPをメイン言語としてバックエンドのプログラムを書いたりしています。転職してからは社内向けのアウトプットは多少していたのですが、インプットと実務で最近ほとんど外部向けへのアウトプットが行えていなかったので、リハビリがてら今まで読んだ本を覚えている範囲でリストしていこうと思います。(本当はもっと色々読んでいるんですが、難しすぎて理解できなかったり、他の本と内容が重複していたりで覚えていないものも多く、覚えていないものに関しては読んでいないのとほぼ同じだと思うので覚えている範囲のみで…)
※自分は基本的にPHPがメインではあるのですが、特定の技術や言語に関する技術書は時代とともに変化しやすい上、汎用性が低いので自費での書籍購入はなるべく汎用的なものを選ぶようにしています。
## オブジェクト指向でなぜつくるのか
https://www.
CentOS7でLAMP環境構築 Linux, Apache, MariaDB(MySQL), PHP(Laravel)
CentOS7上での基本的なLAMP環境の構築方法の備忘録。
## 新規ユーザーの設定
#### ユーザー追加
`useradd [ユーザー名]`
“`
[root@localhost ~]# useradd sakamoto
“`
実行後に何も表示されませんが追加されています。#### パスワード設定
`passwd [ユーザー名]`
“`
[root@localhost ~]# useradd sakamoto
Changing password for user sakamoto.
New password:
Retype new password:
passwd: all authentication tokens updated successfully.
“`#### ユーザー設定
sudo をパスワードなしで使用できるようにする。
/etc/sudoers のコメントを外す。
“`
[root@localhost ~]# vi /etc/sudoers## Allows people in group wheel to run all comm
PHPUnitで「General error: 1 no such table」エラーの解決
# はじめに
ローカル環境で、CakePHP のプロジェクトに対して PHPUnit 実行コマンドを叩くと、「テーブルがないから DROP できない」エラーが発生しました。
2回 PHPUnit 実行コマンドを叩くと正常にテストを実行するため、都度都度 2回実行する運用をしていましたが、楽をしたいため解決させます。
テスト実行時の DB は SQLite を利用しています。テスト実行時のエラーログ
“`bash
$ docker exec -it app ./vendor/bin/phpunit
PHPUnit 9.5.20 #StandWithUkraineError in bootstrap script: PDOException:
SQLSTATE[HY000]: General error: 1 no such table: files
#0 /var/www/html/vendor/cakephp/cakephp/src/Database/Driver/Sqlite.php(179)As a web engineer intern at ielove GROUP
# Summary
web開発インターン@いえらぶGroup
インターンを通して、実際のプロダクトの環境での開発から学びの記録です:)
**フロントエンドとバックエンド合計12個のプロジェクト**に取り組みました。開発ページ:https://cloud.ielove.jp/
期間:2021.02-2021.09(7か月)
開発環境:JavaScript, PHP, Zend Framework, MySQL, HTML, CSS, Gitlab, phpstorm
![img_reason2_input.gif](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/1714363/093411d2-cacd-5d62-e152-a87cfa021ae9.gif)# 大規模なシステムでの開発
情報科学科でも授業で扱うものは基本的な理論であったり、演習問題も数個のファイルで完結するものが多いです。そこで規模というものが、実際のプロダクトとの違いの一つであり、着目してみました。
### 該当部分探しの旅
開発要件が決XSERVERにlaravelのwebアプリをgitからデプロイ
この作業が何回やっても慣れず、自分の備忘録的な意味も含めて書かせていただきました。
もしよければ参考にしてみてください。## SSH接続
初期設定の部分は簡単なので飛ばしますログインコマンドはこちらです
“`
ssh -l サーバーID -i ~/.ssh/サーバーID.key サーバーID.xsrv.jp -p 10022
“`## PHPのバージョンアップ
#### 1 , 現在のバージョンを確認
LaravelにはPHPのバージョンが7以上であることを要求されています。
まずは以下のコマンドを実行してphpのバージョンを確認してみます。
“`
php -v
“`
laravel8.*を使うときはバージョンが7以上
laravel9.*を使うときはバージョンが8以上であれば、そのままでも大丈夫です。#### 2 , バージョンアップ
では、実際にphpのバージョンを変更していきます。
まずはHOME直下にbinディレクトリを作成します。“`
mkdir $HOME/bin
“`下記コマンドを実行すると使えるバージョンが表示されます。
“`実務4年目のWEBエンジニアが「PHP本格入門(下)」を読んで学んだこと 12選
## はじめに
今回は「__実務4年目のWEBエンジニアが「PHP本格入門(下)」を読んで学んだこと 12選__」というテーマでお伝えします。
PHP本格入門(下)(以下、本書)
https://gihyo.jp/book/2020/978-4-297-11470-1
本書を手に取った経緯などは、下記記事をご参照ください!
https://qiita.com/Yazmatto/items/90f854e11a5b3cd88999
それでは、本題です。
ここからは、本書を読んで学んだこと 12選をお伝えしていきます。
## 結論
私が本書を読んで学んだことは、以下の通りです。
:::note
学んだこと 12選
1. クラスの関係性を表すキーワード
1. 神クラス(アンチパターン)
1. なんでもpublicなクラス(アンチパターン)
1. クラスに動的にアクセスする方法
1. イテレータを使用した繰り返し処理
1. ジェネレーター
1. メソッドチェーンに対応したクラスの作り方
1. HTMLおよびJavaScriptのコメントには注意する
1. セキュリティリスGeneratorを使って配列をコンソールに出す処理を書く
## 概要
再帰的に配列を作成し返す関数とGeneratorを返す関数を書き、その違いを見比べてみます。
## 経緯
任意の配列をコンソールに出す処理を書いていました。
始めは直接ループ内で出力していましたが、非常にテストしづらいので、先に出力する文字列の配列を全部作成してから一気に出力しようと考えました。
そこで、大きい配列を出力するためだけに同じような(あるいは大きい)配列を作成し、メモリを使うのは勿体無いので、Generatorを使って書くに至りました。
恥ずかしながら、Generatorは今まで使った事が無かったのですが、ちゃんと書いてみると配列バージョンとGeneratorバージョンの書き方の対応がよく分かったので、メモがてら残そうと思った次第です。## コード
### 配列を作成し返す場合のコード
“`php
/**
* 配列を表示するための文字列を取得する
*
* @param array $data
* @return array
*/
function getOutputStr_Array(array $data, int $deLaravelとMySQLの接続詰まったところ
# Laravel詰まったところ
## おそらく当たり前のことだけどわからなかったのでメモしておく
## php artisan migrationでのエラー
### .envで、DB_DATABASE=homestead, DB_USERNAME=homestead, DB_PASSWORD=passに設定したときやっておかなければならないこと。
### MySQLにログインする(各人で異なると思うが、私は[mysql -u root]でログインできたぁ)、そんでまずはhomesteadのデータベースを作成、次にhomesteadという名のユーザーをpassというパスワードで作成、最後にhomesteadユーザーにhomesteadデータベースの権限を付与する。
### 上記ができたら、[php artisan migration] を実行する。
### それでうまくいったら、mysqlにログインする。[mysql -u homestead -p] Enter passwordと出るので[pass]と入力する。
### MariaDB[none]> でるので[connect home【メモ】Laravelのオートロードの仕組みについて学ぶ
PHPを初めて触り、Laravelを勉強しているのですが、オートロードという機能を目にして便利だけどなんで機能しているのか全く分からない状態でした。
今回はそんなオートロードについてちゃんと調べました。
最初はLaravelがそういう機能を提供しているのかな?とか思っていたら、いやいや機能を実現するためにファイルを作ったのはComposerだよとなり、実際にComposerによって作成されたファイルを見てみたらPHPで記述されていて、更に見てみたらPHPの標準としてオートロード機能を実装するための関数が用意されていたという話です。# Laravelにおけるオートロードとは
オートロードを実施しない場合、クラスをインスタンス化したりするときには、クラスが定義されているファイルをrequire等で読み込んでからインスタンス化をすると思います。
オートロードでは名前空間+クラス名と、そのクラスが実際に記述されているファイルとを紐づけます。そうすること、インスタンス化するときなどに名前空間が分かるように記述すればで自動でファイルを読み込んで使用できるようにしてくれます。
何がありがたいかとSymbol(XYM) の価格表示をする WordPress プラグイン
# まえがき
Symbol コミュニティは今、phpにつよいエンジニアを探しています!
【募集】
そろそろPHPで(特にWordpressで)Symbol使いたいという要望が増えてきました。
PHPの開発経験がある方は一度Discord「NEM Japan UserGroup」にご参集いただけますでしょうか??♂️https://t.co/pftIkRam56— XEMBook@symbol? (@xembook) May 12, 2022
ストラテジーパターンって何?
## そもそも
>デザインパターンとは、様々なプログラムで再利用できる汎用的な設計パターンのことです。 プログラマの世界では、様々なデザインパターンが知られていますが、その中でも特に有名なのが「GoFデザインパターン」です。https://xtech.nikkei.com/it/article/COLUMN/20051123/225074/#:~:text=%E3%83%87%E3%82%B6%E3%82%A4%E3%83%B3%E3%83%91%E3%82%BF%E3%83%BC%E3%83%B3%E3%81%A8%E3%81%AF%E3%80%81%E6%A7%98%E3%80%85,%E3%80%8CGoF%E3%83%87%E3%82%B6%E3%82%A4%E3%83%B3%E3%83%91%E3%82%BF%E3%83%BC%E3%83%B3%E3%80%8D%E3%81%A7%E3%81%99%E3%80%82
ある問題があって、こう言うときはこんな設計をすれば良いよね。
みたいなのがデザインパターンのイメージ。## Wikiで調べてみた
>Strategy
CakaPHP4でユーザ追加時に関連するテーブルも同時に追加を行う方法
# はじめに
実務でCakePHPを使って社内業務用のWEBアプリケーションを開発しました。
その際、細かい仕様の部分を悩みながら開発を進めたので、共有させていただきたいと思います。
(※ 実務で開発した内容そのままではなく、公開できるように内容を修正しております。)# 開発環境
Mac Monteray 12.2.1
CakePHP 4.3.7
PHP 7.4.2
MySQL 5.7.26# 本記事記載内容
ユーザ追加時に、ユーザのテーブルだけではなく、関連するその他のテーブルに関しても更新を行う、という方法について記載いたします。
所々解説用にXdebugのスクリーンショットを記載いたします。# DB設計
### ER図
![20220413_ER図.png](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/419781/f1a3a292-c924-0c3b-fa53-57ee1075a482.png)### 補足
本記事ではusers, affiliation_committees, comm【Laravel】EloquentCollectionにてネスト先カラムをGroupByする
## はじめに
そもそも1カラムに複数値を持たせるのはどうかという点は置いといておいて、、、。
何らかしらのレスポンスデータをログとしてそのまま格納したい場合などあると思います。
こちら調べてもあまり記事がなく、もしかしたらやりたい人がいるかな~と思いメモとして記事に残しておきます。## 要件
Jsonがそのまま入ったカラムにて、Jsonのキーでグルーピングしたい## 結論
```php
// ドット「.」でつなげる
$collection->gropuBy('xxx.xxx');
```## 検証内容
### テーブル構成
```php:migration.php
Schema::create('conversions', function (Blueprint $table) {
$table->id();
$table->json('meta');
$table->timestamps();
});
```
### データ
|id| meta | created_at | updated_at|
|:-------Laravelで特定のホストでリクエストが来た時しか発動しないrouteを作って管理画面の認証画面すらも隠蔽してみる
趣味で作っているLaravelのアプリケーションで管理画面だけ通常のサービスを提供しているホストは全く別のIdentity-Aware Proxyで保護されたホストで配信して、一般のユーザから `/admin/` を叩かれても応答を返さないことで管理画面の認証画面すらも隠蔽したくなったのでその方法を紹介したいと思います。
## 早速route middlewareを作る
名前は何でも良いので早速route middlewareを作りましょう。```php:app/Http/Middleware/CheckRestrictedRouteHost.php
【PHP】Google Analytics APIでレポートデータを取得したい!
最近めっきりAPIからは遠ざかっていたのですが、
久しぶりに運用担当さんから連絡が来ました。
曰く「**Google Analyticsのレポートを自動化したい**」とのこと。ヤッホーーーイ!!
最近バージョンアップとかしかなくて退屈してたんだよね!(違う)
ということで、今回挑むのはGoogle Analytics APIです。
例によって「(意地でも)**サンプルを使わずにデータを取る!**」方式により
頑張っていきたいと思います。毎度の繰り返しになりますが、
Googleは「サンプルプログラムを使ってやってね!」を推奨しているので
なにかあっても自己責任でお願いします!**っていうかアナリティクスってなに!?**
正直あまり馴染みがないのですが・・・まあなんとかなるか。なるか・・・?# Google Analytics APIとは
Google Analyticsとは、天下のGoogleさんが提供しているアクセス解析ツールです。
当然のことながら無料。さすがぐーぐるさんですね。Analyticsを利用すると、サイトにどのくらいアクセスが来ているか、
リア[Drupal]PHPの設定を変更する
PHPのメモリ容量などphp.iniに書かれている情報はsettings.phpに以下のような行を追加することで編集できます。
```php
ini_set('memory_limit', '256M');
```他には
- php.ini
- .user.ini
- .htaccess
を編集する方法もあります。詳しくはこちらをご覧ください。https://www.drupal.org/docs/7/managing-site-performance-and-scalability/changing-php-memory-limits
EC2にLaravel+MySQL環境構築
# はじめに
EC2にLaravelをインストールし、
すでに作成済み(githubやcodecommitなど)のプロジェクトを展開する方法です。※バージョンなどは古い場合があります。
# 開発環境作成
#### 必要なものをインストール
ec2-userで作業します。**httpd** をインストール。
```
$ sudo yum -y install httpd
```**git** をインストール。
```
$ sudo yum -y install git
```**PHP** をインストール。(バージョンは任意)
```
$ sudo amazon-linux-extras enable php7.4 -y
``````
$ sudo yum clean metadata
``````
$ sudo yum install php php-{pear,cgi,common,curl,mbstring,gd,mysqlnd,gettext,bcmath,json,xml,fpm,intl,zip,imap}
```問題なくインスト
関連する記事
OTHERカテゴリの最新記事
-
- 2024.09.19
JavaScript関連のことを調べてみた
-
- 2024.09.19
JAVA関連のことを調べてみた
-
- 2024.09.19
iOS関連のことを調べてみた
-
- 2024.09.19
Rails関連のことを調べてみた
-
- 2024.09.19
Lambda関連のことを調べてみた
-
- 2024.09.19
Python関連のことを調べてみた