XSLT — страница 86 из 124

import javax.xml.transform.TransformerFactory;

import javax.xml.transform.stream.StreamSource;

import javax.xml.transform.stream.StreamResult;

import javax.xml.transform.TransformerException;

import javax.xml.transform.TransformerConfigurationException;

import java.io.FileOutputStream;

import java.io.FileNotFoundException;

import java.io.IOException;


public class xalanjava {

 public static void main(String[] args)

  throws TransformerException, TransformerConfigurationException,

  FileNotFoundException, IOException {

  TransformerFactory tFactory = TransformerFactory.newInstance();

  Transformer transformer =

   tFactory.newTransformer(new StreamSource(args[1]));

  transformer transform(new StreamSource(args[0]),

   new StreamResult(new FileOutputStream(args[2])));

 }

}

Чтобы скомпилировать файл

xalanjava.java
в
xalanjava.class
и выполнить этот класс, задайте
classpath
так, чтобы путь включал Xalan и разборщик XML, который вы обычно используете с Xalan, Xerces (о Xerces говорилось в главе 1, в том числе и о том, где его взять), — в Windows это будет выглядеть так (как всегда, пишите пути в соответствии со своей системой):

C:\>set classpath=.;c:\xalan\xalan.jar;c:\xalan\xerces.jar

Затем скомпилируйте

xalanjava.java
компилятором с Java,
javac
:

C:\>javac xalanjava.java

Здесь считается, что путь к

javac.exe
прописан, и его можно сразу активизировать из командной строки. (Как правило, компилятор Java javac.exe находится в каталоге Java bin — поэтому если путь к нему не задан, к нему можно обратиться, например, так:
C:\>c:\jdk1.3\bin\javac xalanjava.java
.) Компилятор Java создаст файл
xalanjava.class
, при помощи которого производится преобразование:

C:\>java xalanjava planets.xml planets.xsl planets.html

При этом из файлов

planets.xml
и
planets.xsl
будет создан файл
planets.html
— здесь я его создал при помощи своего собственного класса Java.

РАБОТА С ПАКЕТОМ JAXP ФИРМЫ SUN ДЛЯ XSLT

Фирма Sun, создатель Java, обладает пакетом Java для обработки XML, JAXP, который можно загрузить с http://java.sun.com/xml. JAXP способен также осуществлять XSLT-преобразования. Но я не буду отдельно рассматривать JAXP в текущей главе, поскольку этот пакет (по крайней мере, сейчас) для всех своих преобразований использует Xalan, поставляемый в xalan.jar. Значит, предыдущий пример, листинг 10.7, без всяких изменений можно использовать с пакетом JAXP.

Взаимодействие Saxon с Java

Процессор Saxon также определяет API для работы с Java, но, конечно, в деталях этот прикладной интерфейс отличается от API Xalan. Для демонстрации создания преобразований при помощи Saxon API версии 6.0.2 я создам новый класс Java

saxonjava
. Начать нужно с создания нового объекта
XSLTProcessor
, вызвав метод
newInstance
класса
Processor
в файле
saxonjava.java
:

import java.io.*;

import org.xml.sax.*;

import org.w3c.dom.*;

import com.icl.saxon.trax.*:


public class saxonjava {

 public static void main(String args[])

  throws ProcessorException, ProcessorFactoryException,

  TransformException, SAXException, IOException {

  Processor processor = Processor.newInstance("xslt");

  .

  .

  .

Затем необходимо создать объект

Templates
на основе таблицы стилей XSL, которую мы хотим применить, хранимой в
args[1]
. Это можно сделать при помощи класса
InputSource
:

import java.io.*;

.

.

.

public class saxonjava {

 public static void main(String args[])

  throws ProcessorException, ProcessorFactoryException,

  TransformException, SAXException, IOException {

  Processor processor = Processor.newInstance("xslt");

  Templates templates =

   processor.process(new InputSource(args[1]));

  .

  .

  .

 }

}

При помощи нового объекта

Templates
можно создать объект
Transformer
, который в действительности делает работу:

import java.io.*;

.

.

.

public class saxonjava {

 public static void main(String args[])

  throws ProcessorException, ProcessorFactoryException,

  TransformException, SAXException, IOException {

  Processor processor = Processor.newInstance("xslt");

  Templates templates =

   processor.process(new InputSource(args[1]));

  Transformer transformer = templates.newTransformer();

  .

  .

  .

 }

}

Наконец, чтобы осуществить XSLT-преобразование, нужно вызвать метод

transform
объекта
transformer
, записывая результат в выходной документ при помощи объекта
FileWriter
(листинг 10.8).

Листинг 10.8. saxonjava.java, взаимодействие Saxon с Java

import java.io.*;

import org.xml.sax.*;

import org.w3c.dom.*;

import com.icl.saxon.trax.*;


public class saxonjava {

 public static void main(String args[])

  throws ProcessorException, ProcessorFactoryException,

  TransformException, SAXException, IOException {

  Processor processor = Processor.newInstance("xslt");

  Templates templates =

   processor.process(new InputSource(args[1]));

  Transformer transformer = templates.newTransformer();

  transformer.transform(new InputSource(args[0]),

   new Result(new FileWriter(args[2])));

 }

}

Чтобы скомпилировать и использовать новый класс

saxonjava
, нужно установить
classpath
так, чтобы переменная включала путь к
saxon.jar
:

С:\>set сlasspath=.;с:\saxon\saxon.jar

Затем при помощи компилятора Java,

javac
, создается
saxonjava.class
.

Как и многие использующие API процессоры XSLT, Saxon ожидает, что ему будут переданы URL документов, с которыми вы хотите работать, — что я и делаю на следующем шаге:

C:\>java saxonjava http://www.starpowder.com/planets.xml http://www.starpowder.com/planets.xsl planets.html

Таким образом, создается

planets.html