私はOOPを初めて使用するので、しばらくお待ちください;)
コードにコメントしてください。
FormParameterHandlerを拡張するクラスRegisterFormParameterHandlerがあります。登録またはログインユーザーの$_POST変数を検証するために使用しています。クラス「notice」は、エラー報告とログ用です。
RegisterFormParameterHandlerのコンストラクターの引数としてオブジェクト$noticeを渡すことで、コードを機能させました。クラス通知で静的メソッドを使用する必要がありますか?
class notice {
private $_notice = array();
public function get_notice(){
return $this->_notice;
}
public function add($type, $message) {
$this->_notice[$type][] = $message;
}
}
と:
abstract class FormParameterHandler {
protected $parameters;
public function __construct($associative_array) {
$this->parameters = array();
foreach($associative_array as $key => $value) {
$this->{$key} = $value;
}
}
public function __get($key) {
$value = null;
if(method_exists($this, "get_$key")) {
$value = $this->{"get_$key"}();
} else {
$value = $this->parameters[$key];
}
return $value;
}
public function __set($key, $value) {
$value = addslashes($value);
$value = htmlentities($value);
if(method_exists($this, "set_$key")) {
$this->{"set_$key"}($value);
} else {
$this->parameters[$key] = $value;
}
}
と:
class RegisterFormParameterHandler extends FormParameterHandler {
protected $notice;
public function __construct($form_parameters, $notice, $tok_id, $captcha) {
parent::__construct($form_parameters);
$this->notice = $notice;
$args = func_get_args();
foreach($form_parameters as $key=>$value) {
$key = 'validate_'.$key;
$this->$key($args);
}
}
public function validate_something($args) {
if(something === true) {
$this->notice->add('error', 'Error message');
}
}
}
これは、メソッドvalidate_somethingで$ argを渡す正しい方法ですか、それともコンストラクターでそれを行う方法がありますか?
クラス通知は、クラスRegisterFormParameterHandlerの前にオートローダーでインスタンス化されます。
$notice = new notice();
.....
$reg = new RegisterFormParameterHandler($_POST, $notice, $tok_id, $captcha);
したがって、クラス通知にはすでにいくつかのエラーメッセージが含まれており、このクラスが呼び出された後に使用されます。
クラスRegisterFormParameterHandlerでクラス通知を使用するより良い方法はありますか?