As another example of accessing Java objects in PHP, we will use the Xalan-java XSLT engine from the Apache XML project. With this application, we can transform XML source files using instructions in a XSL file. This allows for a great number of interesting scenarios in the field of document processing and content management.
To get started, we need to place both xerces.jar and xalan.jar files (included in Xalan-Java version 1.2 from xml.apache.org) in your java.class.path, as defined in your php.ini file.
The function xslt_transform() takes XML and XSL files as parameters and returns the transformed output in a string. XML and XSL parameters can be filenames (eg. foo.xml) or fully resolved URI's (eg. http://localhost/foo.xml).
<?phpfunction xslt_transform($xml,$xsl) { // Create a XSLTProcessorFactory object. XSLTProcessorfactory is a Java // class which manufactures the processor for performing transformations. $XSLTProcessorFactory = new java("org.apache.xalan.xslt.XSLTProcessorFactory"); // Use the XSLTProcessorFactory method getProcessor() to create a // new XSLTProcessor object. $XSLTProcessor = $XSLTProcessorFactory->getProcessor(); // Use XSLTInputSource objects to provide input to the XSLTProcessor // process() method for transformation. Create objects for both the // xml source as well as the XSL input source. Parameter of // XSLTInputSource is (in this case) a 'system identifier' (URI) which // can be an URL or filename. If the system identifier is an URL, it // must be fully resolved. $xmlID = new java("org.apache.xalan.xslt.XSLTInputSource", $xml); $stylesheetID = new java("org.apache.xalan.xslt.XSLTInputSource", $xsl); // Create a stringWriter object for the output. $stringWriter = new java("java.io.StringWriter"); // Create a ResultTarget object for the output with the XSLTResultTarget // class. Parameter of XSLTResultTarget is (in this case) a 'character // stream', which is the stringWriter object. $resultTarget = new java("org.apache.xalan.xslt.XSLTResultTarget", $stringWriter); // Process input with the XSLTProcessors' method process(). This // method uses the XSL stylesheet to transform the XML input, placing // the result in the result target. $XSLTProcessor->process($xmlID,$stylesheetID,$resultTarget); // Use the stringWriters' method toString() to // return the buffer's current value as a string to get the // transformed result. $result = $stringWriter->toString(); $stringWriter->close(); return($result);}?>
Then, you can call this function as shown in the example below. $xml contains a string with the fully resolved URL of XML file. $xsl contains string with a XSL stylesheet URL containing rules for conversion to generic HTML. $out will contain a string with output, as a result of calling xslt_transform described above. This example parses a XML newsfeed containing the 5 latest articles on phpbuilder.com. You are encouraged to also try other XML feeds and/or XSl stylesheets.
<?php$xml = "http://www.phpbuilder.com/rss_feed.php?type=articles&limit=5";$xsl = "http://www.soeterbroek.com/code/xml/rss_html.xsl";$out = xslt_transform($xml,$xsl);echo $out;?>
If you are processing local files, make sure you use the full path name to pass to the Java class.
<?php$xml = "/web/htdocs/xml_java/rss_feed.xml";$xsl = "/web/htdocs/xml_java/rss_html.xsl";$out = xslt_transform($xml,$xsl);echo $out;?>
Although there are a number of other ways in PHP to achieve the same results, the above example gives you a good idea of the possibilities of accessing Java objects in PHP.