Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/242.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 获取用户所选项目的id?_Php_Html_Mysql_Arrays_Post - Fatal编程技术网

Php 获取用户所选项目的id?

Php 获取用户所选项目的id?,php,html,mysql,arrays,post,Php,Html,Mysql,Arrays,Post,在phtml文件中,我的所有数据库都显示在一个表中,包括price、id等,然后在php文件的详细信息中,当用户尝试按rent时,它获取商品的id,并使用add方法将其存储在商店中,我一直收到此错误 Fatal error: Function name must be a string. 我从数据库中存储项目id的原因是,当用户签出时,我将使用用户选择的项目id检索所有信息。我还使用数组列表来存储多个项目,另一个需要说明的是,获取项目id的方法是通过局部变量$tem=$\u POST['$dv

在phtml文件中,我的所有数据库都显示在一个表中,包括price、id等,然后在php文件的详细信息中,当用户尝试按rent时,它获取商品的id,并使用add方法将其存储在商店中,我一直收到此错误

Fatal error: Function name must be a string.
我从数据库中存储项目id的原因是,当用户签出时,我将使用用户选择的项目id检索所有信息。我还使用数组列表来存储多个项目,另一个需要说明的是,获取项目id的方法是通过局部变量$tem=$\u POST['$dvdDetails->getDvdId'];在添加购物车文件中,但我不确定它是否存储了正确的值,因为有一个foreach循环,并且变量的持续时间将在方法结束时被扭曲,因此如何获得已选择项目的id

<?php
    require_once('Models/Product.php');

    class Shop {
         private $_products = array();

        public function getProducts() 
            { return $this->_products;}

        public function addProduct(Product $product) 
            { $this->_products[] = $product; 
              return $this;
            }

    }

    ?>


    <?php


    class Option {
      private $_optionKey;
        private $_optionValue;

        public function getKey()
            { return $this->_optionKey; }

        public function getVlue()
            { 
            return $this->_optionValue; 

            }

        public function setOption($key, $value)
            { 
              $this->_optionKey = $key;
              $this->_optionValue = $value;
              return $this;
            }
    }

    ?>


    <?php
    require_once('Models/Option.php');



    class Product {
        private $_options = array();

        public function getOptions()
            { return $this->_options; }

        public function addOption(Option $option)
            { $this->_options[] = $option;
              return $this;
            }
    }

    ?>
    //SHow all 
    <?php require('template/header.phtml') ?> 
    <form action="<?php echo $_SERVER['PHP_SELF']; ?>" method="post"> 

     <table class="datatable"> 
     <tbody> 

     <?php foreach ($view->dd as $dvdDetails) { 

     echo '<tr> <td>' 
           .'<img src="images/'. $dvdDetails->getPhotoDetails() .'"alt="no picture" height="240" width="820" />' .'<br><br>'.'<font size="3" color="#2E2E2E"><center>'. $dvdDetails->getDvdPhoto(). '</center></font>'.
             '<br><br><br>'.  '<font size="2" color="blue"><strong>Genre: </strong></font>'.  $dvdDetails->getDvdGenre() .
              '<br><br>'. '<font size="2" color="blue"><strong>Director: </strong></font>'.  $dvdDetails->getDvdDirector() . '<br><br>' .'<font size="2" color="blue"><strong>Ritels: </strong></font>'. $dvdDetails->getDvdRitels() .
             '<br><br>' . '<font size="2" color="blue"><strong>Price for rent: </strong></font>'. $dvdDetails->getDvdId()) . 
       '<br><br>' .
          '<div class="ghassar">' .
             '<div id="op"> <label>Number of days </label> <select name="days" > <option>1</option> <option>2</option> <option>3</option> <option>4</option> <option>5</option> 
     </select> 
     <br><br><br><br> 

     </div> 



     <div> 



     <input type="submit" value="Add to the basket" name="rent" id="buttom1" /> 
     </div> ' . '<br><br>' .
           '<br><br>' .'<div>'.

    '</td> </td> </tr>'; 
     } ?> 
     </tbody> 
    </table>
     <?php require('template/footer.phtml') ?>
//添加到购物车

<?php
require_once('Models/Dvd_sql.php'); 
require_once('Models/Shop.php');  


$view = new stdClass(); 
$view->dd = 'SQL'; 
$dvd_sql = new Dvd_sql(); 
$view->dd  = $dvd_sql->fetchAllStudents();    //->fetchAllStudents(); 
if (isset($_POST['rent']))
{
    $tem = $_POST(['$dvdDetails->getDvdId()']);
 $shop = new Shop(); $shop->addProduct($tem);
}

   require_once('Views/dvdDetails.phtml');

我认为您要做的是将DVD的ID从表单页面输入表单处理页面。假设是这样的话,你在做这件事的时候会遇到一些问题

首先,$\u POST['$dvdDetails->getDvdId']在POST数据中查找与字符串'$dvdDetails->getDvdId'匹配的字符串键。PHP不会对单引号中的字符串进行插值,即使使用双引号,您也确实希望使用简单变量和/或使用{$方括号}。 其次,在我看来,对象$dvdDetails甚至不存在于表单处理脚本中。我只在表单显示代码中看到它,而这不会自动将它转移到处理脚本。您需要在表单中显式传递所需的数据。为此,您可以这样做: 以字符串连接样式后面的形式

编辑 第一次,我错过了你在循环播放很多DVD的事实。在这种情况下,我的建议将导致许多item_id输入,我认为处理脚本将只看到最后一个。你的日子也会遭遇同样的问题。在这种情况下,我认为最简单的解决方案是为每张DVD创建一个单独的表单,并使用我上面的建议。这样,当您提交特定DVD的表单时,只会发送一份日期和项目id的副本

'<input type="hidden" name="item_id" value="' . $dvdDetails->getDvdId() . '">' .
$item_id = $_POST['item_id'];