Forging a ChatBot in the Digital Wilderness

Forging a ChatBot in the Digital Wilderness

In the relentless landscape of technological evolution, silence is not the absence of action—it is the crucible of creation. While the world gazed elsewhere, I had been meticulously crafting my digital arsenal: creating some unpublished novels, enhancing the Quitus Small Business Suite, pushing database boundaries with IllicoDB3, and most critically, exploring the uncharted territories of Artificial Intelligence with ChatGPT.

Today, I stand ready to unveil the first expedition of a bold technological journey—a comprehensive guide to constructing your own ChatBot. This isn't merely a tutorial; it's a roadmap through the complex terrain of AI development that will probably span multiple articles. Like a seasoned explorer charting unknown waters, I will guide you from the broad, generalist landscapes of conversational AI towards the specialized, intricate ecosystems of domain-specific intelligence.

Prepare yourself. What follows is not just code—it's a narrative of technological conquest, where each line of PHP represents a strategic manoeuvre in the grand campaign of digital innovation.

La première chose dont nous avons besoin c'est évidemment d'un compte ChatPGPT. Je vous ai initié à la création de ce genre de compte dans mes articles "https://www.dhirubhai.net/pulse/using-chatgpt-digital-transformation-patrick-boens-zzkje/ ", "https://www.dhirubhai.net/pulse/create-account-patrick-boens-2zoae/ " et "https://www.dhirubhai.net/pulse/programmatic-interaction-chatgpt-patrick-boens-g7p2e/ ". Avec ces trois articlezs vous avez tout ce dont vous avez besoin, y compris la clef qui vous permet d'appeler ChatGPT, c'est-à-dire la clef d'API.

la seconde chose dont vous avez besoin est de conna?tre l'URL à appeler dans ChatGPT pour interagir avec le moteur de Chat. C'est simple ... c'est "https://api.openai.com/v1/chat/completions ". Le reste est d'une simplicité enfantine, si si, je vous assure !

The Digital Gateway: Unlocking the Power of ChatGPT

In the treacherous landscape of technological innovation, two critical artifacts are your passport to the realm of AI interaction: an OpenAI account and the sacred coordinates of communication.

The First Conquest: Your OpenAI Passport

Like a seasoned explorer preparing for an expedition into uncharted digital territories, your journey begins with establishing your OpenAI credentials. My previous reconnaissance missions—meticulously documented in a trilogy of strategic guides—have already mapped the intricate path to account creation. These chronicles not only illuminate the route but also reveal the most precious treasure: the API key, your master key to the AI kingdom are here: "https://www.dhirubhai.net/pulse/using-chatgpt-digital-transformation-patrick-boens-zzkje/ ", "https://www.dhirubhai.net/pulse/create-account-patrick-boens-2zoae/ " and"https://www.dhirubhai.net/pulse/programmatic-interaction-chatgpt-patrick-boens-g7p2e/ ".

The Sacred Coordinates: Navigating the API Realm

With the precision of a master cartographer, I unveil the critical navigation point for your ChatGPT interactions:

https://api.openai.com/v1/chat/completions        

This singular URL is your direct line of communication with the AI engine—a digital coordinate as simple yet powerful as a navigator's most trusted compass. Do not be deceived by its apparent simplicity; within this string lies the potential to transform raw data into intelligent conversation.

The Digital Forge: Crafting Our ChatBot Arsenal

In the relentless landscape of technological innovation, we stand at the precipice of creation. Our mission: to forge a ChatBot that will not merely respond, but communicate with surgical precision.

The Architectural Blueprint

Our arsenal will comprise four critical components:

  • HTML: The structural skeleton
  • CSS: The visual armor
  • JavaScript: The responsive nervous system
  • PHP: The intelligent core

We're not just building a chatbot. We're engineering an intelligent communication platform that will adapt, learn, and respond with the precision of a finely-tuned instrument.

Are you prepared to embark on this technological odyssey? Shall we begin constructing our digital sentinel, line by meticulously crafted line? Here's the code:

<!DOCTYPE html>

<html lang="fr">

    <head itemscope itemtype="https://schema.org/WebSite">

        <!-- Author paradeigma: Pat Y. Boens -->

        <meta charset='UTF-8' />
        <meta http-equiv='content-type' content='text/html; charset=UTF-8' />
        <title itemprop='name'>Sermo Chatbot</title>
        <meta name="viewport"       content="width=device-width, initial-scale=1, minimum-scale=1, maximum-scale=1">
        <meta name="description"    content="ChatBot creation">
        <link href='1000.css' rel='stylesheet' type='text/css' />

        <style>
            .chat-container { max-width: 95%;
                width: 95%;
                margin: 20px auto;
                padding: 20px;
                border: 1px solid #ccc;
            }
            .chat-messages {
                height: 400px;
                overflow-y: auto;
                margin-bottom: 10px;
                padding: 10px;
                border: 1px solid #eee;
            }
            .input-container {
                display: flex;
                gap: 10px;
            }
            input[type="text"] {
                flex: 1;
                padding: 8px;
            }
            .message {
                margin: 10px 0;
                padding: 8px;
                border-radius: 5px;
            }
            .user-message {
                background-color: #e3f2fd;
                margin-left: 20px;
            }
            .bot-message {
                background-color: #f5f5f5;
                margin-right: 20px;
            }
        </style>

    </head>

    <body>

        <h1>Chatbot</h1>

        <div class="chat-container">
            <div id="chat-messages" class="chat-messages"></div>
            <form id="chat-form" method="post" class="input-container">
                <input type="text" name="message" id="message" placeholder="Your message..." required>
                <button type="submit">Submit</button>
            </form>
        </div>

        <?php
            $response = "";

            if ( $_SERVER['REQUEST_METHOD'] === 'POST' && ! empty( $_POST[ 'message' ] ) )
            {
                // ?? Replace 'YOUR_API_KEY' with your own key
                $bot = new ChatGPTBot( 'YOUR_API_KEY' );
                $userMessage = $_POST['message'];
                $response = $bot->getResponse($userMessage);
                //var_dump( $response );
                echo "<script>
                    document.getElementById('chat-messages').innerHTML += 
                        '<div class=\"message user-message\"><strong>Vous:</strong> " . htmlspecialchars( addslashes( $userMessage ) ) . "</div>' +
                        '<div class=\"message bot-message\"><strong>Bot:</strong> "   . htmlspecialchars( addslashes( $response    ) ) . "</div>';
                    document.getElementById('message').value = '';
                    var chatMessages = document.getElementById('chat-messages');
                    chatMessages.scrollTop = chatMessages.scrollHeight;
                </script>";
            }
        ?>
    </body>
</html>

<?php
class ChatGPTBot
{
    private $api_key;
    private $api_url              = 'https://api.openai.com/v1/chat/completions';
    private $conversation_history = [];

    public function __construct( $api_key )
    {
        $this->api_key = $api_key;
    }
    
    public function getResponse($userInput)
    {
        $this->conversation_history[] = [
            'role' => 'user',
            'content' => $userInput
        ];

        $data = [ 'model'       => 'gpt-3.5-turbo',
                  'messages'    => $this->conversation_history,
                  'temperature' => 0.7,
                  'max_tokens'  => 150
                ];

        $headers = [ 'Content-Type: application/json',
                     'Authorization: Bearer ' . $this->api_key
                   ];

        $ch = curl_init($this->api_url);

        curl_setopt( $ch,CURLOPT_POST          ,1 );
        curl_setopt( $ch,CURLOPT_POSTFIELDS    ,json_encode( $data ) );
        curl_setopt( $ch,CURLOPT_HTTPHEADER    ,$headers );
        curl_setopt( $ch,CURLOPT_RETURNTRANSFER,true );

        $response  = curl_exec($ch);
        $http_code = curl_getinfo($ch, CURLINFO_HTTP_CODE);
        curl_close($ch);

        if ( $http_code === 200 )
        {
            $result = json_decode($response, true);
            $botResponse = $result['choices'][0]['message']['content'];
            $this->conversation_history[] = [ 'role'      => 'assistant',
                                              'content'   => $botResponse
                                            ];

            return $botResponse;
        }
        else
        {
            return "Sorry .... we have encountered an error";
        }
    }
}
?>        

Less than 150 lines of code and ... you believe it or not, you have built your first ChatBot !

Conclusion

With the introduction I've provided, I'd like to remind you of some old articles that should help you create your ChatGPT account and fund it with credits. You'll also find everything you need to generate an API key, if you haven't already done so. You have a PHP class to interact with ChatGPT in chat mode. You've got a minimal interface to test your first chatBot ... and it all adds up to this:


Previous article




要查看或添加评论,请登录

社区洞察

其他会员也浏览了