![]() |
Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(PHP ActiveX) Conversation with Streaming ResponsesSee more AI ExamplesDemonstrates an AI conversation with receiving streaming responses.Note: This example requires Chilkat v11.2.0 or greater.
<?php $success = 0; // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. $ai = new COM("Chilkat.Ai"); // The provider can be "openai", "google", "claude", "deepseek", "xai", or "perplexity". // Support for additional providers will be added in future versions of Chilkat. $ai->Provider = 'google'; // Use your provider's API key. $ai->ApiKey = 'MY_API_KEY'; // Choose a model. $ai->Model = 'gemini-2.5-flash'; // Indicate streaming mode is to be used. $ai->Streaming = 1; // Create a new conversation to be maintained locally in memory. // If the conversation is the first to be created, it is also automatically selected. $systemMsg = 'You are a creative storyteller'; $developerMsg = ''; $conversationName = 'test_conversation'; $ai->NewConvo($conversationName,$systemMsg,$developerMsg); // Add a text input. $ai->InputAddText('Write a detailed story about a turtle who decides to run a bakery. Describe the setting, the kinds of pastries, how the turtle feels, and include at least three paragraphs.'); // Ask the AI for text output. $success = $ai->Ask('text'); if ($success == 0) { print $ai->LastErrorText . "\n"; exit; } $sbEventName = new COM("Chilkat.StringBuilder"); $sbDelta = new COM("Chilkat.StringBuilder"); $sbFullResponse = new COM("Chilkat.StringBuilder"); $finished = 0; $abortFlag = 0; $maxWaitMs = 5000; while (!$finished) { $result = $ai->PollAi($abortFlag); if ($result == 1) { // We have output waiting. It should be instantly available. The maxWaitMs is just-in-case. $success = $ai->NextAiEvent($maxWaitMs,$sbEventName,$sbDelta); if ($success == 0) { print $ai->LastErrorText . "\n"; exit; } // Some AI providers send many "empty" events. Just ignore them. if (!$sbEventName->ContentsEqual('empty',1)) { // The delta contains the new output. This could be emitted to a display or the terminal // as real-time output. if ($sbEventName->ContentsEqual('delta',1)) { // This example will emit each delta to its own line. print $sbDelta->getAsString() . "\n"; // Accumulate the delta's so we can show the full response later. $sbFullResponse->AppendSb($sbDelta); } else { // A streaming AI response is always terminated by a single "null_terminator" event. $finished = $sbEventName->ContentsEqual('null_terminator',1); } } } else { if ($result == 0) { // Nothing is immediately available. Sleep for 1/10 of a second before polling again. $ai->SleepMs(100); } else { // Something failed.. print $ai->LastErrorText . "\n"; $finished = 1; } } } // ------------------------------------------------------------- // The response is in markdown format. // Also see Markdown to HTML Conversion Examples. // ------------------------------------------------------------- // Show the accumulated (full) response. print '----' . "\n"; print $sbFullResponse->getAsString() . "\n"; print '----' . "\n"; // ---------------------------------------------------------------------------------------------------------- // For the 2nd request in this conversation, ask for a shorter version of the story. $ai->InputAddText('Rewrite the story, but this time make it shorter, about one third as long.'); $success = $ai->Ask('text'); if ($success == 0) { print $ai->LastErrorText . "\n"; exit; } $sbFullResponse->Clear(); $finished = 0; while (!$finished) { $result = $ai->PollAi($abortFlag); if ($result == 1) { // We have output waiting. It should be instantly available. The maxWaitMs is just-in-case. $success = $ai->NextAiEvent($maxWaitMs,$sbEventName,$sbDelta); if ($success == 0) { print $ai->LastErrorText . "\n"; exit; } // Some AI providers send many "empty" events. Just ignore them. if (!$sbEventName->ContentsEqual('empty',1)) { // The delta contains the new output. This could be emitted to a display or the terminal // as real-time output. if ($sbEventName->ContentsEqual('delta',1)) { // This example will emit each delta to its own line. print $sbDelta->getAsString() . "\n"; // Accumulate the delta's so we can show the full response later. $sbFullResponse->AppendSb($sbDelta); } else { // A streaming AI response is always terminated by a single "null_terminator" event. $finished = $sbEventName->ContentsEqual('null_terminator',1); } } } else { if ($result == 0) { // Nothing is immediately available. Sleep for 1/10 of a second before polling again. $ai->SleepMs(100); } else { // Something failed.. print $ai->LastErrorText . "\n"; $finished = 1; } } } print '----' . "\n"; print $sbFullResponse->getAsString() . "\n"; ?> |
||||
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.