Sample code for 30+ languages & platforms
Ruby

Fetch ISBN XML from isbndb.com and Parse

See more HTTP Examples

Demonstrates sending a query to isbndb.com and parsing the XML response.

Chilkat Ruby Downloads

Ruby
require 'chilkat'

success = false

# This example assumes the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.

http = Chilkat::CkHttp.new()

# The access_key in this URL is a valid access key, but limited to 100 queries per day.
# If the key does not work, it may be that others were testing and exhausted the limit.
strXml = http.quickGetStr("http://isbndb.com/api/books.xml?access_key=OV8L2Y9I&results=details&index1=isbn&value1=0443074348")
if (http.get_LastMethodSuccess() != true)
    print http.lastErrorText() + "\n";
    exit
end

xml = Chilkat::CkXml.new()
success = xml.LoadXml(strXml)

# The XML returned for this URL is the following:

# <?xml version="1.0" encoding="UTF-8" ?>

# <ISBNdb server_time="2007-10-25T14:07:25Z">
#     <BookList total_results="1" page_size="10" page_number="1" shown_results="1">
#         <BookData book_id="diagnostic_histopathology_of_tumors_2_volume_set_with_cd_rom" isbn="0443074348">
#             <Title>Diagnostic Histopathology of Tumors: 2-Volume Set with CD-ROMs</Title>
#             <TitleLong>Diagnostic Histopathology of Tumors: 2-Volume Set with CD-ROMs (Diagnostic Histopathology of Tumors (Fletcher))</TitleLong>
#             <AuthorsText>Christopher D. M. Fletcher (Editor)</AuthorsText>
#             <PublisherText publisher_id="churchill_livingstone">Churchill Livingstone</PublisherText>
#             <Details dewey_decimal="616" physical_description_text="2166 pages" language="" edition_info="Hardcover; 2007-03-13" dewey_decimal_normalized="616" lcc_number="" change_time="2006-12-13T14:53:42Z" price_time="2007-10-25T01:12:13Z" />
#         </BookData>
#     </BookList>
# </ISBNdb>

# First, navigate to the BookData node:
success = xml.FirstChild2()
success = xml.FirstChild2()

# Show the Title and AuthorsText:
print xml.getChildContent("Title") + "\n";
print xml.getChildContent("AuthorsText") + "\n";

# Show the publisher_id attribute of the PublisherText node:

# xml2 is a CkXml
xml2 = xml.FindChild("PublisherText")
print xml2.getAttrValue("publisher_id") + "\n";

# Save the XML to a file:
success = xml.SaveXml("book.xml")