Путеводитель по интернету - все самое интересное в сети. Использование XML Document Object Model Несколько слов об организации документооборота

Язык XML все чаще используется для хранения информации, обмена ею между приложениями и Web-узлами. Во многих приложениях этот язык применяется в качестве базового для хранения данных, в других - для экспортирования и импортирования XML-данных. Из этого следует, что разработчикам пора задуматься над тем, как можно использовать XML-данные в собственных приложениях.

В этой статье мы рассмотрим XML Document Object Model (DOM) и ее реализацию фирмой Microsoft - Microsoft XML DOM.

XML DOM - это объектная модель, предоставляющая в распоряжение разработчика объекты для загрузки и обработки XML-файлов. Объектная модель состоит из следующих основных объектов: XMLDOMDocument, XMLDOMNodeList, XMLDOMNode, XMLDOMNamedNodeMap и XMLDOMParseError. Каждый из этих объектов (кроме XMLDOMParseError) содержит свойства и методы, позволяющие получать информацию об объекте, манипулировать значениями и структурой объекта, а также перемещаться по структуре XML-документа.

Рассмотрим основные объекты XML DOM и приведем несколько примеров их использования в Borland Delphi.

Использование XML DOM в Borland Delphi

Для того чтобы использовать Microsoft XML DOM в Delphi-приложениях, необходимо подключить к проекту соответствующую библиотеку типов. Для этого мы выполняем команду Project | Import Type Library и в диалоговой панели Import Type Library выбираем библиотеку Microsoft XML version 2.0 (Version 2.0), которая обычно находится в файле Windows\System\MSXML.DLL

После нажатия кнопки Create Unit будет создан интерфейсный модуль MSXML_TLB, который позволит нам воспользоваться объектами XML DOM: DOMDocument, XMLDocument, XMLHTTPRequest и рядом других, реализованных в библиотеке MSXML.DLL. Ссылка на модуль MSXML_TLB должна быть указана в списке Uses.

Устройство XML DOM

Document Object Model представляет XML-документ в виде древовидной структуры, состоящей из ветвей. Программные интерфейсы XML DOM позволяют приложениям перемещаться по дереву документа и манипулировать его ветвями. Каждая ветвь может иметь специфический тип (DOMNodeType), согласно которому определяются родительская и дочерние ветви. В большинстве XML-документов можно встретить ветви типа element, attribute и text. Атрибуты (attribute) представляют собой особый вид ветви и не являются дочерними ветвями. Для управления атрибутами используются специальные методы, предоставляемые объектами XML DOM.

Помимо реализации рекомендованных World Wide Web Consortium (W3C) интерфейсов, Microsoft XML DOM содержит методы, поддерживающие XSL, XSL Patterns, Namespaces и типы данных. Например, метод SelectNodes позволяет использовать синтаксис шаблонов XSL (XSL Pattern Syntax) для поиска ветвей по определенному контексту, а метод TransformNode поддерживает использование XSL для выполнения трансформаций.

Тестовый XML-документ

В качестве примера XML-документа возьмем каталог музыкальных CD-ROM, который имеет следующую структуру :

Empire Burlesque Bob Dylan USA Columbia 10.90 1985 Hide your heart Bonnie Tylor UK CBS Records 9.90 1988 ... Unchain my heart Joe Cocker USA EMI 8.20 1987

Теперь мы готовы приступить к рассмотрению объектной модели XML DOM, знакомство с которой начнем с объекта XMLDOMDocument.

XML-документ - объект XMLDOMDocument

Работа с XML-документом начинается с его загрузки. Для этого мы используем метод Load, который имеет всего один параметр, указывающий URL загружаемого документа. При загрузке файлов с локального диска указывается только полное имя файла (протокол file:/// в данном случае можно опустить). Если XML-документ хранится в виде строки, для загрузки такого документа следует использовать метод LoadXML.

Для управления способом загрузки документа (синхронный или асинхронный) используется свойство Async. По умолчанию это свойство имеет значение True, указывающее на то, что документ загружается асинхронно и управление возвращается приложению еще до полной загрузки документа. В противном случае документ загружается синхронно, и тогда приходится проверять значение свойства ReadyState, чтобы узнать, загрузился документ или нет. Также можно создать обработчик события OnReadyStateChange, который получит управление при изменении значения свойства ReadyState.

Ниже показано, как загрузить XML-документ, используя метод Load:

Uses ... MSXML_TLB ... procedure TForm1.Button1Click(Sender: TObject); var XMLDoc: IXMLDOMDocument; begin XMLDoc:= CoDOMDocument.Create; XMLDoc.Async:= False; XMLDoc.Load(‘C:\DATA\DATA.xml’); // // Здесь располагается код, манипулирующий // XML-документом и его ветвями // XMLDoc:= Nil; end;

После того как документ загружен, мы можем обратиться к его свойствам. Так, свойство NodeName будет содержать значение #document, свойство NodeTypeString - значение document, свойство URL - значение file:///C:/DATA/DATA.xml.

Обработка ошибoк

Особый интерес представляют свойства, связанные с обработкой документа при его загрузке. Так, свойство ParseError возвращает объект XMLDOMParseError, содержащий информацию об ошибке, возникшей в процессе обработки документа.

Чтобы написать обработчик ошибки, можно добавить следующий код:

Var XMLError: IXMLDOMParseError; ... XMLDoc.Load(‘C:\DATA\DATA.xml’); XMLError:= XMLDoc.ParseError; If XMLError.ErrorCode <> 0 Then // // Здесь мы обрабатываем ошибку // Else Memo1.Lines.Add(XMLDoc.XML); ... XMLDoc:= Nil;

Чтобы узнать, какая информация возвращается в случае ошибки, изменим следующий элемент каталога:

Empire Burlesque Bob Dylan USA Columbia 10.90 1985

убрав закрывающий элемент во второй строке:</p><p> <CD> <TITLE>Empire Burlesque <ARTIST>Bob Dylan</ARTIST> <COUNTRY>USA</COUNTRY> <COMPANY>Columbia</COMPANY> <PRICE>10.90</PRICE> <YEAR>1985</YEAR> </CD> </p><p>Теперь напишем код, возвращающий значения свойств объекта XMLDOMParseError:</p><p>XMLError:= XMLDoc.ParseError; If XMLError.ErrorCode <> 0 Then With XMLError, Memo1.Lines do begin Add(‘Файл: ‘ + URL); Add(‘Код: ‘ + IntToStr(ErrorCode)); Add(‘Ошибка: ‘ + Reason); Add(‘Текст: ‘ + SrcText); Add(‘Строка: ‘ + IntToStr(Line)); Add(‘Позиция: ‘ + IntToStr(LinePos)); end Else Memo1.Lines.Add(XMLDoc.XML); End; </p><p>и выполним наше приложение. В результате получаем следующую информацию об ошибке .</p> <p>Как видно из приведенного примера, возвращаемой объектом XMLDOMParseError информации вполне достаточно для того, чтобы локализовать ошибку и понять причину ее возникновения.</p> <p>Теперь восстановим закрывающий элемент <TITLE> в нашем документе и продолжим обсуждение XML DOM.</p> <table border="0" width="100%"><tr><td width="50%"> </td> <td width="50%"> </td> </tr></table><h2> Доступ к дереву документа</h2> <p>Для доступа к дереву документа можно либо получить корневой элемент и затем перебрать его дочерние ветви, либо найти какую-то специфическую ветвь. В первом случае мы получаем корневой элемент через свойство DocumentElement, которое возвращает объект типа XMLDOMNode. Ниже показано, как воспользоваться свойством DocumentElement для того, чтобы получить содержимое каждого дочернего элемента:</p><p>Var Node: IXMLDOMNode; Root: IXMLDOMElement; I: Integer; ... Root:= XMLDoc.DocumentElement; For I:= 0 to Root.ChildNodes.Length-1 do Begin Node:= Root.ChildNodes.Item[I]; Memo1.Lines.Add(Node.Text); End; </p><p>Для нашего XML-документа мы получим следующий текст .</p> <p>Если нас интересует какая-то специфическая ветвь или ветвь уровнем ниже первой дочерней ветви, мы можем воспользоваться либо методом NodeFromID, либо методом GetElementByTagName объекта XMLDOMDocument.</p> <p>Метод NodeFromID требует указания уникального идентификатора, определенного в XML Schema или Document Type Definition (DTD), и возвращает ветвь с этим идентификатором.</p> <p>Метод GetElementByTagName требует указания строки со специфическим элементом (тэгом) и возвращает все ветви с данным элементом. Ниже показано, как использовать данный метод для нахождения всех исполнителей в нашем каталоге CD-ROM:</p><p>Nodes: IXMLDOMNodeList; Node: IXMLDOMNode; ... Nodes:= XMLDoc.GetElementsByTagName(‘ARTIST’); For I:= 0 to Nodes.Length-1 do Begin Node:= Nodes.Item[I]; Memo1.Lines.Add(Node.Text); End; </p><p>Для нашего XML-документа мы получим следующий текст </p> <p>Отметим, что метод SelectNodes объекта XMLDOMNode обеспечивает более гибкий способ для доступа к ветвям документа. Но об этом чуть ниже.</p> <table border="0" width="100%"><tr><td width="50%"> </td> <td width="50%"> </td> </tr></table><h2> Ветвь документа - объект XMLDOMNode</h2> <p>Объект XMLDOMNode представляет собой ветвь документа. Мы уже сталкивались с этим объектом, когда получали корневой элемент документа:</p><p>Root:= XMLDoc.DocumentElement; </p><p>Для получения информации о ветви XML-документа можно использовать свойства объекта XMLDOMNode (табл. 1).</p> <p>Для доступа к данным, хранимым в ветви, обычно используют либо свойство NodeValue (доступно для атрибутов, текстовых ветвей, комментариев, инструкций по обработке и секций CDATA), либо свойство Text, возвращающее текстовое содержимое ветви, либо свойство NodeTypedValue. Последнее, однако, может использоваться только для ветвей с типизованными элементами.</p> <table border="0" width="100%"><tr><td width="50%"> </td> <td width="50%"> </td> </tr></table><h3> Перемещение по дереву документа</h3> <p>Объект XMLDOMNode предоставляет множество способов для перемещения по дереву документа. Например, для доступа к родительской ветви используется свойство ParentNode (тип XMLDOMNode), доступ к дочерним ветвям осуществляется через свойства ChildNodes (тип XMLDOMNodeList), FirstChild и LastChild (тип XMLDOMNode) и т.д. Свойство OwnerDocument возвращает объект типа XMLDOMDocument, идентифицирующий сам XML-документ. Перечисленные выше свойства позволяют легко перемещаться по дереву документа.</p> <p>Теперь переберем все ветви XML-документа:</p><p>Root:= XMLDoc.DocumentElement; For I:= 0 to Root.ChildNodes.Length-1 do Begin Node:= Root.ChildNodes.Item[I]; If Node.HasChildNodes Then GetChilds(Node,0); End; </p><p>Как уже отмечалось выше, SelectNodes объекта XMLDOMNode обеспечивает более гибкий способ доступа к ветвям документа. Кроме того, существует метод SelectSingleNode, возвращающий только первую ветвь документа. Оба эти метода позволяют задавать XSL-шаблоны для поиска ветвей.</p> <p>Рассмотрим процесс использования метода SelectNodes для извлечения всех ветвей, у которых есть ветвь CD и подветвь PRICE:</p><p>Root:= XMLDoc.DocumentElement; Nodes:= Root.SelectNodes(‘CD/PRICE’); </p><p>В коллекцию Nodes будут помещены все подветви PRICE ветви CD. К обсуждению XSL-шаблонов вернемся чуть позже.</p> <table border="0" width="100%"><tr><td width="50%"> </td> <td width="50%"> </td> </tr></table><h3> Манипуляция дочерними ветвями</h3> <p>Для манипуляции дочерними ветвями мы можем воспользоваться методами объекта XMLDOMNode (табл. 2).</p> <p>Для того чтобы полностью удалить запись о первом диске, необходимо выполнить следующий код :</p><p>Var XMLDoc: IXMLDOMDocument; Root: IXMLDOMNode; Node: IXMLDOMNode; XMLDoc:= CoDOMDocument.Create; XMLDoc.Async:= False; XMLDoc.Load(‘C:\DATA\DATA.xml’); // Получить корневой элемент Root:= XMLDoc.DocumentElement; Node:= Root; // Удалить первую дочернюю ветвь Node.RemoveChild(Node.FirstChild); </p><p>Обратите внимание на то, что в данном примере мы удаляем первую дочернюю ветвь. Как удалить первый элемент первой дочерней ветви, показано ниже :</p><p>Var XMLDoc: IXMLDOMDocument; Root: IXMLDOMNode; Node: IXMLDOMNode; XMLDoc:= CoDOMDocument.Create; XMLDoc.Async:= False; XMLDoc.Load(‘C:\DATA\DATA.xml’); // Получить корневой элемент Root:= XMLDoc.DocumentElement; // и первую дочернюю ветвь Node:= Root.FirstChild; // Удалить первую дочернюю ветвь Node.RemoveChild(Node.FirstChild); </p><p>В приведенном выше примере мы удалили не первую ветвь <CD>…</CD>, а первый элемент ветви - <TITLE>….

Теперь добавим новую ветвь. Ниже приведен код, показывающий, как добавить новую запись о музыкальном CD-ROM :

Var NewNode: IXMLDOMNode; Child: IXMLDOMNode; ... // Создадим новую ветвь - NewNode:= XMLDoc.CreateNode(1, ‘CD’, ‘’); // Добавим элемент Child:= XMLDoc.CreateNode(1,‘TITLE’,‘’); // Добавим элемент NewNode.AppendChild(Child); // И установим его значение Child.Text:= ‘Pink Floyd’; // Добавим элемент <ARTIST> Child:= XMLDoc.CreateNode(1, ‘ARTIST’, ‘’); // Добавим элемент NewNode.AppendChild(Child); // И установим его значение Child.Text:= ‘Division Bell’; // Добавим элемент <COUNTRY> Child:= XMLDoc.CreateNode(1, ‘COUNTRY’, ‘’); // Добавим элемент NewNode.AppendChild(Child); // И установим его значение Child.Text:= ‘UK’; // Добавим элемент <COMPANY> Child:= XMLDoc.CreateNode(1, ‘COMPANY’, ‘’); // Добавим элемент NewNode.AppendChild(Child); // И установим его значение Child.Text:= ‘EMI Records Ltd.’; // Добавим элемент <PRICE>Child:= XMLDoc.CreateNode(1, ‘PRICE’, ‘’); // Добавим элемент NewNode.AppendChild(Child); // И установим его значение Child.Text:= ’11.99"; // Добавим элемент <YEAR> Child:= XMLDoc.CreateNode(1, ‘YEAR’, ‘’); // Добавим элемент NewNode.AppendChild(Child); // И установим его значение Child.Text:= ‘1994’; // И добавим ветвь Root.AppendChild(NewNode); ... </p><p>Приведенный выше код показывает следующую последовательность действий по добавлению новой ветви:</p> <ul><li>Создание новой ветви методом CreateNode: <ul><li>создание элемента методом CreateNode;</li> <li>добавление элемента к ветви методом AppendChild;</li> <li>установка значения элемента через свойство Text;</li> <li>… повторить для всех элементов.</li> </ul></li> <li>Добавление новой ветви к документу методом AppendChild.</li> </ul><p>Напомним, что метод AppendChild добавляет ветвь в конец дерева. Для того чтобы добавить ветвь в конкретное место дерева, необходимо использовать метод InsertBefore.</p> <h2> Набор ветвей - объект XMLDOMNodeList</h2> <p>Объект XMLNodeList содержит список ветвей, который может быть построен с помощью методов SelectNodes или GetElementsByTagName, а также получен из свойства ChildNodes.</p> <p>Мы уже рассматривали использование этого объекта в примере, приведенном в разделе «Перемещение по дереву документа». Здесь же мы приведем некоторые теоретические замечания.</p> <p>Число ветвей в списке может быть получено как значение свойства Length. Ветви имеют индексы от 0 до Length-1, и каждая отдельная ветвь доступна через элемент массива Item с соответствующим индексом.</p> <p>Перемещение по списку ветвей также может осуществляться с помощью метода NextNode, возвращающего следующую ветвь в списке, или Nil, если текущая ветвь - последняя. Чтобы вернуться к началу списка, следует вызвать метод Reset.</p> <table border="0" width="100%"><tr><td width="50%"> </td> <td width="50%"> </td> </tr></table><h2> Создание и сохранение документов</h2> <p>Итак, мы рассмотрели, как можно добавлять ветви и элементы в существующие XML-документы. Теперь создадим XML-документ «на лету». Прежде всего напомним, что документ может быть загружен не только из URL, но и из обычной строки. Ниже показано, как создать корневой элемент, который затем может использоваться для динамического построения остальных элементов (что мы уже рассмотрели в разделе «Манипуляция дочерними ветвями»):</p><p>Var XMLDoc: IXMLDOMDocument; Root: IXMLDOMNode; Node: IXMLDOMNode; S: WideString; ... S:= ‘<CATALOG></CATALOG>’; XMLDoc:= CoDOMDocument.Create; XMLDoc.Async:= False; XMLDoc.LoadXML(S); Root:= XMLDoc.DocumentElement; Node:= XMLDoc.CreateNode(1, ‘CD’, ‘’); Root.AppendChild(Node); Memo1.Lines.Add(XMLDoc.XML); ... XMLDoc:= Nil; </p><p>После построения XML-документа сохраним его в файле с помощью метода Save. Например:</p> <p>XMLDoc.Save(‘C:\DATA\NEWCD.XML’);</p> <p>Помимо сохранения в файле метод Save позволяет сохранять XML-документ в новом объекте XMLDOMDocument. В этом случае происходит полная обработка документа и, как следствие, проверка его структуры и синтаксиса. Ниже показано, как сохранить документ в другом объекте:</p><p>Procedure TForm1.Button2Click(Sender: TObject); var XMLDoc2: IXMLDOMDocument; begin XMLDoc2:= CoDOMDocument.Create; XMLDoc.Save(XMLDoc2); Memo2.Lines.Add(XMLDoc2.XML); ... XMLDoc2:= Nil; end; </p><p>В заключение отметим, что метод Save также позволяет сохранять XML-документ в другие COM-объекты, поддерживающие интерфейсы IStream, IPersistStream или IPersistStreamInit.</p> <table border="0" width="100%"><tr><td width="50%"> </td> <td width="50%"> </td> </tr></table><h2> Использование XSL-шаблонов</h2> <p>Обсуждая метод SelectNodes объекта XMLDOMNode, мы упомянули о том, что он обеспечивает более гибкий способ доступа к ветвям документа. Гибкость заключается в том, что в качестве критерия для выбора ветвей можно указать XSL-шаблон. Такие шаблоны предоставляют мощный механизм для поиска информации в XML-документах. Например, для того, чтобы получить список всех названий музыкальных CD-ROM в нашем каталоге, можно выполнить следующий запрос:</p><p>Чтобы узнать, диски каких исполнителей выпущены в США, запрос формируется следующим образом:</p><p>Nodes:= Root.SelectNodes(‘CD/ARTIST’); </p><p>Ниже показано, как найти первый диск в каталоге:</p><p>Nodes:= Root.SelectNodes(‘CD/TITLE’); </p><p>и последний:</p><p>Nodes:= Root.SelectNodes(‘CD/TITLE’); </p><p>Чтобы найти диски Боба Дилана, можно выполнить следующий запрос:</p><p>Nodes:= Root.SelectNodes(‘CD[$any$ ARTIST= ”Bob Dylan”]/TITLE’); </p><p>а чтобы получить список дисков, выпущенных после 1985 года, мы выполняем следующий запрос:</p><p>Nodes:= Root.SelectNodes(‘CD/TITLE’); </p><p>Более подробное обсуждение синтаксиса XSL требует отдельной публикации. Чтобы заинтриговать читателей и подтолкнуть к дальнейшим исследованиям, приведу всего один небольшой пример возможного использования XSL. Допустим, нам необходимо преобразовать наш каталог в обычную HTML-таблицу. Пользуясь традиционными способами, мы должны перебрать все ветви дерева и для каждого полученного элемента сформировать соответствующие тэги <TD>…</TD>.</p> <p>Используя XSL, мы просто создаем шаблон (или таблицу стилей), в котором указываем, что и как надо преобразовать. Затем накладываем этот шаблон на наш каталог - и готово: перед нами текст XSL-шаблона, преобразующего каталог в таблицу (листинг 2).</p> <p>Код для наложения XSL-шаблона на наш каталог выглядит так:</p><p>Procedure TForm1.Button2Click(Sender: TObject); var XSLDoc: IXMLDOMDocument; begin XSLDoc:= CoDOMDocument.Create; XSLDoc.Load(‘C:\DATA\DATA.xsl’); Memo2.Text:= XMLDoc.TransformNode(XSLDoc); XSLDoc:= Nil; end; </p><p>Завершая наше обсуждение XSL, следует сказать, что в настоящее время этот язык активно используется для трансформации между различными XML-документами, а также для форматирования документов.</p> <table border="0" width="100%"><tr><td width="50%"> </td> <td width="50%"> </td> </tr></table><h2> Заключение</h2> <p>По вполне понятным причинам в одной статье невозможно рассмотреть все объекты Microsoft XML DOM и привести примеры их использования. Здесь мы лишь коснулись основных вопросов использования XML DOM в приложениях. В табл. 3 показаны все объекты, реализованные в Microsoft XML DOM.</p> <p>КомпьютерПресс 12"2000</p> <p>ЗАКАЗАТЬ РЕШЕНИЕ ЗАДАЧ НА DELPHI <br> Delphi – это второй по значимости язык программирования, с которым чаще всего студенты знакомятся в процессе обучения. Это начало изучения объектно-ориентированного программирования. Я как студент, сделал для себя вывод, что нет проще метода освоить язык, чем написать на нём калькулятор. Даже если вы реализуете элементарную функцию сложения двух чисел, это уже на многое прольёт свет.</p> <p>CodeGaear, Delphi 7, Lazarus – это разные компиляторы, программы, которые передадут написанный вами код машине, преобразовав его в нолики и единички. Это всё программы для создания программ, а не отдельные языки программирования. Данные компиляторы используют язык программирования Object Pascal, лежащий в основе языка Delphi, который по синтаксису похож на обычный Pascal, но функционально существенно отличается.<br></p> <h2>Что такое синтаксис языка программирования?</h2> <p>Это формат написания различных операторов. Например, цикл «for» на паскале имеет следующий формат: «for n:=1 to k do» и т.д.</p><p>В языке программирования C++ этот же цикл пишется несколько иначе: for (n = 1; n Пишем калькулятор</p><p>Это даст вам понять, как взаимодействуют объекты с программным кодом, что такое «переменные», как работают математические функции. Всякое программирование в любом случае будет вычислением. Игра – это тоже программа, которая постоянно что-то считает, работает с цифрами и числовыми функциями. Программирование неотделимо от математики.</p> <p>Воспользуемся для написания средой разработки Lazarus. Её функционал не так богат, как, скажем, у CodeGear, но она находится в бесплатном доступе и предназначена для обучения.</p><p>Открывая среду разработки, мы видим форму и панель элементов. Вот форма.</p> <p><img src='https://i1.wp.com/reshatel.org/wp-content/uploads/2018/09/Bez-imeni-24.jpg' width="100%" loading=lazy></p><p>Вот панель элементов.</p><p>Первое, что мы сделаем – это добавим три необходимых нам элемента для реализации функции сложения двух чисел. Нужны: «Tedit» в количестве трёх штук и «TButton». На картинке ниже они показаны на панели стрелками. Щелкаем по ним один раз, а потом один раз по форме, и они появляются на ней.</p><p>Это текстовые поля для ввода и обычная кнопка. С данными элементами вы сталкиваетесь, используя практически любую программу Windows. Взгляните.</p><p><img src='https://i0.wp.com/reshatel.org/wp-content/uploads/2018/09/Bez-imeni-27.jpg' width="100%" loading=lazy><br></p> <p>Теперь очистим эти надписи. Нажмите вкладку «Вид». И щелкните по пункту «Инспектор объектов. Появится вот такое окно.</p><p><img src='https://i0.wp.com/reshatel.org/wp-content/uploads/2018/09/Bez-imeni-28.jpg' width="100%" loading=lazy></p><p>Щелкаем один раз по нашему элементу «Кнопка» на форму и меняем значение «Caption» в окне инспектора на любое другое. Например, на слово «Ок». Жмём Enter. Видим на форме, как элемент поменял название.</p><p>Так же поступим и с Edit’ами, только не переименуем, а сделаем их без всякого содержания. Выделяем их по очереди и очищаем значение Text в инспекторе. Не забываем жать Enter.</p><p><img src='https://i2.wp.com/reshatel.org/wp-content/uploads/2018/09/Bez-imeni-29.jpg' width="100%" loading=lazy></p><p>По итогу наша форма выглядит вот так.</p><p><img src='https://i1.wp.com/reshatel.org/wp-content/uploads/2018/09/Bez-imeni-30.jpg' width="100%" loading=lazy><br></p> <p>Теперь, чтобы наш калькулятор заработал, нужно прописать необходимый программный код для процедуры нашей кнопки. Жмём по элементу Button дважды и открываем редактор исходного кода.</p><p><img src='https://i0.wp.com/reshatel.org/wp-content/uploads/2018/09/Bez-imeni-31.jpg' width="100%" loading=lazy></p><p>Видите? Процедура Button1Click. Это процедура, которая отвечает за то, что произойдёт, когда мы нажмём по кнопке один раз. А произойти должно следующее: программе нужно в третьем Edit вывести нам сумму чисел, введённых в первых двух полях. Пишем код.</p><p><img src='https://i0.wp.com/reshatel.org/wp-content/uploads/2018/09/Bez-imeni-32.jpg' width="100%" loading=lazy></p><p>Такие несложные 5 строк кода нам нужно написать. Комментарии и пояснения видны на картинке выше. После этого, нажимаем вот эту кнопку.</p> <p>Будет выполнена компиляция нашего проекта. Он будет собран в программу. Вводим числа в первые два поля, жмём на кнопку и получаем значение суммы.</p><p><img src='https://i1.wp.com/reshatel.org/wp-content/uploads/2018/09/Bez-imeni-34-2.jpg' width="100%" loading=lazy></p> <h2>Заключение</h2> <p>Можете нажать кнопку «Файл», затем «Сохранить всё», выбрать папку для сохранения и у вас будет полноценная программа, запуск которой можно осуществить с рабочего стола. Теперь попробуйте разобраться самостоятельно, что нужно переписать в этом коде, чтобы программа делила два числа, а не складывала. Подсказка: нужно изменить тип данных. На видео ниже рассмотрен похожий пример, но в среде Delphi 7, а не Lazarus.</p><p><span class="6qR5tjJKK3g"></span></p> <p>Последнее время много внимания уделяется построение систем электронного бизнеса, или как их еще называют - B2B (business to business). Учитывая рекомендации по построению обменных потоковых систем координирующего интернет-технологий органа - WWW Consortium: акцент сделан в сторону XML-технологий и построение систем обмена XML-документами.</p> <p>Преимущество использования XML в электронном бизнесе - высокая эффективность B2B систем при низких затратах на ее создание за счет четкого и наглядного представления структурированной информации, возможность использования современных сетевых протоколов и создания бизнес-систем реального времени.</p> <p>Независимость представления информации в виде XML документов позволяет разным, участвующим в электронном бизнесе, фирмам производить независимое друг от друга ПО.</p> <p>Во всех системах обмен, как правило, строится по одинаковой схеме, с использованием HTTP запросов. В качестве протокола защиты информации применяется протокол SSL (но это отдельная тема).</p> <p>Один из возможных вариантов обработки XML сообщения является построение BIN/CGI (ISAPI)-приложений или COM (серверных) компонент, формирующих или обрабатывающих XML-документы.</p> <p>С одной стороны, приложение выступает в качестве клиента, которое в режиме POST выдает HTTP запрос, с другой стороны, находится WEB сервер на стороне которого осуществляется обработка запроса и выдача ответа. В информационном обмене используются XML-документы.</p> <p>Один из наиболее эффективных вариантов реализации - использование существующего XML-парсера, поддерживающего DOM модель. Такой парсер является дистрибутивной поставкой Win`98 или составной частью IE 4,7 и выше (для Win`95) и представляет COM сервер, находящийся в библиотеке msxml.dll.</p> <p>Модель компонентных объектов (COM) - представляет инкапсулированные данные и методы в единую сущность и способ доступа к ним через систему интерфейсов. Средствами Delphi достаточно просто осуществить доступ к классам COM-объекта (в одном COM-сервере может быть включено несколько классов). Доступ к объектам осуществляется путем инициализации экземпляра класса через систему интерфейсов. Описание интерфейсов осуществляется языком определения интерфейсов (IDL), которое возможно осуществить средствами среды автоматически.</p> <p>Средствами Delphi осуществляется импорт из COM-сервера <i>msxml.dll </i>, строится файлы описания интерфейса IDL и файл бинарного описания типов библиотеки - TLB. Данная операция осуществляется через системное меню: <b>Project | Type Library Import: </b>(рисунок 1). Далее появляется диалоговое окно (рисунок 2), в котором необходимо выбрать COM-объект (в нашем случае объект зарегистрирован под именем "Microsoft.XMLDom (Version 2.0)") и создать TLB-файл (кнопка <b>Create Unit </b>). Используя TLB-файл, среда генерирует "паскалевский" файл описания COM-сервера - MSXML_TLB.pas</p> <p>В файле MSXML_TLB.pas описаны все интерфейсы, константы и соклассы COM-сервера.</p> <p>Для доступа к объектам COM-элемента, необходимо в директиве <b>USES </b>добавить имя файла описания библиотеки (MSXML_TLB.pas). Ниже представлена простейшая программа, использующая DOM стандартный анализатор msxml.dll, которая загружает XML-документ и отображает его в элементе текстового поля Memo1.</p> <b>uses </b> Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, OleServer, MSXML_TLB, StdCtrls; <b>type </b> TForm1 = <b>class </b>(TForm) Button1: TButton; Memo1: TMemo; <b>procedure </b> Button1Click(Sender: TObject); <b> end; </b> <b>var </b> Form1: TForm1; <b>implementation </b> {$R *.DFM} <b>Procedure </b> TForm1.Button1Click(Sender: Tobject); <span> // объявление сокласса объекта DOMDocument; </span> <b>var </b> coDoc: CoDOMDocument; <span> // класс, согласованный с интерфейсом IDOMDocument; </span> <b>var </b> Doc: IXMLDOMDocument; <b>begin </b> <span> // создание экземпляра объекта DOMDocument; </span> Doc:= coDoc.Create; <span> // вызов метода Load экземпляра объекта DOMDocument; </span> Doc.load("data.xml"); <span> // доступ к свойстве xml экземпляра объекта DOMDocument; </span> Memo1.Text:=Doc.xml; <b>end; </b> <b>end. </b> <h2>Концепция DOM - объектная модель документа</h2> <p>Каждый XML документ представляется в виде набора множества объектов (классов), с помощью которых возможен доступ к отдельным элементам (полям объекта). DOM - интерфейс описывает доступ как к простым объектам типа DOMString или CharacterData, так и к частям или отдельным элементам XML документа: DOMFragmentElement, DOMNode, DOMElement.</p> <p>Ниже приведены самые важные свойства и методы объектов XMLDOMDocument, XMLDOMNode, XMLDOMNodeList. Необходимо отметить, что представленные ниже методы и функции объектов DOM модели (Document Object Model) используются Microsoft XML-анализатором msxml.dll и несколько шире, чем утвержденная W3C Консорциумом DOM модель.</p> <p>Более полное описание интерфейса DOM объектов можно найти на </p> <table cellspacing="0" cellpadding="4" width="500" border="1"><tbody><tr><td valign="top" colspan="2"> Объект XMLDOMDocument </td> </tr><tr><td valign="top" colspan="2">Представляет верхний уровень объектной иерархии и содержит методы для работы с документом: его загрузки, анализа, создания в нем элементов, атрибутов, комментариев и т.д. . </td> </tr><tr><td valign="top" colspan="2"><b>Свойства </b> </td> </tr><tr><td valign="top" width="39%"><b>Async </b> </td> <td valign="top" width="61%">Свойство идентифицирующее текущий режим обработки </td> </tr><tr><td valign="top" width="39%" height="19"><b>ParseError </b> </td> <td valign="top" width="61%" height="19">Возвращает ссылку на объект обработки ошибки XMLDOMParseError </td> </tr><tr><td valign="top" width="39%"><b>Включение - выключение верификации документа. </b> </td> <td> </td> </tr><tr><td valign="top" width="39%"><b>url </b> </td> <td valign="top" width="61%">Возвращает URL документа </td> </tr><tr><td valign="top" width="39%"><b>documentElement </b> </td> <td valign="top" width="61%">Содержит ссылку на корневой элемент документа в виде объекта XMLDOMElement. </td> </tr><tr><td valign="top" colspan="2"><b>Методы </b> </td> </tr><tr><td valign="top" width="39%"><b>load(url) <br>loadXML(xmlString) </b> </td> <td valign="top" width="61%">Загружает XML документ, </td> </tr><tr><td valign="top" width="39%"><b>save(objTarget) </b> </td> <td valign="top" width="61%">Сохраняет XML документ в файле </td> </tr><tr><td valign="top" width="39%"><b>abort </b> </td> <td valign="top" width="61%">Прерывание процесса загрузки и обработки документа. </td> </tr><tr><td valign="top" width="39%"><b>createAttribute (name) </b> </td> <td valign="top" width="61%">Создает для текущего элемента новый атрибут с указанным именем. </td> </tr><tr><td valign="top" width="39%"><b>createNode(Type, name, nameSpaceURI) </b> </td> <td valign="top" width="61%">Создает узел указанного типа и названия </td> </tr><tr><td valign="top" width="39%"><b>createElement(tagName) </b> </td> <td valign="top" width="61%">Создает элемент документа с указанным названием. </td> </tr><tr><td valign="top" width="39%"><b>createTextNode(data) </b> </td> <td valign="top" width="61%">Создает текст внутри документа </td> </tr><tr><td valign="top" width="39%"><b>getElementsByTagName(tagname) </b> </td> <td valign="top" width="61%">Возвращает ссылку на коллекцию элементов документа с заданным именем </td> </tr><tr><td valign="top" width="39%"><b>nodeFromID(idString) </b> </td> <td valign="top" width="61%">Поиск элемента по идентификатору </td> </tr></tbody></table><br><table cellspacing="0" cellpadding="4" width="500" border="1"><tbody><tr><td valign="top" colspan="2"> <b>Объект XMLDOMNode </b> </td> </tr><tr><td valign="top" colspan="2">Объект XMLDOMNode, реализующий базовый DOM интерфейс <b>Node </b>, предназначен для манипулирования с отдельным узлом дерева документа. Его свойства и методы позволяют получать и изменять полную информацию о текущем узле - его тип, название, полное название, его содержимое, список дочерних элементов и т.д. </td> </tr><tr><td valign="top" colspan="2"><b>Свойства </b> </td> </tr><tr><td valign="top" width=" "><b>nodeName, baseName </b> </td> <td valign="top" width="65%">Возвращает название текущего узла. </td> </tr><tr><td valign="top" width="35%"><b>prefix </b> </td> <td valign="top" width="65%">Возвращает Namespace префикс. </td> </tr><tr><td valign="top" width="35%"><b>dataType </b> </td> <td valign="top" width="65%">Определяет тип содержимого текущего узла </td> </tr><tr><td valign="top" width="35%"><b>nodeType, nodeTypeString </b> </td> <td valign="top" width="65%">Возвращает тип текущего узла: </td> </tr><tr><td valign="top" width="35%"><b>attributes </b> </td> <td valign="top" width="65%">Возвращает список атрибутов текущего узла в виде коллекции XMLDOMNamedNodeMap. </td> </tr><tr><td valign="top" width="35%"><b>text </b> </td> <td valign="top" width="65%">Возвращает содержимое текущего поддерева в виде текста </td> </tr><tr><td valign="top" width="35%"><b>xml </b> </td> <td valign="top" width="65%">Возвращает XML-представление текущего поддерева. </td> </tr><tr><td valign="top" width="35%"><b>nodeValue </b> </td> <td valign="top" width="65%">Возвращает содержимое текущего узла. </td> </tr><tr><td valign="top" width="35%"><b>childNodes </b> </td> <td valign="top" width="65%">Возвращает список дочерних элементов в виде XMLDOMNodeList. </td> </tr><tr><td valign="top" width="35%"><b>firstChild, lastChild </b> </td> <td valign="top" width="65%">Возвращает первый/последний дочерний элемент </td> </tr><tr><td valign="top" width="35%"><b>previousSibling ,nextSibling </b> </td> <td valign="top" width="65%">Возвращает предыдущий /следующий сестринский элемент. </td> </tr><tr><td valign="top" width="35%"><b>parentNode </b> </td> <td valign="top" width="65%">Содержит ссылку на родительский элемент. </td> </tr><tr><td valign="top" width="35%"><b>ownerDocument </b> </td> <td valign="top" width="65%">Возвращает указатель на документ, в котором находится текущий узел. </td> </tr><tr><td valign="top" colspan="2"><b>Методы </b> </td> </tr><tr><td valign="top" width="35%"><b>appendChild(newChild) </b> </td> <td valign="top" width="65%">Добавляет текущему узлу новый дочерний элемент. </td> </tr><tr><td valign="top" width="35%"><b>insertBefore(newChild, refChild) </b> </td> <td valign="top" width="65%">Вставляет дочерний узел, располагая его в текущем поддереве "левее" узла, указанного параметром refChild. </td> </tr><tr><td valign="top" width="35%"><b>cloneNode (deep) </b> </td> <td valign="top" width="65%">Создание копии текущего элемента. </td> </tr><tr><td valign="top" width="35%"><b>getAttribute </b><b>(name)<br> </b><b>getAttributeNode </b><b><span> (name)<br>setAttribute(name, value)<br>setAttributeNode(XMLDOMAttribute) </span> </b> </td> <td valign="top" width="65%">Доступ к атрибутам (создание, чтение, запись) объекта. Name - имя атрибута, value - его значение. Возращает значение объект XMLDOMAttribute. </td> </tr><tr><td valign="top" width="35%"><b>replaceChild(newChild, oldChild) removeChild(oldChild) </b> </td> <td valign="top" width="65%">Замена объекта oldChild текущего списка дочерних объектов на newChild. Удаление объекта oldChild </td> </tr><tr><td valign="top" width="35%"><b>selectNodes(patternString) selectSingleNode(patternString) </b> </td> <td valign="top" width="65%">Возвращает объект XMLDOMNodeList, выбранное по шаблону поиска или первый узел </td> </tr><tr><td valign="top" width="35%"><b>transformNode(stylesheet)<br>transformNodeToObject(stylesheet, outputObject) </b> </td> <td valign="top" width="65%">Назначает стилевую таблицу для поддерева текущего узла и возвращает строку - результат обработки. В качестве параметра передается ссылка на объект DOMDocument, в котором находятся XSL инструкции. </td> </tr></tbody></table><br><h2>Использование XML в бизнесе.</h2> <p>Для более ясной картины необходимо пояснение, а зачем все это нужно с тем, что бы понять, как это работает:</p> <p>При построении B2B или корпоративной ERP системы, при организации информационного обмена XML-документами между предприятиями или филиалами пр-я, используются эффективно себя зарекомендовавшая система передачи информации на основе имеющихся WEB серверов по HTTP протоколам.</p> <p>С одной стороны, приложение выступает в качестве клиента, которое в режиме POST выдает HTTP запрос, с другой стороны, находится WEB сервер, на стороне которого осуществляется обработка запроса и выдача ответа. В качестве обмена используются XML-документы.</p> <p>Например, в простой корпоративной ERP системе бухгалтерской программе (АСУ Бухучет) необходимо сформировать некий запрос на выписку накладной и передать его в филиал, который имеет склад (АСУ Склад). АРМ Аналогичная постановка задачи при создании В2В системы, когда Предприятие А запрашивает наличие продукции (делает заказ на приобретение) у Поставщика В.</p> <p>Предприятие А и его программа выступает в качестве клиента. Склад обслуживает Поставщик В, у которого находится складской комплекс БД на SQL сервере. Обмен осуществляется через корпоративный WEB сервер Поставщика В.</p> <p>Ниже представлен следующий типовой алгоритм обмена:</p> <br>Рисунок 3. <ol><li><b>Предприятие А </b>инициирует <b>процесс А </b>(заказ продукции), который выступает в качестве WEB-клиента.</li><li><b>Процесс А </b>формирует XML документ (например запрос- накладная) и передает его как POST запрос http на WEB сервер Поставщика В. В качестве URI - используется идентификатор ресурса обрабатывающего приложения. URI может быть одинаковым как для всех типов документов, либо индивидуальным для каждого типа. Все зависит от структуры B2B (WEB) сервера.</li><li>WEB сервер анализирует запрос и порождает серверный <b>Процесс В </b>, передавая в качестве параметра тело XML документа. <br>Процессе В запускается WEB-сервером и обрабатывается либо как ASP страница,CGI (ISAPI) - приложение или JAVA севрлет (серверное приложение)</li><li><b>Процесс В </b>- формирует запрос на SQL-сервер базы данных.</li><li>SQL-сервер производит необходимые операции в БД, формирует ответ и возвращает его <b>Процессу В </b>.</li><li>По ответу от SQL-сервера <b>Процесс В </b> формирует XML документ (ответ) и возращает его как на ответ на http запрос клиентскому приложению.</li><li>Далее, в зависимости от ситуации на стороне клиента формируется либо новый http запрос, либо заканчивается сеанс.</li> </ol><h2>Несколько слов об организации документооборота.</h2> <p>Общим правилом разработки системы обмена XML документами является:</p><ul><li><b>во-первых </b>- разработка схемы потоков электронных документов и их структуры;</li><li><b>во-вторых </b>- разработка таблиц функций процессов (подпроцессов) т.е. какую функцию по отношению к какому XML-документу будет реализовывать каждый процесс.</li> </ul><p>Каждый XML документ, подобно HTML документу, должен состоять из заголовка сообщения (информация заключенная тагами) и тела сообщения (для запроса эта информация обрамленная тагами для ответа на запрос). Для того, чтобы XML документ был правильно сформирован, необходимо его две составные части "Заголовок" и "Запрос" обрамить тегами, например. Вид типового документа представлен ниже:</p> <p>Заголовок (Рисунок 4), в отличие HTML документа, должен содержать разного рода служебную информацию, в том числе информацию о типе передаваемого документа и процессе его обработки. В информационную обработку поступает тело документа, т.е. содержательная часть обрамленная тагами. Следует отметить, что структуру заголовков должна быть единой для всех типов документов.</p> <p>Для запущенного сервером Процесса, алгоритм обработки предпочтительно (но не обязательно) строить следующим образом:</p> <img src='https://i2.wp.com/codenet.ru/np-includes/upload/2005/01/05/128666.jpg' height="500" width="408" loading=lazy><br>Рисунок 6. <h2>Некоторые принципиальные моменты при создании клиентской части</h2> <p>Как уже пояснялось, при создание XML-документа используется его представление в виде DOM модели. Ниже приведен пример части текста Delphi программы создания заголовка xml сообщения.</p> <b>procedure </b> TThread1.HeaderCreate(Sender: Tobject); <b>var </b> <span> // объявление сокласса, необходим для создания </span> coDoc: CoDomDocument ; <span> // объекта XMLDomDocument </span> Doc: DomDocument ; r: IXMLDOMElement; Node: IXMLDOMElement; // DOMText txt: IXMLDOMText; // DOMAttribute attr: IXMLDOMAttribute; <b>begin </b> <span> // создание документа DOM </span> Doc:=coDoc.Create; Doc.Set_async(false); <span> // начальная инициация DOM документа </span> Doc.LoadXML("<Header/>"); <span> // создание DOMElement (таг <<b>Sender </b>>) </span> Node:= Doc.createElement ("Sender"); <span> // создание текстового узла "<b>ООО "Тайфун" </b>" </span> txt:= Doc.createTextNode("ООО "Тайфун""); <span> // присвоение узлу <<b>Sender </b>> значение </span> <span> // текстового узла "<b>ООО "Тайфун" </b>" </span> Node.appendChild(txt); <span> // добавление элемента <<b>Sender </b>> в корень документа как дочернего </span> r.appendChild(Node); <span> <<b>From </b>> </span> Node:= Doc.createElement ("From"); txt:= Doc.createTextNode("http://tayfun.ru/xml/default.asp"); Node.appendChild(txt); r.appendChild(Node); <span> // аналогичные операции для тага <<b>To </b>> </span> Node:= Doc.createElement ("To"); txt:= Doc.createTextNode("http://irbis.ru"); Node.appendChild(txt); r.appendChild(Node); <span> // создание DOMElement () </span> Node:= Doc.createElement ("TypeDocument"); <span> // создание узла XMLDOMAttribute </span> Att:= Doc.createAttribute ("Id ", " Order"); <span> // <TypeDocument Id="Order"/> </span> Node.appendChild(Att); r.appendChild(Node); <b>end; </b> <p>Следует отметить, что объявление переменной coDoc: CoDomDocument и Doc: DomDocument , а также ее создание методом Create (Doc:=coDoc.Create;) осуществляется один раз. Объявление переменной находится в секции описания глобальных переменных, а не в локальной процедуре, как было продемонстрировано для наглядности в данном примере (т.е. одна глобальная переменная типа DomDocument на один программный модуль).</p> <p>Результатом работы вышеприведенной программы будет созданный заголовок, применительно к нашему примеру xml-документа: изображен на рисунке 5.</p> <img src='https://i1.wp.com/codenet.ru/np-includes/upload/2005/01/05/128662.gif' height="116" width="298" loading=lazy><br>Рисунок 5.<p><img src='https://i0.wp.com/codenet.ru/np-includes/upload/2005/01/05/128664.gif' height="179" width="385" loading=lazy><br>Рисунок 6. </p><p>Основное преимущество передачи информации в виде XML-документов в том, что существует возможно формировать сообщение, используя независимые структуры таблиц в СУБД как на принимаемой, так и на передаваемой стороне. Используя наш пример, пусть требуется передать информацию об инвойсах Предприятия А, из СУБД имеющий структуру, изображенную на рисунке 6</p> <p>Для формирования xml-документа, содержащего инвойс первоначально строится SQL-запрос (запрос А) с информацией о самом инвойсе:</p> <b>SELECT </b> * FROM Invoice_General <b>WHERE </b> InvoiceNum = :num <b>SELECT </b> Goods,Qulity,Price, HZ_cod <b>FROM </b> Goods <b>WHERE </b> InvoiceNum = :num <span> // :num - параметр, который задает номер инвойса. </span> <p>Ниже представлена часть программы, формирующей тело xml-документа:</p> <b>procedure </b> TThread1.DataBodyCreate(Sender: Tobject); <b>var </b> <span> // объявление сокласса и объекта XMLDomDocument </span> //coDoc: CoDomDocument ; <span> // должно быть глобальным, для всего модуля. </span> //Doc: DomDocument ; <span> // объявление объектов DOMElement </span> r: IXMLDOMElement; // DOMElement; Node, Node2: IXMLDOMElement; Node3, Node4: IXMLDOMElement; // DOMText txt: IXMLDOMText; str: String; <span> // InvoiceNumber: <b>integer; </b> - глобальная переменная - // имеет значение 987654 // queryA, queryB: <b>String; </b> - глобальная переменная, // имеет значение,соответствующее запросу // queryA - запрос А генеральная информацией об инвойсе // queryB - запрос B информация о товарах, описываемых в // инвойсе (см. текст) </span> <b>begin </b> Query.Close; <span> // см. по тексту "запрос А" </span> Query.Text:= queryA; <span> // выполнение запроса </span> Query.ExecSQL; Query.Open; <span> // получение адреса корневого элемента </span> r:=Doc.Get_documentElement; Node2:= Doc.createElement (" Request "); <span> // создание DOMElement (таг) </span> Node:= Doc.createElement ("Invoice"); <span> // добавление элемента в корень </span> r.appendChild(Node2); <span> // добавление элемента в </span> Node2. appendChild(Node); <span> // создание DOMElement (таг) </span> Node3:= Doc.createElement ("Depurture") ; <span> // добавление элемента в </span> Node. appendChild(Node3); <span> // обращение к полю "Depurture" запроса </span> str:= Query.FieldByName("Depurture").AsString; <span> // создание текстового узла = значению поля </span><span> // присвоение узлу значение </span> <span> // текстового узла, переменной str </span> Node.appendChild(txt); <span> // аналогичные операции для тага <Destination>, <DataSend>, // <DataDepurture>, <Currency> // <DestinationCompany> (поле DB "Consignee") </span> Node:= Doc.createElement ("Destination"); <span> // имя поля БД может и не совпадать с именем </span> str:= Query.FieldByName("Consignee ").AsString; <span> // тага, в этом преимущество использования </span> txt:= Doc.createTextNode(str); <span> // DOM интерфейса перед СУБД, имеющим поддержку XML-интерфейса, // типа ORACLE 8i или Ms SQL 2000 </span> Node.appendChild(txt); ... <span> // формирование запроса на спецификацию по товарам </span> <span> // закрывает запрос для доступа </span> Query.Close; <span> // см. по тексту "запрос В", информац. О товарах </span> Query.Text:= queryВ; <span> // присваивание значения параметров </span> Query.Params.AsInteger:= InvoiceNumber; <span> // выполнение запроса </span> Query2.ExecSQL; <span> // открытие доступа к данным запроса </span> Query.Open; <span> // создание DOMElement (таг) </span> Node3:= Doc.createElement (" Imems") ; <span> // добавление элемента в </span> Node. appendChild(Node3); <span> // цикл по всем строкам запроса </span> <b>while </b> <b>not </b> Eof.Query <b>do </b> begin Node4:= Doc.createElement ("Imem"); <span> // добавление элемента в </span> Node3.appendChild(Node4); <span> // формирование данных для тага </span> str:= Query.FieldByName("Price").AsString; txt:= Doc.createTextNode(str); Node.appendChild(txt); ... <span>// аналогичные операции для тагов <HZ_Cod>, <Quality>, <GoodName> </span> <b>end; </b> <b>end; </b> <p>В результате выполнения данной процедуры формируется следующий текст XML-документа:</p> <table width="100%"><tbody><tr><td align="middle"><br><img src='https://i1.wp.com/codenet.ru/np-includes/upload/2005/01/05/128661.gif' width="100%" loading=lazy></td> </tr></tbody></table><p>Для формирования запроса используется метод Open объекта <b>IXMLHttpRequest </b>:</p> <b>procedure </b> Open(const bstrMethod, - тип метода ="POST" bstrUrl, - Url адрес сервера varAsync, - режим связи асинхронный/синхронный = true bstrUser, - имя пользователя для аутентификации bstrPassword) - пароль <h2>Создании серверной части обработки документа</h2> <p>Как было отмечено ранее, обработка HTTP запроса может осуществляться либо CGI-приложениями, либо Java-сервлетами. Возможен и вариант написания ASP-страниц. Но в этом случае передача данных возможна только методом "GET" через строку запроса. Хотя, обработка HTTP запроса ASP-страниц работает более эффективнее, чем CGI-приложением. Однако, на мой взгляд, без разницы, как обрабатывать, а важнее решить вопрос - как построить программу обработки, а не какими средствами.</p> <p>Если из предыдущей главы мы рассмотрели варианты формирования XML-документ, то задача серверного приложения обратная - разбор XML-документов. Ниже представлена часть программы, осуществляющей разбор xml-документа:</p> <b>procedure </b> Tthread1.DataParser(Sender: Tobject); <b>var </b> <span>// объявление объектов DOMElement </span> r,FNode: IXMLDOMElement; Str,Filename: String; parm: String; <span>// объявление сокласса и </span> CoDocXML, CoDocXSL, CoDocResult: CoDomDocument ; <span>// объекта XMLDomDocument </span> XMLDoc, XSLDoc, ResultDoc: DomDocument ; <span>// HttpStr: String; - глобальная переменная, содержащая строку HTTP запроса </span> <b>Begin </b> XMLDoc:=coDocXML.Create; XMLDoc.LoadXML(HttpStr); <span> // получение адреса корневого элемента </span> r:=Doc.Get_documentElement; <span> // получение значения элемента </span> FNode:= r.SelectSingleNode("//TypeDocument"); <span> // получение значения атрибута id="Order" </span> FileName:= FNode.GetAttibute("id"); <span> // и формирование имени файла Order.xsl </span> FileName:= FileName+".xsl"; <span> // создание документа XSLDoc </span> XSLDoc:=coDocXSL.Create; XSLDoc.LoadXML(FileName); <span> // создание документа XMLDoc </span> ResultDoc:=coDocResult.Create; <span> // установка синхронного режима обработки </span> ResultDoc.Set_async(false); <span> // установка проверки разбора </span> ResultDoc.validateOnParse:= true; <span> // разбор XMLDoc по XSL-шаблону </span> XMLDoc.transformNodeToObject(XSLDoc, ResultDoc); <span> // переменной Str присваивается текстовое значение </span> <span> // результирующего документа. </span> Str:= ResultDoc.text; <span> // поиск элемента </span> FNode:= r.SelectSingleNode("//InvoiceNumber"); <span> // и получение значения элемента </span> parm:= FNode.text; <span> // закрывает запрос для доступа </span> Query.Close; Query.Text:= Str; <span> // присваивание значения параметра </span> Query.Params.AsString:= parm; <span> // выполнение запроса </span> Query.ExecSQL; <b>end; </b> <p>Вся изюминка разбора заключается в применении XSL-шаблона, который сформирован для каждого типа документа индивидуально. Результатом разбора является строка SQL-запроса. В последствие выполнение сформированной строки SQL-запроса осуществит необходимые изменения данных в СУБД.</p> <p>Преимущество использования разбора через шаблон еще и в том, что получается некая гибкость данных, и получается полная независимость работы алгоритма от программного кода. Ниже приведен используемый для обработки документа типа ORDER текст XSL-шаблона:</p><p> <!-- файл Order.xsl --> <xsl:stylesheet xmlns:xsl="http://www.w3.org/TR/WD-xsl"> <xsl:template match="/"> <xsl:for-each select="//header"> INSERT into TABREG (FROM, TO, TYPEDOC,body) VALUES(" <xsl:value-of select="from" />", "<xsl:value-of select="to" />", "<xsl:value-of select="TypeDocument/@id" />") </xsl:for-each> <xsl:for-each select="//item"> INSERT into GOODS (invoiceNumber, name, price, quality) VALUES(" :num", "<xsl:value-of select="name" />", "<xsl:value-of select="price" />", "<xsl:value-of select="quality" /> ") </xsl:for-each> </xsl:template> </xsl:stylesheet> </p><p>Поясняя вышеприведенный пример, надо отметить, что использование пары тагов и носит формальный характер, т.к. после разбора в результирующем XML-документе формально должен присутствовать хотя бы один узел. Метод ResultDoc.text присваивает текстовое значение полученного в ходе разбора XML-документа ResultDoc. В этом случае значением является все то, что обрамлено пары тегов и, т.е. сформированный нами SQL-запрос.</p> <p>Другой особенностью написания программы надо отметить возможность использования SQL-параметра <b>:num. </b> Использование параметра позволяет упростить текст xsl-шаблона. Определение значение соответствующих элементов узлов XML-документа определяется первоначально выбора по имени соответствующего узла, например:</p><h2>Коротко об XSL</h2> <p>Аббревиатура XSL происходит от eXtensible Stylesheet Language - язык форматирования таблиц стилей (XML данных). Как понятно из заголовка eXtensible Stylesheet Language (XSL) используется для форматирования XML данных. По определению W3C XSL состоит из двух частей:</p> <ul><li>XSLT - XSL Transformation. Язык, используемый для преобразования или форматирования (трансформирования) XML документов. Таким образом, при помощи XSLT мы можем получить разные разрезы множества данных и формы представления данных.</li><li>Элементы форматирования. К этим элементам относятся все элементы типографического оформления данных, после их обработки их при помощи XSL. Используется только для формирования HTML страниц.</li> </ul><p>При помощи XSLT мы можем отобрать нужные нам данные из XML файла, и оформить их в виде для предоставления пользователю. Например, в нашем случае мы преобразовали XML данные в виде SQL запроса. Классическое применение XSL - это, как правило форматирование данных в виде HTML страниц или более редкое представление в виде RTF файлов.</p> <p>XSL файл описывает шаблон (template), согласно которому будет совершаться преобразование XML данных. Возвращаясь к xsl-шаблонам, в XSLT можно выделить следующие элементы (директивы):</p> <table cellspacing="0" cellpadding="4" width="500" border="1"><tbody><tr><td valign="top" width="31%"> <b>XSL-директивы </b> </td><th align="middle" width="69%"> <b>описание </b> </th> </tr><tr><td>xsl:apply-templates </td> <td>Директива, указывающая на применение соответствующих шаблонов атрибуту select="имя шаблона" </td> </tr><tr><td>xsl:attribute </td> <td>создает дерево атрибутов и добавляет его в выходной элемент, параметр name="имя атрибута", namespace - URI на пространство имен (префикс пространства имен) </td> </tr><tr><td>xsl:call-template </td> <td>вызывает шаблон, атрибуту name=" URI на шаблон" </td> </tr><tr><td>xsl:choose<br>xsl:when<br>xsl:otherwise </td> <td>осуществление выбора по условию xsl:when expr="вычисление выражения на script ", <br>language="language-name" <br>test= "вычисляемое выражение" </td> </tr><tr><td>xsl:comment </td> <td>генерирует комментарий в выходной документ </td> </tr><tr><td>xsl:copy<br>xsl:copy-of </td> <td>копирует текущей узел в выходной источник или вставляет фрагмент документа в узел, где атрибут select="имя узла источника" </td> </tr><tr><td>xsl:element </td> <td>создает выходной элемент по имени, атрибут name="имя элемента", namespace="uri ссылка на пространство имен" </td> </tr><tr><td>xsl:for-each </td> <td>повторно применяет шаблон ко всем узлам списка узлов, атрибут select задает список узлов </td> </tr><tr><td>xsl:if </td> <td>проверка условия, задается атрибутом test в виде выражения </td> </tr><tr><td>xsl:include </td> <td>включает внешний шаблон, атрибут href = "URI reference" </td> </tr><tr><td>xsl:output </td> <td>специфицирует выходной результат, атрибут method может иметь значения "xml", "html" или "text" </td> </tr><tr><td>xsl:param </td> <td>специфицирует значение параметров, атрибут name="имя параметра", select = "значение" </td> </tr><tr><td>xsl:processing-instruction </td> <td>создает инструкцию обработки, атрибут name="имя процесс инструкции" </td> </tr><tr><td>xsl:sort </td> <td>сортирует множество узлов, атрибуты select = "имя узла", data-type = тип данных {"text" | "number" | Qname}, order = направление сортировки {"ascending" | "descending"} </td> </tr><tr><td>xsl:stylesheet </td> <td>определяет документ xsl-шаблонов, является корневым элементом для XSLT </td> </tr><tr><td>xsl:template </td> <td>определяет xsl-шаблон, атрибут name= " URI префикс на имя шаблона", match= "указание на узел, к которому применяется шаблон" </td> </tr><tr><td>xsl:text </td> <td>генерирует текст в выходной поток, атрибут disable-output-escaping = "yes" или "no", указывает на возможность генерации символов ESC </td> </tr><tr><td>xsl:value-of </td> <td>вставляет значение выбранного узла как текст, атрибут select= "указатель на узел" из которого берут значение </td> </tr><tr><td>xsl:variable </td> <td>специфицирует значение границ переменных, атрибут name = "имя переменной", select = "вычисление значения переменной" </td> </tr><tr><td>xsl:with-param </td> <td>применяет параметр к шаблону, атрибут name ="имя параметра", select = выражение для вычисления текущего контекста, значение по умолчанию "." </td> </tr></tbody></table><h2>Заключение</h2> <p>В заключение, необходимо отметить, что использование стандартного XML-парсера <i>msxml.dll </i>является не единственным средством разбора и создания XML-документов. Например, для создание XML документов эффективно использовать компоненты <b>TPageProduser </b>и <b>TТableProduser </b>. Но, данная статья лишь подчеркивает широту и возможность применения на практике DOM модели.</p> <p>Автор будет очень благодарен за отзывы об актуальности темы, общем содержании, стиле изложения, а также всем остальным комментариям, которые помогут в дальнейшем улучшить качество написания сборника статей и выпуску книги, освещающую тему практической стороны использования XML-документов в электронной коммерции. Более подробную информацию о практической стороне применения электронных документов можно почерпнуть на авторском сайте www.eDocs.al.ru Также на авторском сайте планируется разместить исходные тексты и примеры.</p> <p>Добро пожаловать! Этот блог посвящен интернету и компьютерам, а, точнее был им посвящен.</p> <p>Наверное, сразу видно, что уже много лет на сайте не появлялось новых статей. Да, такова судьба большинства блогов. Когда-то этот проект был амбициозным начинанием, и у автора, как и у многих других, писавших в то время, были масштабные планы стать одним из лучших российских блоггеров. Что же, если сейчас посмотреть, то из тех блогов, что создавались одновременно с моим, большинство уже растворилось в вечности. И у меня банально стало не хватать времени на блог. Так что да, он больше не обновляется. Хотя когда-то мы с этим сайтом выиграли в конкурсе "Блог рунета 2011".</p> <p>У меня даже была мысль удалить все это, но потом я пересмотрел старые материалы, и понял, что они все еще могут быть полезны читателям. Да, некоторые статьи устарели (если у меня хватит сил, то они получат соответствующие пометки), но сайт, например, может быть полезен начинающим - здесь можно прочитать про базовые понятия интернета, научиться настраивать интернет, Windows или даже решиться перейти на Linux. Так что посмотрите на рубрики и выберите ту, которая подойдет именно вам.</p> <p>И, все-таки, я надеюсь, что это - больше, чем просто блог, а настоящий путеводитель по интернету. Сайт можно смотреть в режиме справочника , где все имеющиеся статьи структурированы по категориям. И, кто знает, может быть, в один день здесь начнут появляться новые качественные статьи.</p> <p><i>Сандер </i></p> <p>Picodi.ru - это скидочный портал от компании International Coupons , польского эксперта в области экономии и дешёвых покупок. Поляки считаются одной из самой экономных наций на свете, поэтому неудивительно, что такого типа проект вырос именно из польского стартапа kodyrabatowe.pl . Чем может пригодиться этот портал рядовому пользователю интернета в России?</p> <p>Современные телефоны под управлением android это больше, чем телефоны. Вы привыкаете к набору установленных программ, к истории своих звонков и текстовых сообщений, коллекции фотографий и многому другому. Но время идет, и устраивавший вас полностью аппарат начинает тормозить, глючить, или же просто теряет презентабельный вид из-за сколов на корпусе или царапин на экране. Возникает вопрос выбора нового телефона и смены android телефона. И если вопрос выбора мы сейчас обойдем стороной, то "переезд" на новый телефон остается серьезной проблемой - совершенно не хочется заводить все данные с нуля. Вот об этом мы сегодня и поговорим.</p> <p>Большинство из читателей этого блога, скорей всего, никогда с системами контроля версий не сталкивались и в ближайшее время не столкнутся. А жалко. Это чрезвычайно удобное изобретение достаточно широко используется программистами, но, на мой взгляд, могло бы очень пригодиться и тем, кто активно работает с текстами. Но, наверное, сейчас нет ни одной системы контроля версий, которую было бы легко начать использовать для "офисной" (Microsoft Office) работы. Тем не менее, мне думается, что материал, изложенный в статье, может быть интересным для всех читателей.</p> <p>Если вы задумывались о том, как с вашего телевизора смотреть фильмы по сети и выходить в интернет, эта статья для вас. Нет, я знаю о том, что у некоторых телевизоров и так есть функциональность Smart TV, однако я ни разу не видел, чтобы она работала нормально. Видимо поэтому недавно корпорация Google продемонстрировала совершенно потрясающее устройство, немедленно ставшее сенсацией. Речь идет о медиа-стримере Chromecast (Хромкаст), более совершенной и доступной версии прошлогоднего провального плеера Nexus Q.</p> <p>Донгл Хромкаст, размеры которого не превышают 2 дюймов, подключается к порту HDMI телевизора и позволяет наслаждаться просмотром потокового веб-контента. Для управления стримером можно использовать любое устройство (планшет, ПК, смартфон) базирующееся на операционной платформе iOS, Windows, Android или Mac OS.</p> <p>Эта статья посвящена устройству системной памяти android, проблемам, которые могут возникать из-за ее нехватки и способам их решения. Я сам не так давно столкнулся с тем, что мой телефон на базе android стал регулярно выдавать сообщения о нехватке памяти при попытке установить то или иное приложение. Что было для меня очень странно при том, что по описанию на маркете там должно было иметься около 16GB, да еще и я увеличил этот объем при помощи дополнительной карты памяти. Однако проблема имелась, и пришлось основательно повозиться, прежде чем я нашел правильное решение, не требующее получения root-доступа или полного восстановления телефона к заводскому состояние.</p> <p>У многих программистов Delphi, сохранение настроек ассоциируется с использованием <i>INI </i> файлов в своих программах. Применение данного метода, в более менее серьезных проектах, необходимо избегать, так как это ограничивает в гибкости, что препятствует дальнейшему расширению программы. Стоит сказать, что такой подход достаточно популярен, в силу своей простоты использования и наличия встроенных средств в среду разработки.<br><br> Тем не менее, идеальным вариантом для хранения настроек программы являются структурированные <i>XML </i> файлы. Их преимущество заключается в том, что количество параметров может быть не фиксированным. Чтобы лучше это понять, рассмотрим конкретный пример.</p><p>В программе USearch , при клике по записи, появляется контекстное меню , в котором отображается список пунктов. Эти пункты являются командами, которые в свою очередь загружаются из файла настроек. В случае, если бы настройки хранились в <i>INI </i> файле, то программа могла бы сохранять и загружать определенное количество команд, например 10 или 50. Как только потребуется большее значение, придется заново переписывать код и соответственно повторно компилировать его.</p><p><img src='https://i0.wp.com/zoo-mania.ru/wp-content/uploads/2011/08/settings.ini_.jpg' height="145" width="247" loading=lazy><br> Применяя подход с использованием <i>XML </i> файлов, у нас появится возможность загружать все параметры секции динамически. Ко всему этому, файл конфигурации станет более изящным, без избыточной нумерации параметров. Однако, стандартные средства для работы с <i>XML </i> в Delphi имеют множество недостатков, поэтому рекомендую использовать стандартную библиотеку <b>MSXML </b>. Обычно она по-умолчанию входит в состав операционных систем семейства Windows.</p><p><img src='https://i2.wp.com/zoo-mania.ru/wp-content/uploads/2011/08/settings.xml_.jpg' align="center" width="100%" loading=lazy><br> Для подключения <b>MSXML </b>, нам необходимо сформировать файл интерфейса со списком всех функций, импортировав его из COM-сервера. Как импортировать интерфейс написано не мало подробных статей, я же предлагаю вам скачать файл <b>MSXML2_TLB.PAS </b> уже готовый к использованию. После того, как файл будет скачан, разместите его рядом с вашим проектом, либо закиньте в папку lib среды Delphi. Таким образом, все создаваемые программы смогут использовать модуль <b>MSXML </b>, достаточно лишь дописать в uses строчку MSXML2_TLB .</p><p>Для наглядности, рассмотрим следующий пример применения этой библиотеки:</p><p>Procedure LoadData; var XMLDoc: DOMDocument; Root: IXMLDOMElement; begin XMLDoc:= CoDOMDocument.Create; XMLDoc.Load("settins.xml"); Root:= XMLDoc.DocumentElement; ShowMessage(Root.SelectSingleNode("size/width").Text); Root:= nil; XMLDoc:= nil; end; </p><p>Сначала создается экземпляр класса DOMDocument , после чего в память загружается содержимое файла settings.xml . Так как по стандарту любой <i>XML </i> файл должен содержать корневой тэг (в данном случае <i>config </i>), то нам необходимо его получить, используя функцию <i>DocumentElement </i>. Затем происходит вывод содержимого между тэгами <width></width> , которые в свою очередь находятся между тэгами <size></size> . Таким образом из файла settings.xml , наш метод выведет в MessageBox текст <i>"100px" </i>.</p><p> <?xml version="1.0" encoding="utf-8"?> <config> <size> <height>500px</height> <width>100px</width> </size> </config> </p><p>Здесь применен метод SelectSingleNode , который в качестве параметра принимает строку</p> <script>document.write("<img style='display:none;' src='//counter.yadro.ru/hit;artfast_after?t44.1;r"+ escape(document.referrer)+((typeof(screen)=="undefined")?"": ";s"+screen.width+"*"+screen.height+"*"+(screen.colorDepth? screen.colorDepth:screen.pixelDepth))+";u"+escape(document.URL)+";h"+escape(document.title.substring(0,150))+ ";"+Math.random()+ "border='0' width='1' height='1' loading=lazy>");</script> </div> <div class="data"> <div class="data__top clearfix"> <div class="data__print"> <a href='javascript:window.print(); void 0;'> Печать</a> </div> </div> <div class="data__bottom clearfix"> <div class="data__share"> <script src="//yastatic.net/es5-shims/0.0.2/es5-shims.min.js"></script> <script src="//yastatic.net/share2/share.js"></script> <div class="ya-share2" data-services="vkontakte,facebook,odnoklassniki,moimir,gplus,twitter,evernote,whatsapp,skype"></div> </div> </div> </div> <div class="navi"> <a href="/hardware-solutions/chasy-na-ekran-kompyutera-cifrovye-chasy-na-rabochii-stol-kompyutera.html" class="navi__prev"></a> <!-- /next_post --> <a href="/wi-fi-setup/chto-takoe-kachestvo-chastic-v-gta-5-grand-theft-auto-v-grafika-rukovodstvo-po-nastroikam-testirova.html" class="navi__next"></a> <!-- /next_post --> </div> </div> </div> <div class="news-blocks clearfix"> <div class="news-block"> <div class="papers"> <div class="papers__title">Также интересно:</div> <div class="papers__items"> <style> </style> <div class="papers__item"> <div class="papers__img"> <a href="/tips-for-beginners/smartfony-s-frontalnoi-kameroi-8-smartfony-s-horoshei-frontalnoi.html"><img src="/uploads/4da1e45504dd0be15637f959099eb9f2.jpg" style="width:70px; height:70px;" / loading=lazy></a> </div> <div class="papers__ovh"> <div class="papers__name"> <a href="/tips-for-beginners/smartfony-s-frontalnoi-kameroi-8-smartfony-s-horoshei-frontalnoi.html">Смартфоны с хорошей фронтальной камерой</a> </div> <div class="papers__category"> </div> </div> </div> <div class="papers__item"> <div class="papers__img"> <a href="/computer-security/pishet-obnovit-flesh-pleer-dlya-yandeksa-kak-v-yandex-brauzere.html"><img src="/uploads/a11967da76a86fbea9159f924f37575d.jpg" style="width:70px; height:70px;" / loading=lazy></a> </div> <div class="papers__ovh"> <div class="papers__name"> <a href="/computer-security/pishet-obnovit-flesh-pleer-dlya-yandeksa-kak-v-yandex-brauzere.html">Как в Yandex браузере активировать нужный Adobe Flash Player</a> </div> <div class="papers__category"> </div> </div> </div> <div class="papers__item"> <div class="papers__img"> <a href="/windows-10/ipad-postoyanno-zaprashivaet-parol-vkontakte-icloud-sprashivaet-parol-ot-starogo.html"><img src="/uploads/3b61969e520fdb40c90f2e38edeaceb7.jpg" style="width:70px; height:70px;" / loading=lazy></a> </div> <div class="papers__ovh"> <div class="papers__name"> <a href="/windows-10/ipad-postoyanno-zaprashivaet-parol-vkontakte-icloud-sprashivaet-parol-ot-starogo.html">ICloud спрашивает пароль от старого Apple ID — что делать</a> </div> <div class="papers__category"> </div> </div> </div> </div> </div> </div> <div class="news-block"> <div class="papers"> <div class="papers__title">Рекомендуем почитать:</div> <div class="papers__items"> <div class="papers__item"> <div class="papers__img"> <a href="/problem-solving/obmen-mezhdu-ut-11-3-i-bp-3-0-optovaya-prodazha-po-zakazu.html"> <img width="50" height="50" src="/uploads/7ea3d6af07f237148fc11d62853c72a0.jpg" class="attachment-50 size-50 wp-post-image" alt="Обмен между ут 11.3 и бп 3.0. Оптовая продажа по заказу покупателя" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a> </div> <div class="papers__ovh"> <div class="papers__date">2024-05-01 03:58:25</div> <div class="papers__name"> <a href="/problem-solving/obmen-mezhdu-ut-11-3-i-bp-3-0-optovaya-prodazha-po-zakazu.html">Обмен между ут 11.3 и бп 3.0. Оптовая продажа по заказу покупателя</a> </div> </div> </div> <div class="papers__item"> <div class="papers__img"> <a href="/wi-fi-setup/izmenit-shrift-vkontakte-kak-uvelichit-shrift-v-kontakte-tri-prostyh.html"> <img width="50" height="50" src="/uploads/0800df5ef4d3760ca00c7b3214710c7e.jpg" class="attachment-50 size-50 wp-post-image" alt="Как увеличить шрифт В Контакте?" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a> </div> <div class="papers__ovh"> <div class="papers__date">2024-04-30 03:52:58</div> <div class="papers__name"> <a href="/wi-fi-setup/izmenit-shrift-vkontakte-kak-uvelichit-shrift-v-kontakte-tri-prostyh.html">Как увеличить шрифт В Контакте?</a> </div> </div> </div> <div class="papers__item"> <div class="papers__img"> <a href="/wi-fi-setup/kak-vernut-noutbuku-acer-aspire-v5-zavodskie-nastroiki-kak-vosstanovit.html"> <img width="50" height="50" src="/uploads/30f1411909cdb68d690bd9c164d2708c.jpg" class="attachment-50 size-50 wp-post-image" alt="Как восстановить заводские настройки ноутбука Acer Acer aspire v3 571g как восстановить систему" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a> </div> <div class="papers__ovh"> <div class="papers__date">2024-04-26 03:58:13</div> <div class="papers__name"> <a href="/wi-fi-setup/kak-vernut-noutbuku-acer-aspire-v5-zavodskie-nastroiki-kak-vosstanovit.html">Как восстановить заводские настройки ноутбука Acer Acer aspire v3 571g как восстановить систему</a> </div> </div> </div> </div> </div> </div> </div> <div class="rate clearfix"> <div class="papers__title">В продолжение темы:</div> </div> <div class="rate clearfix"> <div class="rate__img"> <a href="/wi-fi-setup/prilozhenie-dlya-sozdaniya-doma-obzor-besplatnyh-programm-dlya.html"> <img width="150" height="150" src="/uploads/2053b9da01402843c3895512a12961f0.jpg" class="attachment-alm-thumbnail size-alm-thumbnail wp-post-image" alt="Обзор бесплатных программ для проектирования домов" sizes="(max-width: 150px) 100vw, 150px" / loading=lazy> </a> </div> <div class="rate__ovh"> <div class="rate__label"> <span>Настройка Wi-Fi</span> </div> <div class="rate__name"> <a href="/wi-fi-setup/prilozhenie-dlya-sozdaniya-doma-obzor-besplatnyh-programm-dlya.html">Обзор бесплатных программ для проектирования домов</a> </div> <div class="rate__description"> <p>Любой пользователь, кто хотя бы раз пытался вникнуть в хитрые тонкости создания стильных жилых интерьеров, сталкивался с такой ситуацией, когда представленные на рынке... </p> </div> </div> </div> <!-- /next_post --> </div> <div class="button-menu"></div> <div class="page__right"> <div class="menu"> <div class="menu__exit">×</div> <ul> <li><a href="/category/problem-solving/" class="link-catalog">Решение проблем</a> </li> <li><a href="/category/tips-for-beginners/" class="link-catalog">Советы начинающим</a> </li> <li><a href="/category/windows-10/" class="link-catalog">Windows 10</a> </li> <li><a href="/category/hardware-solutions/" class="link-catalog">Аппаратные решения</a> </li> <li><a href="/category/wi-fi-setup/" class="link-catalog">Настройка Wi-Fi</a> </li> <li><a href="/category/internet-tips/" class="link-catalog">Интернет-подсказки</a> </li> <li><a href="/category/configuring-windows/" class="link-catalog">Настройка Windows</a> </li> <li><a href="/category/useful-programs/" class="link-catalog">Полезные программы</a> </li> </ul> </div> <div class="page__hidden-mobile"> <div class="papers"> <div class="papers__tabs"> <div class="active" data-eq="0">Новые статьи</div> <span>/</span> <div data-eq="1">Популярные</div> </div> <div class="papers__blocks"> <div class="papers__block active"> <div class="papers__items"> <div class="papers__item"> <div class="papers__img"> <a href="/problem-solving/samyi-luchshii-monitor-vse-serezno-kak-vybrat-luchshii-igrovoi-monitor.html"> <img width="50" height="50" src="/uploads/6a1b58ac95a211be66adf5b11358b99a.jpg" class="attachment-50 size-50 wp-post-image" alt="Самый лучший монитор. Все серьезно? Как выбрать лучший игровой монитор" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a> </div> <div class="papers__ovh"> <div class="papers__date">2024-04-22 03:59:47</div> <div class="papers__name"> <a href="/problem-solving/samyi-luchshii-monitor-vse-serezno-kak-vybrat-luchshii-igrovoi-monitor.html">Самый лучший монитор. Все серьезно? Как выбрать лучший игровой монитор</a> </div> <div class="papers__category"> <a href="/category/problem-solving/">Решение проблем</a> </div> </div> </div> <div class="papers__item"> <div class="papers__img"> <a href="/problem-solving/ne-zapuskaetsya-battlestations-pacific-tormozit-igra-vyletaet-glyuchit-reshenie-samyh.html"> <img width="50" height="50" src="/uploads/cc7f6b8c586d3f28ef1857997281e946.jpg" class="attachment-50 size-50 wp-post-image" alt="Не запускается Battlestations: Pacific?" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a> </div> <div class="papers__ovh"> <div class="papers__date">2024-04-20 04:19:21</div> <div class="papers__name"> <a href="/problem-solving/ne-zapuskaetsya-battlestations-pacific-tormozit-igra-vyletaet-glyuchit-reshenie-samyh.html">Не запускается Battlestations: Pacific?</a> </div> <div class="papers__category"> <a href="/category/problem-solving/">Решение проблем</a> </div> </div> </div> <div class="papers__item"> <div class="papers__img"> <a href="/hardware-solutions/kak-ustroen-ch-rnyi-yashchik-i-pochemu-ego-trudno-rasshifrovat-kak-ustroen.html"> <img width="50" height="50" src="/uploads/3c7ede12d279eacc1d485e409db743b3.jpg" class="attachment-50 size-50 wp-post-image" alt="Как устроен “черный ящик” самолета Как расшифровать черный ящик" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a> </div> <div class="papers__ovh"> <div class="papers__date">2024-04-19 04:08:34</div> <div class="papers__name"> <a href="/hardware-solutions/kak-ustroen-ch-rnyi-yashchik-i-pochemu-ego-trudno-rasshifrovat-kak-ustroen.html">Как устроен “черный ящик” самолета Как расшифровать черный ящик</a> </div> <div class="papers__category"> <a href="/category/hardware-solutions/">Аппаратные решения</a> </div> </div> </div> <div class="papers__item"> <div class="papers__img"> <a href="/computer-security/obzor-besplatnyh-alternativnyh-tekstovyh-redaktorov-tekstovye-redaktory.html"> <img width="50" height="50" src="/uploads/11df09f8cea8313f46077930adb0dfdd.jpg" class="attachment-50 size-50 wp-post-image" alt="Обзор бесплатных альтернативных текстовых редакторов" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a> </div> <div class="papers__ovh"> <div class="papers__date">2024-04-17 03:59:06</div> <div class="papers__name"> <a href="/computer-security/obzor-besplatnyh-alternativnyh-tekstovyh-redaktorov-tekstovye-redaktory.html">Обзор бесплатных альтернативных текстовых редакторов</a> </div> <div class="papers__category"> <a href="/category/computer-security/">Безопасность компьютера</a> </div> </div> </div> <div class="papers__item"> <div class="papers__img"> <a href="/tips-for-beginners/pochemu-kompyuter-ne-vidit-telefon-cherez-usb-no-zaryazhaetsya.html"> <img width="50" height="50" src="/uploads/7cb328d0e8e6f14b1299277e55bf2b81.jpg" class="attachment-50 size-50 wp-post-image" alt="Компьютер не видит телефон — Решения проблемы На компьютере не отображается телефон" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a> </div> <div class="papers__ovh"> <div class="papers__date">2024-04-15 04:06:10</div> <div class="papers__name"> <a href="/tips-for-beginners/pochemu-kompyuter-ne-vidit-telefon-cherez-usb-no-zaryazhaetsya.html">Компьютер не видит телефон — Решения проблемы На компьютере не отображается телефон</a> </div> <div class="papers__category"> <a href="/category/tips-for-beginners/">Советы начинающим</a> </div> </div> </div> <div class="papers__item"> <div class="papers__img"> <a href="/hardware-solutions/chto-delat-esli-propali-ikonki-lokalnyh-diskov-chto-delat-esli-na.html"> <img width="50" height="50" src="/uploads/120ccf12f49f2ef1fd807b5df3cc3b7f.jpg" class="attachment-50 size-50 wp-post-image" alt="Что делать если на компе нету диска D?" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a> </div> <div class="papers__ovh"> <div class="papers__date">2024-04-14 04:11:30</div> <div class="papers__name"> <a href="/hardware-solutions/chto-delat-esli-propali-ikonki-lokalnyh-diskov-chto-delat-esli-na.html">Что делать если на компе нету диска D?</a> </div> <div class="papers__category"> <a href="/category/hardware-solutions/">Аппаратные решения</a> </div> </div> </div> </div> </div> <div class="papers__block"> <div class="papers__items"> <div class="papers__item"> <div class="papers__img"><a href="/wi-fi-setup/antivirus-kotoryi-udalyaet-reklamu-kak-ubrat-reklamu-v.html"> <img width="50" height="50" src="/uploads/8adbb0e889677639b1c247274b8244da.jpg" class="attachment-50x50 size-50x50 wp-post-image" alt="Как убрать рекламу в браузере: удалить баннеры и всплывающие окна" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a></div> <div class="papers__ovh"> <div class="papers__name"> <a href="/wi-fi-setup/antivirus-kotoryi-udalyaet-reklamu-kak-ubrat-reklamu-v.html">Как убрать рекламу в браузере: удалить баннеры и всплывающие окна</a> </div> <div class="papers__category"><a href="/category/wi-fi-setup/" rel="tag">Настройка Wi-Fi</a></div> </div> </div> <div class="papers__item"> <div class="papers__img"><a href="/configuring-windows/kogda-budet-apgreid-yandeksa-apdeity-yandeksa-chto-eto-vidy-kogda.html"> <img width="50" height="50" src="/uploads/2094cb11f53c311e3ba8e8cd38e3d2c1.jpg" class="attachment-50x50 size-50x50 wp-post-image" alt="Апдейты Яндекса — что это?" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a></div> <div class="papers__ovh"> <div class="papers__name"> <a href="/configuring-windows/kogda-budet-apgreid-yandeksa-apdeity-yandeksa-chto-eto-vidy-kogda.html">Апдейты Яндекса — что это?</a> </div> <div class="papers__category"><a href="/category/configuring-windows/" rel="tag">Настройка Windows</a></div> </div> </div> <div class="papers__item"> <div class="papers__img"><a href="/computer-security/kto-takoi-full-stack-razrabotchik-perevod-full-stack-razrabotchik-eto-mif-perevod-full.html"> <img width="50" height="50" src="/uploads/5232c5a5321cdd75a5c10e759df82c98.jpg" class="attachment-50x50 size-50x50 wp-post-image" alt="Перевод: full stack разработчик — это миф Перевод: full stack разработчик - это миф" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a></div> <div class="papers__ovh"> <div class="papers__name"> <a href="/computer-security/kto-takoi-full-stack-razrabotchik-perevod-full-stack-razrabotchik-eto-mif-perevod-full.html">Перевод: full stack разработчик — это миф Перевод: full stack разработчик - это миф</a> </div> <div class="papers__category"><a href="/category/computer-security/" rel="tag">Безопасность компьютера</a></div> </div> </div> <div class="papers__item"> <div class="papers__img"><a href="/computer-literacy/samyi-emkii-pover-bank-kakoi-power-bank-samyi-luchshii-vybiraem-vneshnii.html"> <img width="50" height="50" src="/uploads/49f3c97fe6343c44412a8cc50ce59a06.jpg" class="attachment-50x50 size-50x50 wp-post-image" alt="Какой Power Bank самый лучший?" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a></div> <div class="papers__ovh"> <div class="papers__name"> <a href="/computer-literacy/samyi-emkii-pover-bank-kakoi-power-bank-samyi-luchshii-vybiraem-vneshnii.html">Какой Power Bank самый лучший?</a> </div> <div class="papers__category"><a href="/category/computer-literacy/" rel="tag">Компьютерная грамотность</a></div> </div> </div> <div class="papers__item"> <div class="papers__img"><a href="/internet-tips/rasshirenie-faila-m2v-chem-otkryt-fail-m2v.html"> <img width="50" height="50" src="/uploads/5e1fd28c3705c9ce91555c69eecf18de.jpg" class="attachment-50x50 size-50x50 wp-post-image" alt="Расширение файла M2V. Чем открыть файл.M2V" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a></div> <div class="papers__ovh"> <div class="papers__name"> <a href="/internet-tips/rasshirenie-faila-m2v-chem-otkryt-fail-m2v.html">Расширение файла M2V. Чем открыть файл.M2V</a> </div> <div class="papers__category"><a href="/category/internet-tips/" rel="tag">Интернет-подсказки</a></div> </div> </div> <div class="papers__item"> <div class="papers__img"><a href="/hardware-solutions/chasy-na-ekran-kompyutera-cifrovye-chasy-na-rabochii-stol-kompyutera.html"> <img width="50" height="50" src="/uploads/bbe8c6015cbff268b5f18e0316121926.jpg" class="attachment-50x50 size-50x50 wp-post-image" alt="Цифровые часы на рабочий стол компьютера" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a></div> <div class="papers__ovh"> <div class="papers__name"> <a href="/hardware-solutions/chasy-na-ekran-kompyutera-cifrovye-chasy-na-rabochii-stol-kompyutera.html">Цифровые часы на рабочий стол компьютера</a> </div> <div class="papers__category"><a href="/category/hardware-solutions/" rel="tag">Аппаратные решения</a></div> </div> </div> </div> </div> </div> </div> <div class="comments"> </div> </div> </div> </div> </div> </div> <div class="footer"> <div class="footer__top"> <div class="cnt"> <div class="footer__nav"> <ul> <li><a href="/feedback.html">Контакты</a></li> <li><a href="">Реклама</a></li> <li><a href="">О сайте</a></li> </ul> </div> <div class="footer__counter"> </div> <div class="footer__logo1" align="right"> <img style="max-height:60px;" src="/uploads/logo.svg" alt="" loading=lazy> </div> </div> </div> <div class="footer__bottom"> <div class="cnt"> <div class="footer__copyright"> © bostan-opt.ru 2024 г. Компьютерный журнал для новичков и профессионалов </div> </div> </div> </div> <a href="#top" class="up"></a> </div> <script src="https://bostan-opt.ru/wp-content/themes/tehnika-expert/js/jquery-1.12.0.js"></script> <script src="https://bostan-opt.ru/wp-content/themes/tehnika-expert/js/owl.carousel.min.js"></script> <script src="https://bostan-opt.ru/wp-content/themes/tehnika-expert/js/mousewheel.js"></script> <script src="https://bostan-opt.ru/wp-content/themes/tehnika-expert/js/jscrollpane.min.js"></script> <script src="https://bostan-opt.ru/wp-content/themes/tehnika-expert/js/scripts.js?v=8"></script> <!--[if lt IE 10]> <script src="https://bostan-opt.ru/wp-content/themes/tehnika-expert/js/placeholder.js"></script> <![endif]--> <script type='text/javascript' src='https://bostan-opt.ru/wp-content/plugins/table-of-contents-plus/front.min.js?ver=1509'></script> <script type='text/javascript' src='https://bostan-opt.ru/wp-content/plugins/wp-ajaxify-comments/js/wp-ajaxify-comments.min.js?ver=1.5.0'></script> <script type='text/javascript' src='https://bostan-opt.ru/wp-content/plugins/wp-polls/polls-js.js?ver=2.73.8'></script> <script type='text/javascript' src='https://bostan-opt.ru/wp-content/plugins/wp-postratings/js/postratings-js.js?ver=1.85'></script> <script type='text/javascript' src='https://bostan-opt.ru/wp-content/plugins/wp_testme/js/testme.js?ver=1.1'></script> <script type='text/javascript' src='/wp-includes/js/comment-reply.min.js?ver=4.9'></script> <script type='text/javascript'> var q2w3_sidebar_options = new Array(); q2w3_sidebar_options[0] = { "sidebar" : "sidebar-2", "margin_top" : 10, "margin_bottom" : 112, "stop_id" : "", "screen_max_width" : 0, "screen_max_height" : 0, "width_inherit" : false, "refresh_interval" : 1500, "window_load_hook" : false, "disable_mo_api" : false, "widgets" : ['cb_widget-2'] } ; </script> <script type='text/javascript' src='https://bostan-opt.ru/wp-content/plugins/q2w3-fixed-widget/js/q2w3-fixed-widget.min.js?ver=5.0.4'></script> <script type='text/javascript' src='/wp-includes/js/wp-embed.min.js?ver=4.9'></script> </body> </html>