1

嘿伙计们希望你能帮助我..

只是为了让你提前知道,我是一个相对较新的 php 编码器,正在做一个练习项目,遇到了这个问题,我花了一个小时重新检查和谷歌搜索,但无法弄清楚是什么原因造成的

错误:解析错误:语法错误,意外的 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:我还收到另一条通知注意:使用未定义的常量 KEY - 在第 20 行的 C:\wamp\www\forum\classes\general.inc 中假定为“KEY”

但我假设这更像是一个警告而不是一个错误......但只是添加它与错误有关

通用公司:

//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");

}

类用户.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;

    };

新用户.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需要function在它前面加上这个词,或者更好的是,与public function类中的其他方法相同(即在你的情况下)。validateinsert

即您需要以下内容:

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 回答