Before you start using a specific Yahoo! Web Service within your own PHP 5 scripts, first you should get an “Application ID,” which is a key provided by Yahoo! that will let you use the services in question in the scope of your web site’s domain. As you might guess, to get this application ID you must complete a simple registration form, and if all goes well, you should receive the key in your email inbox in a very short time. Nothing too difficult, actually. Once you’ve received this key by email, then you’re ready to use the web services provided by Yahoo!, so considering that you’ve already completed this process successfully, it’s time to develop some code samples that will help you to grasp more clearly how to implement a specific web service with PHP 5. All right, to begin with, a simple GET request must be triggered to the URL where a particular web service runs, in order to get its corresponding results. These results, unless you specify another format, will be returned as XML data. To demonstrate how to make a request to the Yahoo! Web Search Service, below I coded an illustrative PHP 5 script, which first queries the mentioned web service using “Madonna” as the search term, and then fetches the corresponding results in XML format. Now that I have explained how this sample script will work, please study its respective signature: try{ // example using Yahoo! Search Web Service - search results are $request='http://search.yahooapis.com/WebSearchService/V1/ // trigger the http request if(!$results=file_get_contents($request)){ throw new Exception('Error requesting Yahoo! Web service'); } // display the results in XML format header('Content-type:text/xml;charset=iso-8859-1'); echo $results; } catch(Exception $e){ echo $e->getMessage(); exit(); } As you can see, using the Yahoo! Web Search Service with PHP 5 is actually a no-brainer process that only requires a few lines of code. In this case, the above code snippet triggers the request to the proper URL, including into the query string the application ID that you got previously, then the pertinent search term and finally (this parameter is optional) the number of results that must be returned to the browser. Lastly, these results are fetched by using the “file_get_contents()” PHP built-in function (make sure that “http” wrappers are enabled on your php.ini file), and displayed directly on the browser, in the following way: <ResultSet xsi:schemaLocation="urn:yahoo:srch <Result> <Title>Madonna</Title> <Summary>Official site of pop diva Madonna, with news, music, media, and fan club.</Summary> <Url>http://www.madonna.com/</Url> <ClickUrl>http://uk.wrs.yahoo.com/ <DisplayUrl>www.madonna.com/</DisplayUrl> <ModificationDate>1192518000</ModificationDate> <MimeType>text/html</MimeType> <Cache> <Url>http: //uk.wrs.yahoo.com/ </Url> <Size>18519</Size> </Cache> </Result> <Result> <Title>MySpace.com - Madonna - Pop / Rock - <Summary>Madonna MySpace page with news, blog, music downloads, <Url>http://www.myspace.com/madonna</Url> <ClickUrl>http://uk.wrs.yahoo.com/_ylt=A0Je5aqLHBZHhCMBlTbdmMwF; </ClickUrl> <DisplayUrl>www.myspace.com/madonna</DisplayUrl> <ModificationDate>1192518000</ModificationDate> <MimeType>text/html</MimeType> <Cache> <Url>http://uk.wrs.yahoo.com/_ylt=A0Je5aqLHBZHhCMBljbdmMwF; </Url> <Size>138157</Size> </Cache> </Result> <Result> <Title>Madonna (I)</Title> <Summary>Facts and filmography for the singer and actress.</Summary> <Url>http://www.imdb.com/name/nm0000187</Url> <ClickUrl>http://uk.wrs.yahoo.com/ </ClickUrl> <DisplayUrl>www.imdb.com/name/nm0000187</DisplayUrl> <ModificationDate>1192518000</ModificationDate> <MimeType>text/html</MimeType> <Cache> <Url>http://uk.wrs.yahoo.com/ </Url> <Size>97655</Size> </Cache> </Result> <Result> <Title>Madonna Song Lyrics: Home Page</Title> <Summary>Extensive collection of Madonna lyrics, organized by album. Includes lyrics to singles.</Summary> <Url>http://www.madonnalyrics.org/</Url> <ClickUrl>http://uk.wrs.yahoo.com/ </ClickUrl> <DisplayUrl>www.madonnalyrics.org/</DisplayUrl> <ModificationDate>1181286000</ModificationDate> <MimeType>text/html</MimeType> <Cache> <Url>http://uk.wrs.yahoo.com/ </Url> <Size>18749</Size> </Cache> </Result> </ResultSet> <!-- ws02.search.scd.yahoo.com uncompressed/chunked Wed Oct 17 --> Undoubtedly, at first glance the output returned by the Yahoo! Web Search service seems to be rather intimidating, but this is a mistaken impression. If you take a closer look at it, you’ll see that the entire output is wrapped into a pair of <ResultSet></ResultSet> nodes, and each of the pertinent results are contained in a pair of <Result></Result> tags too. This obviously implies that it’s perfectly possible to build a simple XML parser with PHP 5 that displays these results in a more readable format, but this process is out of the scope of this article. In addition, if you’re interested in learning more on this topic, you may want to look at the bunch of examples created by Rasmus Lerdorf, which are available for educational purposes, on the aforementioned Yahoo! Developer Network’s official web site. So far, so good. At this point I’m pretty sure that you grasped the logic that stands behind querying the Yahoo! Web Search Service with PHP 5. This is merely the beginning, however, since in the next section I’m going to show you how to implement the Video Search Service provided by Yahoo!, by using a script similar to the one coded previously. To see how this brand new Yahoo! web service can be utilized with PHP 5, please go ahead and read the next few lines. I’ll be there, waiting for you.
blog comments powered by Disqus |
|
|
|
|
|
|
|