1

やあみんなはあなたが私を助けることができることを望んでいた。

事前に知らせておくと、比較的新しいphpコーダーで、練習プロジェクトを行っていて、この問題に遭遇し、1時間ほど再チェックとグーグルを行ったが、何が原因かわからない。

エラー:解析エラー:構文エラー、予期しないT_STRING、7行目のC:\ wamp \ www \ forum \ classes\ClassUser.phpにT_FUNCTIONが必要です

問題の原因となっているコードのセグメント:

include $_SERVER["DOCUMENT_ROOT"]."forum/classes/general.inc";
Class User{


__construct($u,$p){ //this is line 7

    $user=$u;
    if(strlen($p)>30|| empty($p) || !preg_match('/[^a-zA-Z0-9]/i',$p)){
    $password=0;

    }
    else{
    $password=hash_hmac('md5',$p,KEY);

    }

}

ああ、私はphpに慣れていないので、私がすべきではないことをしている場合に備えて、お勧めしてください..事前に感謝します。

注:この投稿のフォーマットを混乱させているようだったので、phpタグを削除しました:/

注2:imも別の通知を受け取ります注意:未定義の定数KEYの使用-20行目のC:\ wamp \ www \ forum \ classes\general.incで「KEY」と見なされます

しかし、それはエラーよりも警告であると想定しています...しかし、エラーと関係がある場合に備えて追加するだけです

general.inc:

//error definations
define("ERROR_FIELD_EMPTY","Error! All required fields not filled");
define("ERROR_INVALID_SIGNIN","Error! Username/password do not match!");
define("ERROR_GENERAL_INPUT", "Error! Invalid input given");
define("ERROR_SQL_CONNECT","Error! Could not connect to sql database");


//field sizes
define("PASSWORD_LENGTH",12);
define("USERNAME_LENGTH",30);

//sql server details
define("SQL_SERVER_NAME","localhost");
define("SQL_SERVER_USERNAME","root");
define("SQL_SERVER_PASSWORD","");
define("SQL_SERVER_DATABASE","forums");

define(KEY,"key");


function __autoload($className){
    require_once($_SERVER["DOCUMENT_ROOT"]."forum/classes/Class$className.php");

}

ClassUser.php

  include $_SERVER["DOCUMENT_ROOT"]."forum/classes/general.inc";
    Class User{


    __construct($u,$p){

        $user=$u;
        if(strlen($p)>30|| empty($p) || !preg_match('/[^a-zA-Z0-9]/i',$p)){
        $password=0;

        }
        else{
        $password=hash_hmac('md5',$p,KEY);

        }

    }

    public function validate(){
        if(strlen($user)>30|| empty($user) || preg_match('/[^a-zA-Z0-9]/i',$password==0 )){
        throw new Exception(ERROR_GENERAL_INPUT);



        }
        $user=mysql_real_escape_string($user);
        return true;

    }

    public function insert(){
       // this->validate();

        $conn= mysqli_connect(SQL_SERVER_NAME,SQL_SERVER_USERNAME,SQL_SERVER_PASSWORD,SQL_SERVER_DATABASE);


        if(empty($conn)){
        throw new Exception(ERROR_SQL_CONNECT);
        }

        $query="INSERT into USERS VALUES ($user,$password)";
        $conn->query($query);



    }

    private $user;
    private $password;

    };

NewUser.php

 include $_SERVER["DOCUMENT_ROOT"]."forum/classes/general.inc";




    try{
    $user = new User($_POST['UserName'],$_POST['Password']);
    $user->insert();
    }

    catch(Exception $Error){
    echo $Error->getMessage();


    }
4

2 に答える 2

8

クラス内の他のメソッドと同じように(つまり、あなたの場合)、その前に__construct単語を置く必要があります。functionpublic functionvalidateinsert

つまり、次のものが必要です。

public function __construct($u,$p){ //this is line 7
于 2012-06-03T16:46:01.463 に答える
1

行を次のように変更します。

public function __construct($u, $p) {
于 2012-06-03T16:44:45.387 に答える