<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>http://sfsys.ru/index.php?action=history&amp;feed=atom&amp;title=IPConnection.InitEncryption</id>
	<title>IPConnection.InitEncryption - Revision history</title>
	<link rel="self" type="application/atom+xml" href="http://sfsys.ru/index.php?action=history&amp;feed=atom&amp;title=IPConnection.InitEncryption"/>
	<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=IPConnection.InitEncryption&amp;action=history"/>
	<updated>2026-04-04T10:10:03Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.31.1</generator>
	<entry>
		<id>http://sfsys.ru/index.php?title=IPConnection.InitEncryption&amp;diff=4248&amp;oldid=prev</id>
		<title>Admin: 1 revision imported</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=IPConnection.InitEncryption&amp;diff=4248&amp;oldid=prev"/>
		<updated>2022-03-13T10:09:28Z</updated>

		<summary type="html">&lt;p&gt;1 revision imported&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;Revision as of 10:09, 13 March 2022&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-notice&quot; lang=&quot;en&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(No difference)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Admin</name></author>
		
	</entry>
	<entry>
		<id>http://sfsys.ru/index.php?title=IPConnection.InitEncryption&amp;diff=4247&amp;oldid=prev</id>
		<title>1&gt;Admin at 06:22, 1 January 2022</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=IPConnection.InitEncryption&amp;diff=4247&amp;oldid=prev"/>
		<updated>2022-01-01T06:22:41Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;Revision as of 06:22, 1 January 2022&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l24&quot; &gt;Line 24:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 24:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;** '''AES''' -- для шифрования используется алгоритм AES-256, никаких дополнительных данных не отсылается для установки протокола, клиент и сервер должны иметь одинаковый ключ шифрования при инициализации шифрования. Функцию ''InitEncryption'' можно вызывать как для сервера, так и для клиента. Второй параметр функции задает расписание шифрования AES-256, и должен являться ANSI строкой с размером 240 байт созданной с помощью функции [[CreateKeySchedule]] с первым параметром, равным нулю.&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;** '''AES''' -- для шифрования используется алгоритм AES-256, никаких дополнительных данных не отсылается для установки протокола, клиент и сервер должны иметь одинаковый ключ шифрования при инициализации шифрования. Функцию ''InitEncryption'' можно вызывать как для сервера, так и для клиента. Второй параметр функции задает расписание шифрования AES-256, и должен являться ANSI строкой с размером 240 байт созданной с помощью функции [[CreateKeySchedule]] с первым параметром, равным нулю.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;** '''OpenSSL''' -- для шифрования инициализируются алгоритмы SSL/TLS, используемые при https соединениях с помощью бесплатных библиотек OpenSSL. Для серверной стороны необходимо пользоваться функцией [[IPConnection.InitServerEncryption|InitServerEncryption]] вместо текущей. Второй, третий и четвертый параметры заданы следующим образом:&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;** '''OpenSSL''' -- для шифрования инициализируются алгоритмы SSL/TLS, используемые при https соединениях с помощью бесплатных библиотек OpenSSL. Для серверной стороны необходимо пользоваться функцией [[IPConnection.InitServerEncryption|InitServerEncryption]] вместо текущей. Второй, третий и четвертый параметры заданы следующим образом:&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;−&lt;/td&gt;&lt;td style=&quot;color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*** &amp;lt;code&amp;gt;''&amp;lt;Путь и имя библиотеки шифрования (STRING)&amp;gt;''&amp;lt;/code&amp;gt; - задается путь и наименование библиотеки &amp;lt;code&amp;gt;libssl*.dll&amp;lt;/code&amp;gt;, по этому же пути должна находиться библиотека &amp;lt;code&amp;gt;libcrypto*.dll&amp;lt;/code&amp;gt;. Для 64-битных версий клиента, должны быть использованы 64-битные версии библиотеки (см. [[ProgramArchitecture]]). Работа библиотек была протестирована на версии 1.1.1, рекомендуется использование &lt;del class=&quot;diffchange diffchange-inline&quot;&gt;указанной &lt;/del&gt;или более поздних версий.&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;+&lt;/td&gt;&lt;td style=&quot;color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*** &amp;lt;code&amp;gt;''&amp;lt;Путь и имя библиотеки шифрования (STRING)&amp;gt;''&amp;lt;/code&amp;gt; - задается путь и наименование библиотеки &amp;lt;code&amp;gt;libssl*.dll&amp;lt;/code&amp;gt;, по этому же пути должна находиться библиотека &amp;lt;code&amp;gt;libcrypto*.dll&amp;lt;/code&amp;gt;. Для 64-битных версий клиента, должны быть использованы 64-битные версии библиотеки (см. [[ProgramArchitecture]]). Работа библиотек была протестирована на версии 1.1.1 &lt;ins class=&quot;diffchange diffchange-inline&quot;&gt;и на версии 3.0&lt;/ins&gt;, рекомендуется использование &lt;ins class=&quot;diffchange diffchange-inline&quot;&gt;указанных &lt;/ins&gt;или более поздних версий.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*** &amp;lt;code&amp;gt;''&amp;lt;Сертификаты и ключи (STRING)&amp;gt;''&amp;lt;/code&amp;gt; - {{Planned }} задается путь и имя личного сертификата, если он необходим при соединении. Сертификат должен иметь формат ''PEM''.&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*** &amp;lt;code&amp;gt;''&amp;lt;Сертификаты и ключи (STRING)&amp;gt;''&amp;lt;/code&amp;gt; - {{Planned }} задается путь и имя личного сертификата, если он необходим при соединении. Сертификат должен иметь формат ''PEM''.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*** &amp;lt;code&amp;gt;''&amp;lt;Наименование метода клиента (STRING)&amp;gt;''&amp;lt;/code&amp;gt; - Аргумент может задавать имя определенного метода соединения. По умолчанию, используется метод OpenSSL ''TLS_client_method'', однако, к примеру, можно форсировать использование ''TLSv1_1_client_method'' или ''TLSv1_client_method''.&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*** &amp;lt;code&amp;gt;''&amp;lt;Наименование метода клиента (STRING)&amp;gt;''&amp;lt;/code&amp;gt; - Аргумент может задавать имя определенного метода соединения. По умолчанию, используется метод OpenSSL ''TLS_client_method'', однако, к примеру, можно форсировать использование ''TLSv1_1_client_method'' или ''TLSv1_client_method''.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>1&gt;Admin</name></author>
		
	</entry>
	<entry>
		<id>http://sfsys.ru/index.php?title=IPConnection.InitEncryption&amp;diff=1264&amp;oldid=prev</id>
		<title>Admin: 1 revision imported</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=IPConnection.InitEncryption&amp;diff=1264&amp;oldid=prev"/>
		<updated>2021-02-07T06:51:25Z</updated>

		<summary type="html">&lt;p&gt;1 revision imported&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;Revision as of 06:51, 7 February 2021&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-notice&quot; lang=&quot;en&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(No difference)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Admin</name></author>
		
	</entry>
	<entry>
		<id>http://sfsys.ru/index.php?title=IPConnection.InitEncryption&amp;diff=1263&amp;oldid=prev</id>
		<title>Admin at 10:29, 28 January 2021</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=IPConnection.InitEncryption&amp;diff=1263&amp;oldid=prev"/>
		<updated>2021-01-28T10:29:08Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;{{infobox function&lt;br /&gt;
|name=InitEncryption&lt;br /&gt;
|object=[[Объект IP]]&lt;br /&gt;
|caption=Шифрование соединения&lt;br /&gt;
|type=1&lt;br /&gt;
|status=2&lt;br /&gt;
|db=0&lt;br /&gt;
|exception=Невозможно превратить в строку, внешняя ошибка&lt;br /&gt;
|visual=0}}&lt;br /&gt;
{{HeadLinks|&lt;br /&gt;
* [[Main_Page|Начальная страница]]&lt;br /&gt;
* [[Общее_описание_языка|Общее описание]]&lt;br /&gt;
* [[Объекты]]&lt;br /&gt;
* [[Объект IP]]}}&lt;br /&gt;
Функция инициализирует шифрование клиентской стороны на существующем IP соединении (чаще всего TCP/IP). Связь должна быть уже установлена, шифрование может быть инициализировано уже после отсылки предварительной информации. На соединение с включенной функцией шифрования, накладываются некоторые ограничения на использование функций, к примеру, не получится использовать функции [[IPConnection.Receive|Receive]] или [[IPConnection.Peek|Peek]]. Блокирующие сокеты рекомендуются для использования совместно с шифрованным соединением, так как не все типы шифрования могут поддерживать иное. Чаще всего эта функция используется для включения шифрования на клиенте при обмене, на серверной стороне необходимо использовать функцию [[IPConnection.InitServerEncryption|InitServerEncryption]].&lt;br /&gt;
&lt;br /&gt;
== Синтаксис ==&lt;br /&gt;
&amp;lt;code&amp;gt;&lt;br /&gt;
{{Grey|IPConnection.}}'''InitEncryption'''(''&amp;lt;Тип шифрования (STRING)&amp;gt;'',''&amp;lt;Путь и имя библиотеки шифрования (STRING)&amp;gt;''{{Optional|,&amp;lt;Сертификаты и ключи (STRING)&amp;gt;,&amp;lt;Наименование метода клиента (STRING)&amp;gt;}})&lt;br /&gt;
&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==== Аргументы ====&lt;br /&gt;
* &amp;lt;code&amp;gt;''&amp;lt;Тип шифрования (STRING)&amp;gt;''&amp;lt;/code&amp;gt; - Тип используемого шифрования. Последующие параметры будут зависеть от типа шифрования. На данный момент доступны следующие типы:&lt;br /&gt;
** '''AES''' -- для шифрования используется алгоритм AES-256, никаких дополнительных данных не отсылается для установки протокола, клиент и сервер должны иметь одинаковый ключ шифрования при инициализации шифрования. Функцию ''InitEncryption'' можно вызывать как для сервера, так и для клиента. Второй параметр функции задает расписание шифрования AES-256, и должен являться ANSI строкой с размером 240 байт созданной с помощью функции [[CreateKeySchedule]] с первым параметром, равным нулю.&lt;br /&gt;
** '''OpenSSL''' -- для шифрования инициализируются алгоритмы SSL/TLS, используемые при https соединениях с помощью бесплатных библиотек OpenSSL. Для серверной стороны необходимо пользоваться функцией [[IPConnection.InitServerEncryption|InitServerEncryption]] вместо текущей. Второй, третий и четвертый параметры заданы следующим образом:&lt;br /&gt;
*** &amp;lt;code&amp;gt;''&amp;lt;Путь и имя библиотеки шифрования (STRING)&amp;gt;''&amp;lt;/code&amp;gt; - задается путь и наименование библиотеки &amp;lt;code&amp;gt;libssl*.dll&amp;lt;/code&amp;gt;, по этому же пути должна находиться библиотека &amp;lt;code&amp;gt;libcrypto*.dll&amp;lt;/code&amp;gt;. Для 64-битных версий клиента, должны быть использованы 64-битные версии библиотеки (см. [[ProgramArchitecture]]). Работа библиотек была протестирована на версии 1.1.1, рекомендуется использование указанной или более поздних версий.&lt;br /&gt;
*** &amp;lt;code&amp;gt;''&amp;lt;Сертификаты и ключи (STRING)&amp;gt;''&amp;lt;/code&amp;gt; - {{Planned }} задается путь и имя личного сертификата, если он необходим при соединении. Сертификат должен иметь формат ''PEM''.&lt;br /&gt;
*** &amp;lt;code&amp;gt;''&amp;lt;Наименование метода клиента (STRING)&amp;gt;''&amp;lt;/code&amp;gt; - Аргумент может задавать имя определенного метода соединения. По умолчанию, используется метод OpenSSL ''TLS_client_method'', однако, к примеру, можно форсировать использование ''TLSv1_1_client_method'' или ''TLSv1_client_method''.&lt;br /&gt;
** '''LibreSSL''' -- для шифрования инициализируются алгоритмы SSL/TLS, используемые при https соединениях с помощью бесплатных библиотек LibreSSL. Использование LibreSSL вместо OpenSSL позволяет загрузить информацию с сайтов, с которыми OpenSSL работает неверно. Для серверной стороны необходимо пользоваться функцией [[IPConnection.InitServerEncryption|InitServerEncryption]] вместо текущей. Второй, третий и четвертый параметры заданы следующим образом:&lt;br /&gt;
*** &amp;lt;code&amp;gt;''&amp;lt;Путь и имя библиотеки шифрования (STRING)&amp;gt;''&amp;lt;/code&amp;gt; - задается путь и наименование библиотеки &amp;lt;code&amp;gt;libtls-*.dll&amp;lt;/code&amp;gt;, по этому же пути должны находиться библиотеки &amp;lt;code&amp;gt;libssl-*.dll&amp;lt;/code&amp;gt; и &amp;lt;code&amp;gt;libcrypto-*.dll&amp;lt;/code&amp;gt;. Для 64-битных версий клиента, должны быть использованы 64-битные версии библиотеки (см. [[ProgramArchitecture]]). Работа библиотек была протестирована на версии 2.5.5, рекомендуется использование указанной или более поздних версий.&lt;br /&gt;
*** &amp;lt;code&amp;gt;''&amp;lt;Сертификаты и ключи (STRING)&amp;gt;''&amp;lt;/code&amp;gt; - {{Planned }} задается путь и имя личного сертификата, если он необходим при соединении. Сертификат должен иметь формат ''PEM''.&lt;br /&gt;
*** &amp;lt;code&amp;gt;''&amp;lt;Наименование метода клиента (STRING)&amp;gt;''&amp;lt;/code&amp;gt; - Аргумент не используется.&lt;br /&gt;
&lt;br /&gt;
== Примеры ==&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
//Пример показывает, как можно осуществить загрузку веб-страницы по ее адресу.&lt;br /&gt;
//Для загрузки по протоколу https требуется указание пути к библиотекам OpenSSL или LibreSSL.&lt;br /&gt;
&lt;br /&gt;
  Function LoadPage(URL)&lt;br /&gt;
    bHTTPs:=pos(&amp;quot;https://&amp;quot;,Lowercase(URL));&lt;br /&gt;
    If pos(&amp;quot;//&amp;quot;,URL)&amp;gt;0 Then&lt;br /&gt;
      tearStr(URL,&amp;quot;//&amp;quot;);&lt;br /&gt;
    EndIf;&lt;br /&gt;
    СтрДоб:=URL;    &lt;br /&gt;
    URL:=tearStr(СтрДоб,&amp;quot;/&amp;quot;);&lt;br /&gt;
    //URL может содержать название параграфа&lt;br /&gt;
    СтрДоб:=TearStr(СтрДоб,&amp;quot;#&amp;quot;);&lt;br /&gt;
    For i:=1 to 3 Do&lt;br /&gt;
      if bHTTPs Then&lt;br /&gt;
        tcp:=IPConnection.Connect(URL+?(Pos(&amp;quot;:&amp;quot;,URL)+Pos(&amp;quot;=&amp;quot;,URL)=0,&amp;quot;=443&amp;quot;),1);&lt;br /&gt;
      Else&lt;br /&gt;
        tcp:=IPConnection.Connect(URL+?(Pos(&amp;quot;:&amp;quot;,URL)+Pos(&amp;quot;=&amp;quot;,URL)=0,&amp;quot;=80&amp;quot;));&lt;br /&gt;
      EndIf;  &lt;br /&gt;
      if tcp.IsConnected Then&lt;br /&gt;
        Break;&lt;br /&gt;
      EndIf;&lt;br /&gt;
    EndDo;&lt;br /&gt;
    if not tcp.IsConnected Then&lt;br /&gt;
      Message(&amp;quot;Could not connect: &amp;quot;+URL,&amp;quot;!&amp;quot;);&lt;br /&gt;
      Exit;&lt;br /&gt;
    EndIf;&lt;br /&gt;
    СтрДоб:=&amp;quot;/&amp;quot;+СтрДоб;&lt;br /&gt;
    if bHTTPs then&lt;br /&gt;
      //tcp.InitEncryption(&amp;quot;LibreSSL&amp;quot;,&amp;quot;C:\LibreSSL255\libtls-15.dll&amp;quot;);&lt;br /&gt;
      tcp.InitEncryption(&amp;quot;OpenSSL&amp;quot;,&amp;quot;C:\OpenSSL111e\libssl-1_1.dll&amp;quot;);&lt;br /&gt;
    endif;  &lt;br /&gt;
    tcp.HTTPSetOperation(&amp;quot;GET &amp;quot;+СтрДоб+&amp;quot; HTTP/1.0&amp;quot;);&lt;br /&gt;
    tcp.HTTPSetHeaderField(&amp;quot;Host&amp;quot;,tcp.HTTPPunycodeEncode(URL));&lt;br /&gt;
    tcp.HTTPSetHeaderField(&amp;quot;User-Agent&amp;quot;,&amp;quot;Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)&amp;quot;);&lt;br /&gt;
    tcp.HTTPSetHeaderField(&amp;quot;Accept&amp;quot;,&amp;quot;text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8&amp;quot;);&lt;br /&gt;
    tcp.HTTPSetHeaderField(&amp;quot;Accept-Language&amp;quot;,&amp;quot;en&amp;quot;);&lt;br /&gt;
    tcp.HTTPSetHeaderField(&amp;quot;Connection&amp;quot;,&amp;quot;Close&amp;quot;);&lt;br /&gt;
    Стр:=&amp;quot;&amp;quot;;&lt;br /&gt;
    Try&lt;br /&gt;
      If tcp.HTTPSendAndReceive Then&lt;br /&gt;
        Стр:=tcp.HTTPBodyAsString;&lt;br /&gt;
        If _And(Pos(_NEWLINE,Стр)=0,Pos(Chr(10),Стр)&amp;gt;0) Then&lt;br /&gt;
          Стр:=Replace(Стр,Chr(10),_NEWLINE);&lt;br /&gt;
        EndIf;&lt;br /&gt;
      EndIf;&lt;br /&gt;
    Except&lt;br /&gt;
      Message(&amp;quot;Could not load: &amp;quot;+URL,&amp;quot;!&amp;quot;);&lt;br /&gt;
    EndTry;  &lt;br /&gt;
    Exit Стр;&lt;br /&gt;
  EndFunction&lt;br /&gt;
&lt;br /&gt;
s:=LoadPage(&amp;quot;https://en.wikipedia.org/wiki/Main_Page&amp;quot;);&lt;br /&gt;
Message(s);&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>
		
	</entry>
</feed>