質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.46%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

3回答

861閲覧

PHPプログラムでのクラス、オブジェクトに関する質問(初心者です)

yuri0906

総合スコア5

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

1グッド

0クリップ

投稿2020/03/13 03:51

前提・実現したいこと

PHP初心者です。
PHPのクラスに関する質問です。
以下のAuthefiticationsクラスでUserDataクラスのゲッターを呼び出したいので、UserDataクラスのオブジェクトを生成したいです。

発生している問題・エラーメッセージ

IDEのエディタ上にエラーが表示されてしまいます。(プログラム実行はしていません)

Unexpected: assign //オブジェクト生成コード上にでてきます。

該当のソースコード

<?php namespace todo; use todo\UserData; class Authentications { private $leaf = false; $user = new UserData();//①フィールド上に宣言したが× public function __construct(){ $user = new UserData();//②コンストラクタに宣言したが使用できない } public function confirmID($user_id){ if($user_id==$user->getID()){ $this->leaf= true; } return $this->leaf; } public function confirmPass($password){ if($password==$user->getPass()){ $this->leaf= true; } return $this->leaf; } }
<?php namespace todo; class UserData { private $user_id = "php"; private $password = "Docker"; public function getID(){ return $this->user_id; } public function getPASS(){ return $this->password; } }

試したこと

Authefications.phpの①②

補足情報(FW/ツールのバージョンなど)

PHP7.2
Laravelとかは使ってません。
フレームワークなしです。

s.k👍を押しています

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

tanat

2020/03/13 03:58

IDEの警告を見ることは大事ですが、 まずはPHPを実行してエラーメッセージを確認するようにして下さい。
退会済みユーザー

退会済みユーザー

2020/03/13 04:04

class Authenticationsの$userってなに?
退会済みユーザー

退会済みユーザー

2020/03/13 04:15

質問の件名に、わざわざ初心者ですとか書く必要はありません。初心者であることを示す若葉マークみたいな機能の方を使ってください。
m.ts10806

2020/03/13 05:21

質問はいつでも編集できるので下記だけでもご対応ください ・(初心者です)を外す ・初心者マークをつける
guest

回答3

0

ベストアンサー

class Authenticationsの$userの扱いが雑すぎてこまる。
そのくせ、$this->leafとか書けているのに、
同じことをuserも$this->userとすればいいだけなのに、
どうして。

php

1 public function __construct(){ 2 $user = new UserData();//②コンストラクタに宣言したが使用できない 3 }

これ、$userがローカル変数扱いされてて、
コンストラクタを抜けると$userは揮発してしまうんだが。
メンバー変数じゃないから、消えちゃうし参照もできなくなる。

そうならないよう、メンバ変数として定義する必要があって、
ローカル変数へのアクセスと区別して保持しないといけない。

php

1class Authentications 2{ 3 private $leaf = false; 4 private $user; 5 6 public function __construct(){ 7 $this->user = new UserData(); // メンバー変数にUserData()のインスタンスを保持 8 } 9 10 public function confirmID($user_id){ 11 if ($user_id == $this->user->getID()) { // ほんとうは == よりも === とするべきか 12 $this->leaf = true; 13 } 14 return $this->leaf; 15 } 16 17 public function confirmPass($password){ 18 if ($password == $this->user->getPass()) { // ほんとうは == よりも === とするべきか 19 $this->leaf = true; 20 } 21 return $this->leaf; 22 } 23}

とかなるだろうか。(机上のコードなので実行してないけども。)

文法上の間違いではないけど、適度に空白をつけて見やすさを改善しないと
コードへの理解も深まらないとわたしは思う。

ところで、confirmID()の結果とconfirmPass()の結果が
同じメンバー変数$this->leafを上書きしてていいのかい?

投稿2020/03/13 04:13

編集2020/03/13 04:30
退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yuri0906

2020/03/13 04:40

回答とご意見ありがとうございます。もう少し文法チェックしてから質問します。
guest

0

Authenticationsクラスで
private $user = null;
など宣言しておいて、コンストラクタ内で
$this->user=new UserData();
とかにしてみては?

投稿2020/03/13 04:09

yambejp

総合スコア115010

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ざっとしか見てないですけど、色々問題ありそうです^^;

とりあえず、質問の箇所は以下で解決できるかと

プロパティ

プロパティを定義するには public、protected あるいは private のいずれかのキーワードのあとに、オプションの型宣言を続け、 そして通常の変数の宣言を続けます。 宣言時に初期値を設定することもできますが、初期値は定数値でなければなりません。 つまり、コンパイル時に評価可能な値でなければならず、 実行時の情報がないと評価できない値であってはいけないということです。


なんかよくわからん説明になったので、とりあえず動くってレベルのコードを追記
やりたいのは、UserData インスタンスをプロパティで持ちたいってことなんですかね?

php

1<?php 2class Authentications 3{ 4 private $leaf = false; 5 6 public function __construct(){ 7 $this->user = new UserData(); 8 } 9 public function confirmID($user_id){ 10 if($user_id===$this->user->getID()){ 11 $this->leaf= true; 12 } 13 return $this->leaf; 14 } 15} 16 17class UserData 18{ 19 private $user_id = "php"; 20 private $password = "Docker"; 21 22 public function getID(){ 23 return $this->user_id; 24 } 25} 26 27$a = new Authentications(); 28var_dump($a->confirmID("php"));

投稿2020/03/13 03:59

編集2020/03/13 04:09
退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2020/03/13 04:14

$this->userの宣言がない?
退会済みユーザー

退会済みユーザー

2020/03/13 04:24

動くだけのコードだからねぇ^^; そもそも命名規則から見直したい。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.46%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問