<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>goodguy о разработке &#187; php</title>
	<atom:link href="http://dev.good-guy.me/archives/tag/php/feed" rel="self" type="application/rss+xml" />
	<link>http://dev.good-guy.me</link>
	<description>python, zope, php, sqlite, postgresql, mysql и прочее с чем сталкиваюсь</description>
	<lastBuildDate>Sun, 04 Dec 2011 17:17:34 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.3.1</generator>
		<item>
		<title>Сборка debian пакета для дополнения к PHP из PECL</title>
		<link>http://dev.good-guy.me/archives/489</link>
		<comments>http://dev.good-guy.me/archives/489#comments</comments>
		<pubDate>Mon, 12 Sep 2011 11:32:49 +0000</pubDate>
		<dc:creator>goodguy</dc:creator>
				<category><![CDATA[Open Source]]></category>
		<category><![CDATA[Языки]]></category>
		<category><![CDATA[debian]]></category>
		<category><![CDATA[php]]></category>

		<guid isPermaLink="false">http://dev.good-guy.me/?p=489</guid>
		<description><![CDATA[<a href="http://dev.good-guy.me/archives/489" title="Сборка debian пакета для дополнения к PHP из PECL"></a>Я довольно часто использую удобный класс HTTPRequest из дополнения pecl_http, который описан в официальной документации по PHP. Но в очередной раз устанавливая его из PECL поразился тому сколько шагов нужно сделать для его сборки на чистой системе, после чего решил &#8230;<p class="read-more"><a href="http://dev.good-guy.me/archives/489">Читать далее &#187;</a></p>]]></description>
			<content:encoded><![CDATA[<a href="http://dev.good-guy.me/archives/489" title="Сборка debian пакета для дополнения к PHP из PECL"></a><p>Я довольно часто использую удобный класс <tt>HTTPRequest</tt> из дополнения <a href="http://pecl.php.net/package/pecl_http">pecl_http</a>, который описан в <a href="http://php.net/HTTPRequest">официальной документации</a> по PHP. Но в очередной раз устанавливая его из PECL поразился тому сколько шагов нужно сделать для его сборки на чистой системе, после чего решил подсобить админам, собрав для него стандартный debian-пакет.</p>
<p><span id="more-489"></span></p>
<p>Сначала нужно было определиться с зависимостями: ими стали пакеты <tt>php5-dev</tt> (включающий в себя команду <tt>phpize</tt> без которой расширение не ставилось) и <tt>libcurl4-openssl-dev</tt>, для поддержки SSL соединений и вообще работу через библиотеку CURL.</p>
<p>После этого магия совсем простая. Нужно установить уже готовый скрипт для подготовки архивов из PECL к сборке в debian:</p>
<p><code><br />
apt-get install php5-dev dh-make-php fakeroot xsltproc<br />
</code></p>
<p>Теперь с помощью этого скрипта подготовим пакет pecl_http:</p>
<p><code><br />
dh-make-pecl --depends curl --build-depends libcurl4-openssl-dev --package-name http pecl_http<br />
</code></p>
<p>Будет создан каталог php-http-x.x.x (соответствующий текущей версии расширения). В нём уже будут необходимые файлы в каталоге debian. Опция <tt>package-name</tt> сообщает скрипту, что по-настоящему пакет называется <tt>http</tt> и собранная библиотека соответственно будет <tt>http.so</tt>, и именно такое название надо использовать для включения расширения в /etc/php5/conf.d.</p>
<p>После этого выполняем прямо в каталоге с расширением команду:</p>
<p><code><br />
dpkg-buildpackage -rfakeroot<br />
</code></p>
<p>И получаем во внешнем каталоге весь набор, включая debian пакет, который уже можно спокойно ставить со всеми зависимостями.</p>
]]></content:encoded>
			<wfw:commentRss>http://dev.good-guy.me/archives/489/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Отлов ошибок PECL класса HTTPRequest</title>
		<link>http://dev.good-guy.me/archives/377</link>
		<comments>http://dev.good-guy.me/archives/377#comments</comments>
		<pubDate>Wed, 30 Sep 2009 06:35:34 +0000</pubDate>
		<dc:creator>goodguy</dc:creator>
				<category><![CDATA[Языки]]></category>
		<category><![CDATA[php]]></category>

		<guid isPermaLink="false">http://dev.goodguy.spb.ru/?p=377</guid>
		<description><![CDATA[<a href="http://dev.good-guy.me/archives/377" title="Отлов ошибок PECL класса &lt;tt&gt;HTTPRequest&lt;/tt&gt;"></a>В модуле pecl_http есть очень удобный, но при этом не всегда хорошо задокументированный класс HTTPRequest. Одной из проблем, с которой я столкнулся при работе с ним, это то, что в случае ошибок при HTTP-соединениях, выбрасывались исключения с текстами: (HttpInvalidParamException) Empty &#8230;<p class="read-more"><a href="http://dev.good-guy.me/archives/377">Читать далее &#187;</a></p>]]></description>
			<content:encoded><![CDATA[<a href="http://dev.good-guy.me/archives/377" title="Отлов ошибок PECL класса &lt;tt&gt;HTTPRequest&lt;/tt&gt;"></a><p style="text-align: justify">В модуле <tt>pecl_http</tt> есть очень удобный, но при этом не всегда хорошо задокументированный класс <tt>HTTPRequest</tt>. Одной из проблем, с которой я столкнулся при работе с ним, это то, что в случае ошибок при HTTP-соединениях, выбрасывались исключения с текстами:</p>
<p><code><br />
(HttpInvalidParamException) Empty or too short HTTP message: ''<br />
</code></p>
<p style="text-align: justify">Понятное дело, для отладки они не подходят. Но, если вывести исключение полностью, то обычно там как-раз и были подробности проблемы:</p>
<p><code><br />
exception 'HttpInvalidParamException' with message 'Empty or too short HTTP message: ''' in example.php:189 inner exception 'HttpRequestException' with message 'Timeout was reached; Operation timed out after 10000 milliseconds with 0 bytes received (https://example.ru/)' in example.php:160<br />
</code></p>
<p style="text-align: justify">Видно, что самое важное содержится в сообщении от inner exception. И его, оказывается, легко поймать, если поставить дополнительный блок <tt>catch</tt> на <tt>HTTPException</tt>, например:</p>
<pre name="code" class="php">
try {
    $request->send();
} catch (HttpException $ex) {
    if (isset($ex->innerException)){
        echo $ex->innerException->getMessage();
        exit;
    } else {
        echo $ex;
        exit;
    }
}
</pre>
<p style="text-align: justify">Информация получена <a href="http://www.markfosteronline.com/2009/01/06/how-to-pecl-http-request-exception-and-error-handling/">отсюда</a>.</p>
]]></content:encoded>
			<wfw:commentRss>http://dev.good-guy.me/archives/377/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Unknown SSL protocol error</title>
		<link>http://dev.good-guy.me/archives/371</link>
		<comments>http://dev.good-guy.me/archives/371#comments</comments>
		<pubDate>Fri, 28 Aug 2009 13:22:48 +0000</pubDate>
		<dc:creator>goodguy</dc:creator>
				<category><![CDATA[ПО]]></category>
		<category><![CDATA[Разное]]></category>
		<category><![CDATA[php]]></category>

		<guid isPermaLink="false">http://dev.goodguy.spb.ru/?p=371</guid>
		<description><![CDATA[<a href="http://dev.good-guy.me/archives/371" title="Unknown SSL protocol error"></a>При запросе из PHP с помощью HTTPRequest к интерфейсу одной серьёзной биллинговой системы получал постоянно ошибку «Unknown SSL protocol error in connection to xxx.xxx.xxx.xxx:443». Быстрый взгляд в гугл подсказал только перебирать параметры, что оказалось вполне верной догадкой: оказывается хост нормальное &#8230;<p class="read-more"><a href="http://dev.good-guy.me/archives/371">Читать далее &#187;</a></p>]]></description>
			<content:encoded><![CDATA[<a href="http://dev.good-guy.me/archives/371" title="Unknown SSL protocol error"></a><p style="text-align: justify">При запросе из PHP с помощью <tt><a href="http://ru.php.net/manual/en/class.httprequest.php">HTTPRequest</a></tt> к интерфейсу одной серьёзной биллинговой системы получал постоянно ошибку «<tt>Unknown SSL protocol error in connection to xxx.xxx.xxx.xxx:443</tt>». Быстрый взгляд в гугл подсказал только перебирать параметры, что оказалось вполне верной догадкой: оказывается хост нормальное работал с SSLv2, который не использовался при соединении. Пришлось указать принудительно строкой:</p>
<pre name="code" class="php">
$req-&gt;setOptions(array('ssl' =&gt; array('version' =&gt; SSL_VERSION_SSLv2)));
</pre>
<p style="text-align: justify">Потом правда всплыли и другие прелести, вроде отдачи XML в UTF-8 с типом «<tt>text/html; charset=ISO-8859-1</tt>», но такие шутки находятся быстрее и решаются проще.</p>
]]></content:encoded>
			<wfw:commentRss>http://dev.good-guy.me/archives/371/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>PHP и SOAP Message Security</title>
		<link>http://dev.good-guy.me/archives/356</link>
		<comments>http://dev.good-guy.me/archives/356#comments</comments>
		<pubDate>Wed, 29 Apr 2009 15:44:29 +0000</pubDate>
		<dc:creator>goodguy</dc:creator>
				<category><![CDATA[Языки]]></category>
		<category><![CDATA[php]]></category>
		<category><![CDATA[SOAP]]></category>
		<category><![CDATA[безопасность]]></category>

		<guid isPermaLink="false">http://dev.goodguy.spb.ru/?p=356</guid>
		<description><![CDATA[<a href="http://dev.good-guy.me/archives/356" title="PHP и SOAP Message Security"></a>Очередной случай из жизни натолкнул меня на мысль расписать, как из PHP создать подписанный по стандарту SOAP Message Security SOAP-запрос по SSL-соединению. Насколько я понимаю, стандарт этот не единственный, но используется достаточно широко и базируется на различных XML-стандартах W3C. Сама &#8230;<p class="read-more"><a href="http://dev.good-guy.me/archives/356">Читать далее &#187;</a></p>]]></description>
			<content:encoded><![CDATA[<a href="http://dev.good-guy.me/archives/356" title="PHP и SOAP Message Security"></a><p style="text-align: justify">Очередной случай из жизни натолкнул меня на мысль расписать, как из PHP создать подписанный по стандарту <a href="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-soap-message-security-1.0.pdf">SOAP Message Security</a> SOAP-запрос по SSL-соединению. Насколько я понимаю, стандарт этот не единственный, но используется достаточно широко и базируется на различных XML-стандартах W3C.
<p style="text-align: justify">Сама суть механизма подписи хорошо описана в <a href="http://xmlhack.ru/texts/03/wssecurity/wssecurity.html">этой статье</a>, из которой и я почерпнул для себя несколько полезных моментов, на которых возник ступор поначалу. Но предлагаемый мной вариант имеет одно важное дополнение: он добавляет в SOAP-сообщение ещё и информацию о сертификате, с помощью которого была сделана подпись. Кстати, меня удивила логика одной системы, для которой это делалось (кстати, написанной на Microsoft&#8217;овских компонентах): помимо сертификата в SSL-соединении они ещё проверяли сертификат и в самом запросе, хотя могли бы и воспользоваться данными HTTPS и тем самым получить ещё дополнительную проверку того, что соединение открыто тем самым агентом, который подписывал запрос.</p>
<p style="text-align: justify">Основным моментом в подписи является то, что собираются хэши (дайджесты) узлов с данными, которые будут подписаны (при этом узлы приводятся в <a href="http://www.w3.org/TR/2002/REC-xml-exc-c14n-20020718/">канонический вид</a> с помощью утилиты <tt>xmllint</tt> из комплекта <tt>libxml2</tt>). После чего собранные внутри одной «обёртки» дайджесты подписываются ключом сертификата, тем самым гарантируя, что если подпись верна, то данные в этих узлах не были изменены во время передачи запроса.</p>
<p style="text-align: justify">Класс так-же переписывает механизм HTTP-запроса к удалённому серверу, т.к. даже с помощью <tt>stream_context</tt> PHP не позволяет использовать совместно с SOAP сертификаты в формате PKCS12. В итоге используется <tt>HTTPRequest</tt>, результат которого уже транслируется далее в обработку.</p>
<ul>
<li> Собственно сам класс: <a href='http://dev.goodguy.spb.ru/wp-content/uploads/2009/04/signedsoapclient.zip'>SignedSoapClient.zip</a></li>
</ul>
]]></content:encoded>
			<wfw:commentRss>http://dev.good-guy.me/archives/356/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Сколько же записей обновилось?</title>
		<link>http://dev.good-guy.me/archives/349</link>
		<comments>http://dev.good-guy.me/archives/349#comments</comments>
		<pubDate>Mon, 30 Mar 2009 12:43:48 +0000</pubDate>
		<dc:creator>goodguy</dc:creator>
				<category><![CDATA[Базы данных]]></category>
		<category><![CDATA[Языки]]></category>
		<category><![CDATA[mysql]]></category>
		<category><![CDATA[php]]></category>

		<guid isPermaLink="false">http://dev.goodguy.spb.ru/?p=349</guid>
		<description><![CDATA[<a href="http://dev.good-guy.me/archives/349" title="Сколько же записей обновилось?"></a>Вроде бы простой вопрос, сколько рядов было затронуто SQL-операцией UPDATE, но и здесь притаился подводный камень (о котором, правда честно предупреждают в документации). В MySQL в это число могут не попадать записи, у которых данные не потребовалось изменять. А значит, &#8230;<p class="read-more"><a href="http://dev.good-guy.me/archives/349">Читать далее &#187;</a></p>]]></description>
			<content:encoded><![CDATA[<a href="http://dev.good-guy.me/archives/349" title="Сколько же записей обновилось?"></a><p style="text-align: justify">Вроде бы простой вопрос, сколько рядов было затронуто SQL-операцией <tt>UPDATE</tt>, но и здесь притаился подводный камень (о котором, правда честно предупреждают в документации). В MySQL в это число могут не попадать записи, у которых данные не потребовалось изменять. А значит, если <tt>REPLACE</tt> не подходит, то нужно проводить дополнительные проверки на тему того, сколько же данных вы обновили. Я споткнулся об этом в функции <tt><a href="http://ru2.php.net/manual/en/function.mysql-affected-rows.php">mysql_affected_rows</a></tt> в PHP. Там-же можно найти один из вариантов решения &#8212; использовать <tt><a href="http://ru2.php.net/manual/en/function.mysql-info.php">mysql_info</a></tt>, но в этом случае нужно парсить строку с ответом. Ну а дальше в вариантах <tt>SELECT</tt>&#8216;ы и т.п.</p>
]]></content:encoded>
			<wfw:commentRss>http://dev.good-guy.me/archives/349/feed</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
	</channel>
</rss>

