Как передать переменную из контроллера в ajax-запрос, а затем получить его в php-скрипте (codeigniter) - PullRequest
0 голосов
/ 17 мая 2019

Здравствуйте. Я хочу передать эту переменную: ID_person для просмотра, а затем отправить его в скрипт php для получения запрошенных данных из базы данных.

Контроллер:

 public function view($id){
        $data = array();

        if(!empty($id)){
            $data['zakaznici'] = $this->Zakaznici_model->getRows($id);              //$data['temperatures'] = $this->Temperatures_model->getRows($id); 
              $data['title'] = 'Údaje o zákazníkovi';
              $data['ID_person'] = $id;


            $this->load->view('zakazniciview', $data);

        }else{
            redirect('/zakaznici');
        }
    }

Пока я использую этот запрос на мой взгляд:

<script type="text/javascript">


$(function() {

  $.ajax({
    url: "http://localhost/skolaa/chart_vypozicky.php",
    type: "GET",
    success: function(data) {
      chartData = data;
      var chartProperties = {
        caption: "Celková suma za prenájmy počas jednotlivých rokov",
        xAxisName: "Rok",
        yAxisName: "Suma ",
        rotatevalues: "0",
        useDataPlotColorForLabels: "1",
        theme: "fusion"

      };
      apiChart = new FusionCharts({
        type: "column2d",
        renderAt: "chart-container",
        width: "550",
        height: "350",
        dataFormat: "json",
        dataSource: {
          chart: chartProperties,
          data: chartData
        }
      });
      apiChart.render();
    }
  });
});
</script>

Это работает, но мне нужно каким-то образом получить переменную ID_person из контроллера и отправить ее в сценарий chart_vypozicky.php , а затем извлечь ее в запросе в этом сценарии.

PHP-скрипт:

<?php
    //address of the server where db is installed
    $servername = "localhost";
    //username to connect to the db
    //the default value is root
    $username = "root";
    //password to connect to the db
    //this is the value you would have specified during installation of WAMP stack
    $password = "";
    //name of the db under which the table is created
    $dbName = "prenajom_sportovisk";
    //establishing the connection to the db.
    $conn = new mysqli($servername, $username, $password, $dbName);
    //checking if there were any error during the last connection attempt
    if ($conn->connect_error) {
      die("Connection failed: " . $conn->connect_error);
    }
    //the SQL query to be executed
    $query = "SELECT SUM(cena) as price, YEAR(DATUM) as rok FROM sportoviska_zakaznici where ID= "; //I need to retrieve that id variable here
    //storing the result of the executed query
    $result = $conn->query($query);
    //initialize the array to store the processed data
    $jsonArray = array();
    //check if there is any data returned by the SQL Query
    if ($result->num_rows > 0) {
      //Converting the results into an associative array
      while($row = $result->fetch_assoc()) {
        $jsonArrayItem = array();
        $jsonArrayItem['label'] = $row['rok'];
        $jsonArrayItem['value'] = $row['price'];
        //append the above created object into the main array.
        array_push($jsonArray, $jsonArrayItem);
      }
    }
    //Closing the connection to DB
    $conn->close();
    //set the response content type as JSON
    header('Content-type: application/json');
    //output the return value of json encode using the echo function.
    echo json_encode($jsonArray);
?>

Возможно ли как-нибудь это сделать? Буду очень благодарен за все предложения.

1 Ответ

0 голосов
/ 17 мая 2019

По вашему мнению, передайте ID_person, а затем используйте $ _GET ['ID_person'] на странице chart_vypozicky.php

<script type="text/javascript">


$(function() {

  $.ajax({
    url: "http://localhost/skolaa/chart_vypozicky.php",
    type: "GET",
    data:{ID_person:'<?php echo $ID_person; ?>'},
    success: function(data) {
      chartData = data;
      var chartProperties = {
        caption: "Celková suma za prenájmy počas jednotlivých rokov",
        xAxisName: "Rok",
        yAxisName: "Suma ",
        rotatevalues: "0",
        useDataPlotColorForLabels: "1",
        theme: "fusion"

      };
      apiChart = new FusionCharts({
        type: "column2d",
        renderAt: "chart-container",
        width: "550",
        height: "350",
        dataFormat: "json",
        dataSource: {
          chart: chartProperties,
          data: chartData
        }
      });
      apiChart.render();
    }
  });
});
</script>


<?php
    //address of the server where db is installed
    $servername = "localhost";
    //username to connect to the db
    //the default value is root
    $username = "root";
    //password to connect to the db
    //this is the value you would have specified during installation of WAMP stack
    $password = "";
    //name of the db under which the table is created
    $dbName = "prenajom_sportovisk";
    //establishing the connection to the db.
    $conn = new mysqli($servername, $username, $password, $dbName);
    //checking if there were any error during the last connection attempt
    if ($conn->connect_error) {
      die("Connection failed: " . $conn->connect_error);
    }
    //the SQL query to be executed
    $person_ID=$_GET['ID_person']
    $query = "SELECT SUM(cena) as price, YEAR(DATUM) as rok FROM sportoviska_zakaznici where ID='".$person_ID."'"; //I need to retrieve that id variable here
    //storing the result of the executed query
    $result = $conn->query($query);
    //initialize the array to store the processed data
    $jsonArray = array();
    //check if there is any data returned by the SQL Query
    if ($result->num_rows > 0) {
      //Converting the results into an associative array
      while($row = $result->fetch_assoc()) {
        $jsonArrayItem = array();
        $jsonArrayItem['label'] = $row['rok'];
        $jsonArrayItem['value'] = $row['price'];
        //append the above created object into the main array.
        array_push($jsonArray, $jsonArrayItem);
      }
    }
    //Closing the connection to DB
    $conn->close();
    //set the response content type as JSON
    header('Content-type: application/json');
    //output the return value of json encode using the echo function.
    echo json_encode($jsonArray);
?>

Используйте этот обновленный код

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...