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 Extension) REST Follow RedirectsDemonstrates how to follow a 302/303 redirect response.
<?php // The version number (9_5_0) should match version of the Chilkat extension used, omitting the micro-version number. // For example, if using Chilkat v9.5.0.48, then include as shown here: include("chilkat_9_5_0.php"); // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. $rest = new CkRest(); $bTls = true; $port = 443; $bAutoReconnect = true; $success = $rest->Connect('chilkatsoft.com',$port,$bTls,$bAutoReconnect); if ($success != true) { print $rest->lastErrorText() . "\n"; exit; } // Send a POST to a URL that will respond with a 302 redirect.. $rest->AddQueryParam('firstName','John'); $rest->AddQueryParam('lastName','Doe'); $responseText = $rest->fullRequestFormUrlEncoded('POST','/echoPost302.asp'); if ($rest->get_LastMethodSuccess() != true) { print $rest->lastErrorText() . "\n"; exit; } $statusCode = $rest->get_ResponseStatusCode(); // Examine the response status code if ($statusCode < 300) { print 'Not a redirect.' . "\n"; print $responseText . "\n"; exit; } if ($statusCode > 399) { print 'Error response: Status code = ' . $statusCode . "\n"; print $responseText . "\n"; exit; } print 'Redirect status code = ' . $statusCode . "\n"; // The response header will contain a Location field with the redirect URL, such as this: // Location: http://www.chilkatsoft.com/echoPostFinal.asp // The response status code determines how the client should behave. // Here are some common possibilities: // 301: Moved Permanently // This and all future requests should be directed to the given URI. (Keep the original HTTP method for the redirect. In this case, the // original request was a POST, so we POST to the redirect URL.) // 302: Found (aka Object Moved aka Moved Temporarily) // This is the most popular redirect code, but also an example of industrial practice contradicting the standard. HTTP/1.0 specification (RFC 1945 ) required the client // to perform a temporary redirect (the original describing phrase was Moved Temporarily), but popular browsers implemented it as a 303 See Other. Therefore, HTTP/1.1 // added status codes 303 and 307 to disambiguate between the two behaviors. However, the majority of Web applications and frameworks still use the 302 status code // as if it were the 303. // 303: See Other // The response to the request can be found under another URI using a GET method. When received in response to a PUT, it should be assumed that the server has // received the data and the redirect should be issued with a separate GET message. // 307: Temporary Redirect // In this occasion, the request should be repeated with another URI, but future requests can still use the original URI. In contrast to 303, the request method // should not be changed when reissuing the original request. For instance, a POST request must be repeated using another POST request. print $rest->responseHeader() . "\n"; // redirectUrl is a CkUrl $redirectUrl = $rest->RedirectUrl(); if ($rest->get_LastMethodSuccess() == false) { print 'No Location header found for redirect.' . "\n"; exit; } // Prep for the redirect.. $rest->ClearAllParts(); // Disconnect and re-connect. // (This can be skipped if both the host and SSL/TLS conditions are the same.) $rest->Disconnect(100); $success = $rest->Connect($redirectUrl->host(),$redirectUrl->get_Port(),$redirectUrl->get_Ssl(),$bAutoReconnect); if ($success != true) { print $rest->lastErrorText() . "\n"; exit; } if (($statusCode == 301) or ($statusCode == 307)) { // Redirect using a POST, sending the same params to the new destination $rest->AddQueryParam('firstName','John'); $rest->AddQueryParam('lastName','Doe'); $responseText = $rest->fullRequestFormUrlEncoded('POST',$redirectUrl->path()); if ($rest->get_LastMethodSuccess() != true) { print $rest->lastErrorText() . "\n"; exit; } } if (($statusCode == 302) or ($statusCode == 303)) { // Redirect using a GET, sending the query params found in the redirect URL. $responseText = $rest->fullRequestFormUrlEncoded('GET',$redirectUrl->pathWithQueryParams()); if ($rest->get_LastMethodSuccess() != true) { print $rest->lastErrorText() . "\n"; exit; } } // Show the final status code and the response text. print 'Final status code = ' . $rest->get_ResponseStatusCode() . "\n"; print 'Final response text (HTML, XML, JSON, or whatever..)' . "\n"; print $responseText . "\n"; ?> |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.