0

我正在学习如何在 php 中使用类

我试图在我的数据库中插入信息,但它给了我这个错误

致命错误:在第 7 行的 C:\xampp\htdocs\kapa\classes\lol.php 中调用未定义的方法 Produto::introduzirProduto()

连接代码:

<?php

class dbConnect{
private $db_host;
            private $db_user;  
            private $db_pass;  
            private $emp_db = "mydb";

            var $connection;
            var $db_select;
            var $result;
            var $row;

            function __construct(){
                $this->db_host = "localhost";
                $this->db_user = "root";
                $this->db_pass = "";
            }

            function connect(){
                $this->connection = mysql_connect($this->db_host, $this->db_user, $this->db_pass);   //create connection
                    checkErr($this->$connection);

                $this->db_select = mysql_select_db($this->emp_db, $connection);
                    checkErr($this->db_select);
            }
}

?>

形式:

<?php
require_once 'introduzir.class.php';
?>
<form action="lol.php" method="POST" id="">
  <input type="text" name="id"/>
  <input type="submit" value="ok.." />
</form>

插入代码

<?php 
  require_once('conectar.php');

  class Produto  extends dbConnect {
        var $bd;
  }

     function Produto() {
        global $emp_db, $db_user, $db_pass, $db_host;
                $this->bd = new dbConnect();
                $this->bd->ligarBD($emp_db, $db_user, $db_pass, $db_host);
        }

        function introduzirProduto($id) {
            $sql = "INSERT INTO produto VALUES ('$id')";
            if($this->bd->executarSQL($sql)) return true;
            else return false;
        }


?>

<?php
require_once 'introduzir.class.php';

if($_REQUEST['id']!="") {

                            $produto = new Produto();
                            if($produto->introduzirProduto($_REQUEST['id'])) {

                                echo "Registo efectuado com sucesso !!!<br>";
                            } else {
                                echo "Problema encontado no Registo !!!<br>";
                            }


            } else {
                echo "ERRO: Deve introduzir a sua password...<br>";
            }

?>

我需要改变什么?

4

2 回答 2

1

您创建的名为 Produto 的类没有函数,您已经定义了$bd变量,然后您已经结束了该类的定义。您需要在变量声明之后删除大括号并将其放在函数之后,如下所示:

<?php 
  require_once('conectar.php');

  class Produto  extends dbConnect {
        var $bd;

        function Produto() {
                global $emp_db, $db_user, $db_pass, $db_host;
                $this->bd = new dbConnect();
                $this->bd->ligarBD($emp_db, $db_user, $db_pass, $db_host);
        }

        function introduzirProduto($id) {
            $sql = "INSERT INTO produto VALUES ('$id')";
            if($this->bd->executarSQL($sql)) return true;
            else return false;
        }
   }

?>

作为旁注,您有一个以大写字母开头的函数,而一个不以大写字母开头的函数,请尝试遵守更严格的命名约定,例如:始终以小写字母开头,后面的单词使用大写字母字母(与您的第二个功能一样)

于 2013-11-09T16:54:07.167 回答
0

You've closed the braces for your Produto class before the definition of the functions Produto() and introdizirProduto(). I strongly suggest you indent the code properly to avoid similar errors in future.

<?php 
require_once('conectar.php');

class Produto  extends dbConnect {
    public $bd;

    function Produto() {
        global $emp_db, $db_user, $db_pass, $db_host;
        $this->bd = new dbConnect();
        $this->bd->ligarBD($emp_db, $db_user, $db_pass, $db_host);
    }

    function introduzirProduto($id) {
        $sql = "INSERT INTO produto VALUES ('$id')";
        if($this->bd->executarSQL($sql)) return true;
        else return false;
    }
}

//Rest of your code follows.
?>

PS: var is deprecated in PHP, avoid its use.\

于 2013-11-09T16:54:44.450 回答