Home > Articles > Web Services > XML

XML Reference Guide

📄 Contents

  1. XML Reference Guide
  2. Overview
  3. What Is XML?
  4. Informit Articles and Sample Chapters
  5. Books and e-Books
  6. Official Documentation
  7. Table of Contents
  8. The Document Object Model
  9. Informit Articles and Sample Chapters
  10. Books and e-Books
  11. Official Documentation
  12. DOM and Java
  13. Informit Articles and Sample Chapters
  14. Books and e-Books
  15. Implementations
  16. DOM and JavaScript
  17. Using a Repeater
  18. Repeaters and XML
  19. Repeater Resources
  20. DOM and .NET
  21. Informit Articles and Sample Chapters
  22. Books and e-Books
  23. Documentation and Downloads
  24. DOM and C++
  25. DOM and C++ Resources
  26. DOM and Perl
  27. DOM and Perl Resources
  28. DOM and PHP
  29. DOM and PHP Resources
  30. DOM Level 3
  31. DOM Level 3 Core
  32. DOM Level 3 Load and Save
  33. DOM Level 3 XPath
  34. DOM Level 3 Validation
  35. Informit Articles and Sample Chapters
  36. Books and e-Books
  37. Documentation and Implementations
  38. The Simple API for XML (SAX)
  39. Informit Articles and Sample Chapters
  40. Books and e-Books
  41. Official Documentation
  42. SAX and Java
  43. Informit Articles and Sample Chapters
  44. Books and e-Books
  45. SAX and .NET
  46. Informit Articles and Sample Chapters
  47. SAX and Perl
  48. SAX and Perl Resources
  49. SAX and PHP
  50. SAX and PHP Resources
  51. Validation
  52. Informit Articles and Sample Chapters
  53. Books and e-Books
  54. Official Documentation
  55. Document Type Definitions (DTDs)
  56. Informit Articles and Sample Chapters
  57. Books and e-Books
  58. Official Documentation
  59. XML Schemas
  60. Informit Articles and Sample Chapters
  61. Books and e-Books
  62. Official Documentation
  63. RELAX NG
  64. Informit Articles and Sample Chapters
  65. Books and e-Books
  66. Official Documentation
  67. Schematron
  68. Official Documentation and Implementations
  69. Validation in Applications
  70. Informit Articles and Sample Chapters
  71. Books and e-Books
  72. XSL Transformations (XSLT)
  73. Informit Articles and Sample Chapters
  74. Books and e-Books
  75. Official Documentation
  76. XSLT in Java
  77. Java in XSLT Resources
  78. XSLT and RSS in .NET
  79. XSLT and RSS in .NET Resources
  80. XSL-FO
  81. Informit Articles and Sample Chapters
  82. Books and e-Books
  83. Official Documentation
  84. XPath
  85. Informit Articles and Sample Chapters
  86. Books and e-Books
  87. Official Documentation
  88. XML Base
  89. Informit Articles and Sample Chapters
  90. Official Documentation
  91. XHTML
  92. Informit Articles and Sample Chapters
  93. Books and e-Books
  94. Official Documentation
  95. XHTML 2.0
  96. Documentation
  97. Cascading Style Sheets
  98. Informit Articles and Sample Chapters
  99. Books and e-Books
  100. Official Documentation
  101. XUL
  102. XUL References
  103. XML Events
  104. XML Events Resources
  105. XML Data Binding
  106. Informit Articles and Sample Chapters
  107. Books and e-Books
  108. Specifications
  109. Implementations
  110. XML and Databases
  111. Informit Articles and Sample Chapters
  112. Books and e-Books
  113. Online Resources
  114. Official Documentation
  115. SQL Server and FOR XML
  116. Informit Articles and Sample Chapters
  117. Books and e-Books
  118. Documentation and Implementations
  119. Service Oriented Architecture
  120. Web Services
  121. Informit Articles and Sample Chapters
  122. Books and e-Books
  123. Official Documentation
  124. Creating a Perl Web Service Client
  125. SOAP::Lite
  126. Amazon Web Services
  127. Creating the Movable Type Plug-in
  128. Perl, Amazon, and Movable Type Resources
  129. Apache Axis2
  130. REST
  131. REST Resources
  132. SOAP
  133. Informit Articles and Sample Chapters
  134. Books and e-Books
  135. Official Documentation
  136. SOAP and Java
  137. Informit Articles and Sample Chapters
  138. Books and e-Books
  139. Official Documentation
  140. WSDL
  141. Informit Articles and Sample Chapters
  142. Books and e-Books
  143. Official Documentation
  144. UDDI
  145. UDDI Resources
  146. XML-RPC
  147. XML-RPC in PHP
  148. Informit Articles and Sample Chapters
  149. Books and e-Books
  150. Official Documentation
  151. Ajax
  152. Asynchronous Javascript
  153. Client-side XSLT
  154. SAJAX and PHP
  155. Ajax Resources
  156. JSON
  157. Ruby on Rails
  158. Creating Objects
  159. Ruby Basics: Arrays and Other Sundry Bits
  160. Ruby Basics: Iterators and Persistence
  161. Starting on the Rails
  162. Rails and Databases
  163. Rails: Ajax and Partials
  164. Rails Resources
  165. Web Services Security
  166. Web Services Security Resources
  167. SAML
  168. Informit Articles and Sample Chapters
  169. Books and e-Books
  170. Specification and Implementation
  171. XML Digital Signatures
  172. XML Digital Signatures Resources
  173. XML Key Management Services
  174. Resources for XML Key Management Services
  175. Internationalization
  176. Resources
  177. Grid Computing
  178. Grid Resources
  179. Web Services Resource Framework
  180. Web Services Resource Framework Resources
  181. WS-Addressing
  182. WS-Addressing Resources
  183. WS-Notifications
  184. New Languages: XML in Use
  185. Informit Articles and Sample Chapters
  186. Books and e-Books
  187. Official Documentation
  188. Google Web Toolkit
  189. GWT Basic Interactivity
  190. Google Sitemaps
  191. Google Sitemaps Resources
  192. Accessibility
  193. Web Accessibility
  194. XML Accessibility
  195. Accessibility Resources
  196. The Semantic Web
  197. Defining a New Ontology
  198. OWL: Web Ontology Language
  199. Semantic Web Resources
  200. Google Base
  201. Microformats
  202. StructuredBlogging
  203. Live Clipboard
  204. WML
  205. XHTML-MP
  206. WML Resources
  207. Google Web Services
  208. Google Web Services API
  209. Google Web Services Resources
  210. The Yahoo! Web Services Interface
  211. Yahoo! Web Services and PHP
  212. Yahoo! Web Services Resources
  213. eBay REST API
  214. WordML
  215. WordML Part 2: Lists
  216. WordML Part 3: Tables
  217. WordML Resources
  218. DocBook
  219. Articles
  220. Books and e-Books
  221. Official Documentation and Implementations
  222. XML Query
  223. Informit Articles and Sample Chapters
  224. Books and e-Books
  225. Official Documentation
  226. XForms
  227. Informit Articles and Sample Chapters
  228. Books and e-Books
  229. Official Documentation
  230. Resource Description Framework (RDF)
  231. Informit Articles and Sample Chapters
  232. Books and e-Books
  233. Official Documentation
  234. Topic Maps
  235. Informit Articles and Sample Chapters
  236. Books and e-Books
  237. Official Documentation, Implementations, and Other Resources
  238. Rich Site Summary (RSS)
  239. Informit Articles and Sample Chapters
  240. Books and e-Books
  241. Official Documentation
  242. Simple Sharing Extensions (SSE)
  243. Atom
  244. Podcasting
  245. Podcasting Resources
  246. Scalable Vector Graphics (SVG)
  247. Informit Articles and Sample Chapters
  248. Books and e-Books
  249. Official Documentation
  250. OPML
  251. OPML Resources
  252. Summary
  253. Projects
  254. JavaScript TimeTracker: JSON and PHP
  255. The Javascript Timetracker
  256. Refactoring to Javascript Objects
  257. Creating the Yahoo! Widget
  258. Web Mashup
  259. Google Maps
  260. Indeed Mashup
  261. Mashup Part 3: Putting It All Together
  262. Additional Resources
  263. Frequently Asked Questions About XML
  264. What's XML, and why should I use it?
  265. What's a well-formed document?
  266. What's the difference between XML and HTML?
  267. What's the difference between HTML and XHTML?
  268. Can I use XML in a browser?
  269. Should I use elements or attributes for my document?
  270. What's a namespace?
  271. Where can I get an XML parser?
  272. What's the difference between a well-formed document and a valid document?
  273. What's a validating parser?
  274. Should I use DOM or SAX for my application?
  275. How can I stop a SAX parser before it has parsed the entire document?
  276. 2005 Predictions
  277. 2006 Predictions
  278. Nick's Book Picks

In other guide sections, I've made the case for the Semantic Web, I've shown you an example of it in use in Google Base, and I've talked about microformats, the so-called (lowercase) semantic web. And all of this is fine, but what we really need is an easy way to produce this information on a regular basis.

If you're a blogger, and thus someone who regularly contributes content to the web, you can try StructuredBlogging. StructuredBlogging is a plug-in for two of of the most popular blogging programs, Wordpress and Movable Type, that makes it easy to create content that is easily analyzed. The StructuredBlogging initiative is also looking to implement microformats, so you can expect greater interoperation between the two of them in the future.

So let's look at how this works. The first step is to go to http://www.structuredblogging.org/download.php and download the StructuredBlogging plug-in for your blogging tool. At the time of this writing, the most recent version is 1pre15.

Once you download the plug-in, you'll need to install it. Instructions for both Wordpress and Movable Type are online, but since I use Movable Type, that's what we'll look at here.

Assuming that you have all of the prerequisites (Movable Type 3.2, MySQL, the XML::Parser Perl module and the LWP::UserAgent Perl module), start by installing the actual software. Unpack the archive file to your hard drive, and then copy all of the files from the plugins directory to the plugins directory of your MT installation. Make sure permissions are set such that the files are readable by your web server.

The StructuredBlogging plug-in enables you to add files such as images to some types of postings, so next you'll need somewhere to put them. Create a directory and make sure the web server can write to it. The actual name and location is immaterial; you'll be telling the plug-in where to find it when you do the configuration. That's the next step.

From the main menu of your Movable Type installation, choose the PLUGINS entry in the right hand column. You should see a listing for the new plugin, along with a Show Settings link on the right hand side. If the Show Settings link does not appear, edit the plugins/StructuredBlogging/StructuredBlogging.pl file as follows:

… author_link => 'http://www.broadbandmechanics.com/', version => '1.0pre15', config => \&configure_plugin_settings, config_template => sub { $structuredblogging->load_tmpl('settings_blog.tmpl') }, settings => new MT::PluginSettings([ ['blog_amazon_url', { Default => 'us' }], ['blog_amazon_affiliate'], …

Click the Show Settings link and enter the appropriate information into the form:

If you don't have an Amazon affiliate ID, that's all right, but it's certainly to your advantage to get one. The plugin inserts this value into any Amazon URLs that reference items you are reviewing. If someone clicks on that link, and then purchases an item, you get paid. Of course, if you really don't want to get one, you can leave it blank. (Or feel free to use my affiliate ID (thevanguardsc-20) if you're feeling generous.)

The OutputThis.org entries pertain to a site that enables you to simultaneously publish your postings to other blogs and destinations. Currently this site is still in beta, and configuring for it is not required.

Now you're ready to create an actual posting.

Creating structured postings

The whole idea behind StructuredBlogging is the thought that data can be marked up in an intelligent way, so it has to be entered in such a way that the plugin understands what the data means. In other words, you can't simply enter everything into one big paragraph and expect the software to figure it out. To that end, if you click on the New Entry button in the Movable Type management interface, you will see a number of new options in the left-hand navigation, including New Review, New List, and New Audio Post. Clicking New Review, gives you the opportunity to choose from a number of different options:

Each type of review has its own fields. For example, it doesn't make any sense to specify the Director of a journal article. For the sake of creating an example, let's create a new Book review:

If you have all of the prerequisites on your server -- specifically, LWP::UserAgent -- all you have to do is enter a title and click the Lookup link next to it. A small window will pop up enabling you to choose from appropriate items as listed on Amazon.com, and if you find the item you're reviewing, selecting it populates the rest of the entries on the page. The ones that involve your opinions, of course, such as the rating and the actual review, will still be left blank.

Complete your review and save the entry. (Note: do not use the "preview" option in Movable Type.)

Fixing the templates

Now, even though you've created a review, or any other type of StructuredBlogging post, if you actually view the pages of your blog, you will see a blank entry. This is because the post is not stored in the normal database location, so we have to adapt the Movable Type templates so they know to look for data stored by the StructuredBlogging plugin.

To do that, go back to the blog administration page and click Configure -> Templates. We'll start by making the post appear on the homepage of the blog. Under the Indexes tab, click the Main Index and add the following code:

...
<MTEntryCategories glue=" | ">
   <a href="<$MTCategoryArchiveLink$>"><$MTCategoryLabel$></a>
</MTEntryCategories>

</span>
 
   <$MTEntryBody$>

   <MTStructuredBloggingHTML>
   <MTStructuredBloggingXML>

          Technorati tags:   <MTEntryTags>
  <a href="http://www.technorati.com/tag/<$MTTag encode_url="1"$>"
    rel="TAG" title="TAG:<$MTTag$>"><$MTTag$></a> | 
  </MTEntryTags>

     <br /> <br />

   <MTEntryIfExtended>

   <div class="extended" style="margin-bottom: 10px"><a href="<$MTEntryPermalink$>#more">Continue reading "<$MTEntryTitle$>"</a></div><br />

   </MTEntryIfExtended>
…

Note that the actual placement of these two tags (which we'll discuss in a moment) will vary according to how your template is laid out, but the important part is that the content is near your <$MTEntryBody$> tag. The instructions on the StructuredBlogging web site will tell you to place these tags inside the <MTEntryIfExtended> element, but if you do, the information won't show up because these posts aren't extended entries.

Click the Archives tab and perform the same steps for the Category- and Date-based and Individual Entry archive templates.

You'll also want to add this information to your RSS feed, and/or to your Atom feed, if you have one. To do that, go back to the Indexes tab and edit the appropriate template as follows:

...
<description><$MTEntryBody encode_xml="1"$>
<MTStructuredBloggingHTML encode_xml="1">
<MTStructuredBloggingXML encode_xml="1"></description>
...

Seeing the results

Okay, so what does all of that actually mean? Let's look at the actual generated page:

All of the information is here, though you'll probably want to adjust the styling somewhat. But let's look at what actually happens on the backend. The two tags we added produced the following code in the actual page:

...
<div class="blogbody">

<a name="000772"></a>

<h3 class="title">Changing my life in seven days</h3>

<span style="margin-bottom: 10px; font-size: smaller;"><a href="http://www.chaosmagnet.com/blog/archives/cat_personal.html"
>Personal</a></span>

<!-- ******* MTStructuredBloggingHTML code starts here ******** -->

<div id="sbentry_772">

  <div class='hreview x-wpsb-review-book'>
     <div>

        <h3 class='item fn'><a class='url' href='http://www.amazon.com/exec/obidos/ASIN/1400082870/thevanguardsc-20/102-6251743-4557719?%5Fencoding=UTF8&camp=1789&link%5Fcode=xm2'>Change your life in seven days</a></h3>

         <p><div><img src="https://ec1.images-amazon.com/images/P/1400082870.01._SCTHUMBZZZ_.jpg"/></div></p>

         <div><b>Rating</b>: <span class="rating">5</span> out of 5<div class="sb-fullstar"> </div><div class="sb-fullstar"> </div><div class="sb-fullstar"> </div><div class="sb-fullstar"> </div><div class="sb-fullstar"> </div></div>

         <p><b>Author</b>: Paul McKenna</p>
         
         <p><b>Year</b>: 2005</p>

         <p><b>Category</b>: Personal development</p>
         <p><b>Publisher</b>: Harmony</p>
         <p><b>Price</b>: 14.95</p>

         <p><b>ISBN</b>: <span class='Z3988' title='ctx_ver=Z39.88-2004&rft_val_fmt=info:ofi/fmt:kev:mtx:book&rft.isbn=1400082870'>1400082870</span></p>
      </div>

      <div class='description'>With a title like "Change Your Life in Seven Days", expectations are pretty high for a book like this.  But I have to say, this book really lives up to the promise of its title.  I've never seen any book that so clearly pointed out in not just what I was doing, but also how I was reacting to everything around me.  This book makes everything so clear that you will wonder why you didn't do this years ago. Buy this book!</div>
      <p><b>Tags</b>: personal development, self-help</p>
   </div>

</div>

<!-- ******** MTStructuredBloggingHTML code ends here ******** -->

<!-- ******** MTStructuredBloggingXML code starts here ******** -->

<script type="application/x-subnode; charset=utf-8">
<!-- the following is structured blog data for machine readers. -->
<subnode alternate-for-id="sbentry_772" xmlns:data-view="http://www.w3.org/2003/g/data-view#" data-view:transformation="http://structuredblogging.org/subnode-to-rdf-interpreter.xsl" xmlns="http://www.structuredblogging.org/xmlns#subnode">
<xml-structured-blog-entry xmlns="http://www.structuredblogging.org/xmlns">

<generator id="mtsb-772" type="x-mtsb-post" version="1"/>
<review><subject year="2005" isbn="1400082870" publisher="Harmony" name="Change your life in seven days" url="http://www.amazon.com/exec/obidos/ASIN/1400082870/thevanguardsc-20/102-6251743-4557719?%5Fencoding=UTF8&camp=1789&link%5Fcode=xm2" image="http://ec1.images-amazon.com/images/P/1400082870.01._SCTHUMBZZZ_.jpg" author="Paul McKenna" price="14.95" category="Personal development" /><rating min="0" max="5">5</rating><description>With a title like "Change Your Life in Seven Days", expectations are pretty high for a book like this.  But I have to say, this book really lives up to the promise of its title.  I've never seen any book that so clearly pointed out in not just what I was doing, but also how I was reacting to everything around me.  This book makes everything so clear that you will wonder why you didn't do this years ago. Buy this book!</description><tags>personal development, self-help</tags></review></xml-structured-blog-entry>

</subnode>
</script>

<!-- ******** MTStructuredBloggingXML code ends here ******** -->

If you read the previous entry on microformats, much of this information is going to look familiar. The StructuredBlogging plugin simply takes the information then outputs it in the appropriate microformat format.

What's more, the MTStructuredBloggingXML tag adds the XML representation, making it even easier for aggregators and other applications to analyze the data.

The end result is that it becomes fairly straightforward to enter structured data, enabling you and every other everyday blogger to more easily contribute to the semantic web.

InformIT Promotional Mailings & Special Offers

I would like to receive exclusive offers and hear about products from InformIT and its family of brands. I can unsubscribe at any time.