sql >> Database teknologi >  >> RDS >> Mysql

PHP MySQL Dialogflow

hver gang webhook udløses, skal du lytte til actions fra JSON-svar, fra action gjort omskifteren til actions

index.php

<?php
require 'get_enews.php';

function processMessage($input) {
    $action = $input["result"]["action"];
    switch($action){

        case 'getNews':
            $param = $input["result"]["parameters"]["number"];
            getNews($param);
            break;

        default :
            sendMessage(array(
                "source" => "RMC",
                "speech" => "I am not able to understand. what do you want ?",
                "displayText" => "I am not able to understand. what do you want ?",
                "contextOut" => array()
            ));
    }
}
function sendMessage($parameters) {
    header('Content-Type: application/json');
    $data = str_replace('\/','/',json_encode($parameters));
    echo $data;
}
$input = json_decode(file_get_contents('php://input'), true);
if (isset($input["result"]["action"])) {
    processMessage($input);
}
?>

get_enews.php

<?php
function getNews($param){
    require 'config.php';
    $getNews="";
    $Query="SELECT link FROM public.news WHERE year='$param'";
    $Result=pg_query($con,$Query);
    if(isset($Result) && !empty($Result) && pg_num_rows($Result) > 0){
    $row=pg_fetch_assoc($Result);
    $getNews= "Here is details that you require - Link: " . $row["link"];
        $arr=array(
            "source" => "RMC",
            "speech" => $getNews,
            "displayText" => $getNews,
        );
        sendMessage($arr);
    }else{
        $arr=array(
            "source" => "RMC",
            "speech" => "No year matched in database.",
            "displayText" => "No year matched in database.",
        );
        sendMessage($arr);
    }
}
?>

Så når handlingen bliver fanget, bliver den eksekveret og går i getNews($param); funktion her får jeg year som et svar fra brugeren i mit tilfælde, og jeg udfører forespørgslen i databasen og giver et svar tilbage fra databasen.




  1. vBulletin som login for hele webstedet (rediger:der er gjort en vis fremskridt)

  2. Laravel 4 Query Builder - gruppe Efter maks. dato

  3. Kunne ikke indlæse filen eller samlingen 'System.Data-fejl ved implementering af applikation på produktionsdatabase

  4. SQL Cross Join