Как я могу подключиться к базе данных mysql с помощью бота LINE? - PullRequest
0 голосов
/ 12 марта 2019

У меня недавно LINE Bot работал на моем хостинге. https://github.com/line/line-bot-sdk-php

Я могу заставить его говорить довольно легко, используя настройки, которые я нашел здесь - https://github.com/afifmakarim/bot-line-simple

Это запутанная часть, я теряюсь в коде из-за недостаточного знания пространств имен. По-видимому, чтобы мой бот LINE мог получить данные из базы данных MySQL и отправить их обратно в виде сообщения, мне нужно использовать класс пространства имен.

В любом случае, я заблудился, может кто-нибудь указать мне правильное направление, пожалуйста?

Edit: Вот index.php

            <?php

            require __DIR__ . '/vendor/autoload.php';
            include 'include/dbconfig.php';
            include 'include/function.php';

            use\ LINE\ LINEBot\ SignatureValidator as SignatureValidator;

             load config
            $dotenv = new Dotenv\ Dotenv( __DIR__ );
            $dotenv->load();

             initiate app
            $configs = [
                settings' => [ 'displayErrorDetails' => true ],
            ];
            $app = new Slim\ App( $configs );

             ROUTES 
            $app->get( '/', function ( $request, $response ) {
                return "Working!";
            } );

            $app->post( '/', function ( $request, $response ) {
                 get request body and line signature header
                $body = file_get_contents( 'php://input' );
                $signature = $_SERVER[ 'HTTP_X_LINE_SIGNATURE' ];

                 log body and signature
                file_put_contents( 'php://stderr', 'Body: ' . $body );

                 is LINE_SIGNATURE exists in request header?
                if ( empty( $signature ) ) {
                    return $response->withStatus( 400, 'Signature not set' );
                }

                 is this request comes from LINE?
                if ( $_ENV[ 'PASS_SIGNATURE' ] == false && !SignatureValidator::validateSignature( $body, $_ENV[ 'CHANNEL_SECRET' ], $signature ) ) {
                    return $response->withStatus( 400, 'Invalid signature' );
                }

                 init bot
                $httpClient = new\ LINE\ LINEBot\ HTTPClient\ CurlHTTPClient( $_ENV[ 'CHANNEL_ACCESS_TOKEN' ] );
                $bot = new\ LINE\ LINEBot( $httpClient, [ 'channelSecret' => $_ENV[ 'CHANNEL_SECRET' ] ] );
                $data = json_decode( $body, true );
                foreach ( $data[ 'events' ] as $event ) {
                    $userMessage = $event[ 'message' ][ 'text' ];
                    $msgchunk = explode( " ", $userMessage );
                    Hello Example
                    if ( strtolower( $msgchunk[ 0 ] ) == 'hello' ) {
                        if ( strtolower( $msgchunk[ 1 ] ) == 'you' ) {
                            $message = "Hi you";
                            $textMessageBuilder = new\ LINE\ LINEBot\ MessageBuilder\ TextMessageBuilder( $message );
                            $result = $bot->replyMessage( $event[ 'replyToken' ], $textMessageBuilder );
                            return $result->getHTTPStatus() . ' ' . $result->getRawBody();

                        } else {
                            $message = "Hi";
                            $textMessageBuilder = new\ LINE\ LINEBot\ MessageBuilder\ TextMessageBuilder( $message );
                            $result = $bot->replyMessage( $event[ 'replyToken' ], $textMessageBuilder );
                            return $result->getHTTPStatus() . ' ' . $result->getRawBody();
                        }
                    }
                    Search for something
                    if ( strtolower( $msgchunk[ 0 ] ) == 'search' ) {
                        if ( strtolower( $msgchunk[ 1 ] ) == 'id' ) {
                            if ( !$msgchunk[ 2 ] ) {
                                $message = "Please include an id to search for.";
                                $textMessageBuilder = new\ LINE\ LINEBot\ MessageBuilder\ TextMessageBuilder( $message );
                                $result = $bot->replyMessage( $event[ 'replyToken' ], $textMessageBuilder );
                                return $result->getHTTPStatus() . ' ' . $result->getRawBody();
                            } else {
                                This is where i want it to retrieve data from mysql database using the getName($userid) function.
                                $message = getName($db_con,$userid);
                                $textMessageBuilder = new\ LINE\ LINEBot\ MessageBuilder\ TextMessageBuilder( $message );
                                $result = $bot->replyMessage( $event[ 'replyToken' ], $textMessageBuilder );
                                return $result->getHTTPStatus() . ' ' . $result->getRawBody();
                            }
                        } else {
                            $message = "What do you want to search for?
                            Try, Search id or Search Sub";
                            $textMessageBuilder = new\ LINE\ LINEBot\ MessageBuilder\ TextMessageBuilder( $message );
                            $result = $bot->replyMessage( $event[ 'replyToken' ], $textMessageBuilder );
                            return $result->getHTTPStatus() . ' ' . $result->getRawBody();
                        }
                    }
                    if ( strtolower( $userMessage ) == 'add member' ) {
                        $message = "Adding Member";
                        $textMessageBuilder = new\ LINE\ LINEBot\ MessageBuilder\ TextMessageBuilder( $message );
                        $result = $bot->replyMessage( $event[ 'replyToken' ], $textMessageBuilder );
                        return $result->getHTTPStatus() . ' ' . $result->getRawBody();

                    }
                    if ( strtolower( $userMessage ) == 'find member' ) {
                        $message = "Finding Member";
                        $textMessageBuilder = new\ LINE\ LINEBot\ MessageBuilder\ TextMessageBuilder( $message );
                        $result = $bot->replyMessage( $event[ 'replyToken' ], $textMessageBuilder );
                        return $result->getHTTPStatus() . ' ' . $result->getRawBody();

                    }
                    if ( strtolower( $userMessage ) == 'ihelp' ) {
                        $carouselTemplateBuilder = new\ LINE\ LINEBot\ MessageBuilder\ TemplateBuilder\ CarouselTemplateBuilder( [
                            new\ LINE\ LINEBot\ MessageBuilder\ TemplateBuilder\ CarouselColumnTemplateBuilder(
                                "Search",
                                "use this to search for member id.",
                                "https://myanimelist.cdn-dena.com/images/characters/8/320273.jpg", [
                                    new\ LINE\ LINEBot\ TemplateActionBuilder\ UriTemplateActionBuilder( 'Search', "Search id 15361839" ),
                                ] ),
                            new\ LINE\ LINEBot\ MessageBuilder\ TemplateBuilder\ CarouselColumnTemplateBuilder(
                                "Sub",
                                "use this to get a list of subs for an id",
                                "https://myanimelist.cdn-dena.com/images/characters/8/320273.jpg", [
                                    new\ LINE\ LINEBot\ TemplateActionBuilder\ UriTemplateActionBuilder( 'Sub', "Sub id 15361839" ),
                                ] ),
                        ] );
                        $templateMessage = new\ LINE\ LINEBot\ MessageBuilder\ TemplateMessageBuilder( 'template name', $carouselTemplateBuilder );
                        $result = $bot->replyMessage( $event[ 'replyToken' ], $templateMessage );
                        return $result->getHTTPStatus() . ' ' . $result->getRawBody();
                    }
                    if ( strtolower( $userMessage ) == "help" ) {
                        $buttonTemplateBuilder = new\ LINE\ LINEBot\ MessageBuilder\ TemplateBuilder\ ButtonTemplateBuilder(
                            "title",
                            "text",
                            "https://i0.wp.com/angryanimebitches.com/wp-content/uploads/2013/03/tamakomarket-overallreview-tamakoanddera.jpg", [
                                new\ LINE\ LINEBot\ TemplateActionBuilder\ MessageTemplateActionBuilder( 'Action Button', 'action' ),
                            ] );
                        $templateMessage = new\ LINE\ LINEBot\ MessageBuilder\ TemplateMessageBuilder( 'template name', $buttonTemplateBuilder );
                        $result = $bot->replyMessage( $event[ 'replyToken' ], $templateMessage );
                        return $result->getHTTPStatus() . ' ' . $result->getRawBody();
                    }
                    if ( $userMessage == "Send image" ) { //your message
                        $imageMessage = new\ LINE\ LINEBot\ MessageBuilder\ ImageMessageBuilder( "https://myanimelist.cdn-dena.com/images/characters/8/320273.jpg", "https://myanimelist.cdn-dena.com/images/characters/8/320273.jpg" );
                        $result = $bot->replyMessage( $event[ 'replyToken' ], $imageMessage );
                        return $result->getHTTPStatus() . ' ' . $result->getRawBody();
                    }
                }


            } );

             $app->get('/push/{to}/{message}', function ($request, $response, $args)
             {
                $httpClient = new \LINE\LINEBot\HTTPClient\CurlHTTPClient($_ENV['CHANNEL_ACCESS_TOKEN']);
                $bot = new \LINE\LINEBot($httpClient, ['channelSecret' => $_ENV['CHANNEL_SECRET']]);

                $textMessageBuilder = new \LINE\LINEBot\MessageBuilder\TextMessageBuilder($args['message']);
                $result = $bot->pushMessage($args['to'], $textMessageBuilder);

                return $result->getHTTPStatus() . ' ' . $result->getRawBody();
             });

             JUST RUN IT 
            $app->run();

Вот функция.php

            <?php

            function getName( $db_con, $userid ) {
                $dstmt = $db_con->prepare( "SELECT * FROM players WHERE p_id=:userid" );
                $dstmt->bindParam( ":userid", $userid );
                $dstmt->execute();
                $drow = $dstmt->fetch();
                return $drow[ 'pname' ];

            }

            ?>

Вот dbconfig.php

$db_host = "localhost";
$db_name = "*****";
$db_user = "*****";
$db_pass = "*****";

try{

    $db_con = new PDO("mysql:host={$db_host};dbname={$db_name}",$db_user,$db_pass);
    $dbh = $db_con;
    $db_con->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
}
catch(PDOException $e){
    echo $e->getMessage();
}

Это то, что я пробовал, и это не работает. Если кто-то хочет что-то указать, пожалуйста, сделайте. Я не пытаюсь быть опытным программистом, это просто хобби, которое я развил.

...