调用类的函数不起作用php

时间:2018-12-15 14:56:57

标签: php

我有一个名为“ purchases.controller.php”的php文件,其中在“购买”类的名为“ ctrCash”的函数中,我将变量传递给了“ CartController”类的名为“ ctrNewCashPurchase”的函数。已经定义,但是当我运行项目时,我收到消息:

  

“致命错误:未捕获的错误:在...中找不到类'CartModel'”

如果我在函数ctrNewCashPurchase中执行var_dump,我意识到我正在输入该函数,但是它告诉我它无法识别“ CartModel”,我也不明白为什么。

我共享“ purchases.controller.php”文件的代码:

class CartController{

    static public function ctrNewCashPurchase($datos){

        $tabla = "compras";

        $respuesta = CartModel::mdlNewCashPurchase($tabla, $datos);

        if($respuesta == "ok"){

            $tabla = "comentarios";
            ModeloUsuarios::mdlIngresoComentarios($tabla, $datos);

        }

        return $respuesta;

    }      

}

class Purchases {

    public function ctrCash (&$arrayCompleto, &$usuario, &$direccion1, &$direccion2, &$dia, &$hora, &$email, &$telefono, &$sesion){

        if(isset($usuario)){

             //Here I create an array
             for($i = 0; $i < count($arrayCompleto); $i++){

               $datos = array("idUsuario"=> $sesion,
                              "idProducto"=> $arrayCompleto[$i]["idProducto"],
                              "metodo"=> "Efectivo",
                              "email"=> $email,
                              "direccion"=> $direccion1,
                              "detalleDireccion"=> $direccion2,
                              "diaEnvio"=> $dia,
                              "horaEnvio"=> $hora,
                              "telefono"=> $telefono,
                              "pais"=> "ARG");

                }

             $respuesta = CartController::ctrNewCashPurchase($datos);

          }

     }

}

我共享“ purchases.model.php”文件的代码,在其中定义了CartModel类:

class CartModel{

    static public function mdlNewCashPurchase($tabla, $datos){

        $stmt = Conexion::conectar()->prepare("INSERT INTO $tabla (id_usuario, id_producto, metodo, email, direccion, pais, detalleDireccion, diaEnvio, horaEnvio, telefono) VALUES (:id_usuario, :id_producto, :metodo, :email, :direccion, :pais, :detalleDireccion, :diaEnvio, :horaEnvio, :telefono)");

        $stmt->bindParam(":id_usuario", $datos["idUsuario"], PDO::PARAM_INT);
        $stmt->bindParam(":id_producto", $datos["idProducto"], PDO::PARAM_INT);
        $stmt->bindParam(":metodo", $datos["metodo"], PDO::PARAM_STR);
        $stmt->bindParam(":email", $datos["email"], PDO::PARAM_STR);
        $stmt->bindParam(":direccion", $datos["direccion"], PDO::PARAM_STR);
        $stmt->bindParam(":pais", $datos["pais"], PDO::PARAM_STR);
        $stmt->bindParam(":detalleDireccion", $datos["detalleDireccion"], PDO::PARAM_STR);
        $stmt->bindParam(":diaEnvio", $datos["diaEnvio"], PDO::PARAM_STR);
        $stmt->bindParam(":horaEnvio", $datos["horaEnvio"], PDO::PARAM_STR);
        $stmt->bindParam(":telefono", $datos["telefono"], PDO::PARAM_INT);

        if($stmt->execute()){ 

            return "ok"; 

        }else{ 

            return "error"; 

        }

        $stmt->close();

        $tmt =null;
    }

}

并且我添加了另一个名为“ aux.php”的文件,以防它影响导致我的错误。这是在“ ctrCash”功能内发送“ purchases.controller.php”参数的方法

    if(isset($_POST['usuario'])){

    require ('purchases.controller.php');

    $arrayCompleto = json_decode($_POST['arrayCompleto'], true);

$usuario = $_POST['usuario']; 
$direccion1 = $_POST['direccion1']; 
$direccion2 = $_POST['direccion2']; 
$dia = $_POST['dia']; 
$hora = $_POST['hora']; 
$email = $_POST['email']; 
$telefono = $_POST['telefono']; 
$sesion = $_POST['sesion'];


 $payments = new Purchases(); 
$payments -> ctrCash($arrayCompleto, $usuario, $direccion1, $direccion2, $dia, $hora, $email, $telefono, $sesion);

    }

0 个答案:

没有答案