XSLT - [127]
> }
>}
Взаимодействие процессора XSLT Oracle с Java
Несколько больше усилий потребуется для осуществления XSLT-преобразования при помощи API процессора XSLT фирмы Oracle. Новый пример, >oraclejava.java
, продемонстрирует работу с этим API.
В >oraclejava.java
в первую очередь необходимо считывать требуемые документы при помощи объекта >DOMParser
:
>import org.w3c.dom.*;
>import java.util.*;
>import java.io.*;
>import java.net.*;
>import oracle.xml.parser.v2.*;
>public class oraclejava {
> public static void main (String args[]) throws Exception {
> DOMParser parser;
> try {
> parser = new DOMParser();
> parser.setPreserveWhitespace(true);
> .
> .
> .
Затем, чтобы считать исходный документ XML и документ таблицы стилей XSLT, нужно преобразовать их URL в объекты >URLJava
при помощи метода >parse
объекта >parser
. После этого я вызываю метод разборщика >getDocument
, для того чтобы извлечь и сохранить документы XML и XSLT в объектах >XMLDocument
:
>public class oraclejava {
> public static void main (String args[]) throws Exception {
> DOMParser parser;
> XMLDocument xmldoc, xsldoc;
> URL xslURL;
> URL xmlURL;
> try {
> parser = new DOMParser();
> parser.setPreserveWhitespace(true);
> xmlURL = new URL(args[0]);
> parser.parse(xmlURL);
> xmldoc = parser.getDocument();
> xslURL = new URL(args[1]);
> parser.parse(xslURL);
> xsldoc = parser.getDocument();
> .
> .
> .
В этот момент >planets.xml
и >planets.xsl
заключены в объекты >XMLDocument
. Для выполнения преобразования мне необходимы еще объекты >XSLStylesheet
и >XSLProcessor
для таблицы стилей XSLT. Фактическое преобразование XSLT осуществляется методом >processXSL
объекта >parser
, возвращающего фрагмент документа:
>public class oraclejava {
> public static void main (String args[]) throws Exception {
> DOMParser parser;
> .
> .
> .
> xslURL = new URL(args[1]);
> parser.parse(xslURL);
> xsldoc = parser.getDocument();
> XSLStylesheet xslstylesheet = new XSLStylesheet(xsldoc, xslURL);
> XSLProcessor processor = new XSLProcessor();
> DocumentFragment docfragment =
> processor.processXSL(xslstylesheet, xmldoc);
> .
> .
> .
Этот код завершает преобразование. Теперь задача состоит в том, чтобы преобразовать данный фрагмент документа в документ XML, который можно записать на диск, — для чего я и создам новый XML-документ, >newdoc
, и вставлю фрагмент документа в корень нового документа:
>import org.w3c.dom.*;
>.
>.
>.
>public class oraclejava {
> public static void main (String args[]) throws Exception {
> DOMParser parser;
> XMLDocument xmldoc, xsldoc, newdoc;
> URL xslURL;
> URL xmlURL;
> try {
> .
> .
> .
> DocumentFragment docfragment =
> processor processXSL(xslstylesheet, xmldoc);
> newdoc = new XMLDocument();
> Element rootElement = newdoc.createElement("root");
> newdoc.appendChild(rootElement);
> rootElement.appendChild(docfragment);
> .
> .
> .
Теперь осталось только сохранить на диске новый XML-документ с именем, заданным в >args[2]
. В этих целях я использую объект >FileOutputStream
, и вот полный код (листинг 10.9).
>import org.w3c.dom.*;
>import java.util.*;
>import java.io.*;
>import java.net.*;
>import oracle.xml.parser.v2.*;
>public class oraclejava {
> public static void main (String args[]) throws Exception {
> DOMParser parser;
> XMLDocument xmldoc, xsldoc, newdoc;
> URL xslURL;
> URL xmlURL;
> try {
> parser = new DOMParser();
> parser.setPreserveWhitespace(true);
> xmlURL = new URL(args[0]);
> parser.parse(xmlURL);
> xmldoc = parser.getDocument();
> xslURL = new URL(args[1]);
> parser.parse(xslURL);
> xsldoc = parser.getDocument();
> XSLStylesheet xslstylesheet = new XSLStylesheet(xsldoc, xslURL);
> XSLProcessor processor = new XSLProcessor();
> DocumentFragment docfragment =
> processor.processXSL(xslstylesheet, xmldoc);
> newdoc = new XMLDocument();
> Element rootElement = newdoc.сreateElement("root");
> newdoc.appendChild(rootElement);
> rootElement.appendChild(docfragment);
> OutputStream out = new FileOutputStream(args[2]);
> newdoc.print(out);
> out.close();
> } catch (Exception e) {}
> }
>}
На этом >oraclejava.java
заканчивается. Чтобы скомпилировать пример, включите в >classpath
путь к разборщику XML процессора XSLT Oracle, >xmlparserv2.jar
:
>C:\>set classpath=.;c:\oraclexml\lib\xmlparserv2.jar
Затем скомпилируйте >oraclejava.java
, как мы это уже делали, компилятором Java >javac
. Для выполнения XSLT-преобразований нужно указать URL документов, с которыми вы хотите работать (если документы локальны, можно указать URL файлов, как и раньше):
>C:\>java oraclejava http://starpowder.com/planets.xml http://starpowder.com/planets.xsl planets.html
Взаимодействие XT с Java
Процессор XT также может работать с Java. API XT спроектирован для работы с классами, определенными в Project X TR2 фирмы Sun, которые поддерживают обработку XML. Вам будет необходим файл >xml.jar
фирмы Sun, который можно получить, загрузив Project X TR2. Чтобы получить >xml.jar
, необходимо зарегистрироваться на web-узле разработчиков Sun, http://developer.java.sun.com, что, к счастью, бесплатно, хотя и потребует от вас заполнения изрядного количества форм.
Книга посвящена рассмотрению всей совокупности проблем, связанных с созданием, воспроизведением на компьютере и практическим использованием электронных и мультимедийных изданий. В частности, показано место этих изданий в современной медиа-индустрии. Рассмотрено использование различных HTML-редакторов и специализированных программных средств создания электронных и мультимедийных изданий (MS FrontPage, Macromedia Director, DreamWeaver и Flash, а также 3ds max). В книгу также вошли разделы, связанные с публикацией и хранением электронных изданий с помощью баз данных, а также семантическим анализом, индексацией и организацией поиска и долговременного хранения электронных документов.
Превратится ли всемирная паутина в «традиционное СМИ», содержание которого строго контролируется в интересах максимизации прибыли? В чьих руках сейчас находится Рубильник интернет-истории и, по сути, — развития общества? Исследуя развитие телефонии, радио, кино и телевидения, автор показывает, как эти индустрии прошли путь от хобби — к крупному бизнесу, от открытости и гибкости — к закрытой и жесткой системе. Какое будущее ожидает всемирную Сеть?Пролить свет на прошлое, чтобы предвидеть будущее — главная задача этой книги.Эта книга для тех, кто считает интернет не просто средством общения, но и инструментом познания мира, способом самовыражения.
Чем полезен Интернет пожилому человеку? Прежде всего, неограниченными возможностями общения. Вы можете вести виртуальный дневник или общаться с друзьями в социальных сетях, делиться советами на форумах или переписываться с родственниками, живущими за рубежом, находить старых друзей и заводить новых.Книга поможет вам ориентироваться в мире социальных сетей и интерактивных сервисов, научит вас работать с ними и использовать все те возможности, которые они предоставляют. Материал книги изложен в доступной форме, что облегчает его восприятие, а различные способы выполнения тех или иных действий дадут вам возможность выбрать наиболее удобный способ именно для вас.
Автор предлагает бесплатную, проверенную на практике, супернадежную и эффективную комплексную защиту от вирусов, шпионских программ, вторжения любопытных хакеров — любых попыток несанкционированного вторжения в ваш компьютер.Пользуясь советами автора, вы сможете не только выстроить надежную систему безопасности, но и контролировать те сайты, которые посещают ваши дети, а также без проблем восстановить операционную систему после любого сбоя и даже полного обрушения. Книга станет настольным пособием и у продвинутых пользователей, и у чайников благодаря простому и краткому изложению материала с подробными иллюстрациями каждого шага.
Рассказывается о ведущем поисковом ресурсе российской части Интернета — Яндексе. Описаны его сервисы для поиска документов и новостей, блогов и адресов, товаров и музыкальных произведений. Рассмотрены почтовый сервис и сервис для создания и размещения сайтов на Народ. ру. Читатель узнает о том, что такое "электронные деньги" и как с их помощью оплатить товар. Большое внимание уделяется общедоступным поисковым программам, которые Яндекс предлагает своим посетителям для поиска информации не только на сайтах, но и на своем компьютере.
В книге рассказывается история главного героя, который сталкивается с различными проблемами и препятствиями на протяжении всего своего путешествия. По пути он встречает множество второстепенных персонажей, которые играют важные роли в истории. Благодаря опыту главного героя книга исследует такие темы, как любовь, потеря, надежда и стойкость. По мере того, как главный герой преодолевает свои трудности, он усваивает ценные уроки жизни и растет как личность.
Что общего между самыми востребованными профессиями и стремительным увеличением количества информации в мире? Ответ: язык структурированных запросов (SQL). SQL — рабочая лошадка среди языков программирования, основа основ для современного анализа и управления данными. Книга «SQL: быстрое погружение» идеальна для всех, кто ищет новые перспективы карьерного роста; для разработчиков, которые хотят расширить свои навыки и знания в программировании; для любого человека, даже без опыта, кто хочет воспользоваться возможностями будущего, в котором будут править данные.
Даже плохой программный код может работать. Однако если код не является «чистым», это всегда будет мешать развитию проекта и компании-разработчика, отнимая значительные ресурсы на его поддержку и «укрощение». Эта книга посвящена хорошему программированию. Она полна реальных примеров кода. Мы будем рассматривать код с различных направлений: сверху вниз, снизу вверх и даже изнутри. Прочитав книгу, вы узнаете много нового о коде. Более того, вы научитесь отличать хороший код от плохого. Вы узнаете, как писать хороший код и как преобразовать плохой код в хороший. Книга состоит из трех частей.
Книга "Изучаем Python" - это ускоренный курс, который позволит вам сэкономить время и сразу начать писать работоспособные программы (игры, визуализации данных, веб-приложения и многое другое). Хотите стать программистом? В первой части книги вам предстоит узнать о базовых принципах программирования, познакомиться со списками, словарями, классами и циклами, вы научитесь создавать программы и тестировать код. Во второй части книги вы начнете использовать знания на практике, работая над тремя крупными проектами: создадите собственную "стрелялку" с нарастающей сложностью уровней, займетесь работой с большими наборами данных и освоите их визуализацию, и, наконец, создадите полноценное веб-приложение на базе Django, гарантирующее конфиденциальность пользовательской информации. Если вы решились разобраться в том что такое программирование, не нужно ждать.
Алгоритмы - это всего лишь пошаговые алгоритмы решения задач, и большинство таких задач уже были кем-то решены, протестированы и проверены. Можно, конечно, погрузится в глубокую философию гениального Кнута, изучить многостраничные фолианты с доказательствами и обоснованиями, но хотите ли вы тратить на это свое время? Откройте великолепно иллюстрированную книгу и вы сразу поймете, что алгоритмы - это просто. А грокать алгоритмы - это веселое и увлекательное занятие.