Версия 1.0 alpha 1 от 31.07.2002 10:55:30
Официальное местонахождение faq.saterenko.ru
Авторы:
Alexey Kolesnichenko
Alexey Sviridov, 2:5002/27.800
anatoly techtonik
Andrey N. Demushkin, drew(a)adx.cjb.net
Andrey Saterenko
Andy Ice, 2:5012/8.13
Dmitrik Kolesnikov, 2:463/3141.95
Dmitry Ban, 2:5020/1169.33
Dmitry Eroshin, 2:5037/31.13
Dmitry Seleznev, 2:5095/6
ivan kovalenko, 2:5057/53
Jon S. Stevens
Kirill Kustov <2:5045/67>
Maxim Matyukhin
Pavel P, vprin@indiainfo.com
Raoul & Natalia Nakhmanson-Kulish
SeazoN
Serge V. Tarasov
trent
Vitaliy N. Kravchenko, kvn(@)phbme.ntu-kpi.kiev.ua
Vladimir N. Zaytcev <2:5015/116>
Vova Rusakevich, 2:454/23.501
Zubarev Andrey, oistets(a)bogatyr.kz
Пальчуковский Евгений Викторович
Составители:
Andy Ice
Geek
trent
Vinny
Благодарности:
Мамам, папам - за нас с вами
сестрам, братьям - за то, что успешно отвлекают от дел наших
[женам|мужьям], [подругам|друзьям] - за самоотверженную выдержку в вечном
ожидании нас.
Отдельная благодарность Андрею Сатеренко
1. Общие вопросы
---------------------------------------------------------------------------
1. Что такое PHP?
2. Как взаимодействуют PHP и HTML?
3. Где взять PHP?
4. Как расшифровывается PHP?
5. Для чего нужен файл php.ini?
6. Подскажите как перехватить средствами PHP переменные JavaScript?
7. Подскажите где скачать Apache+PHP+MySql for Win?
8. Hаписал класс. Хочу выложить его в общее пользование. Как принято
документировать подобные вещи? Где посмотреть?
9. A отладчик PHP в природе существует? Как они работают?
10. Можно ли использовать PHP как замену Perl'а и других
интерпретируемых языков при создании shell-скриптов?
11. Пpи pаботе c сессиями, вываливаетcя cообщение в бpаузеp:
Warning: open(/tmpsess_???, O_RDWR) failed: m (2) in script.php
on line X?
12. Как сделать, что бы вывод из моего скрипта сразу показывался у
пользователя в браузере?
13. Как измерить время с точностью до микpосекунды?
14. Как передать параметры из формы с множественным значением (select
multiple, значение checkbox'ов и т.д)?
15. Как бы мне получить вчеpашнюю дату?
16. Расскажите, чем отличается вызов функции с собакой от вызова без собаки?
17. Функции strtoupper() strtolower() не работают или работают неправильно.
18. Какие специфичные функции не работают под IIS?
19. Имеется форма, где вносится текст с переносом строк, при выводе текста
на страницу строки не переносятся, что делать?
20. Как передать параметры скрипту, если он выполняется из командной строки?
21. Как выполнять свой скрипт с некоторой периодичностью (каждый час)?
----------------------------------------------------------------------------
2. Установка
----------------------------------------------------------------------------
1. Установка PHP в системе Windows.
2. Скрещивание PHP/Win32 и Apache/Win32.
3. Установка PHP >=4.2.2 как модуль Apache 2.0.x под Windows.
----------------------------------------------------------------------------
3. Hастройка
----------------------------------------------------------------------------
1. Каким образом создать ссылку, типа как у http://lenta.ru/2002/01/09/?
2. Я делаю так, как написано в примерах, но переменные, передаваемые в
скрипт, не видны. Почему?
3. Зачем теперь register_globals=off?
4. У моего хостера стоит register_globals=off, как можно включить
register_globals программно?
----------------------------------------------------------------------------
4. Работа с базами данных
----------------------------------------------------------------------------
1. При выборке из базы не правильно сортирует руские буквы.
2. Как перейти c MySQL на PostgreSQL?
3. Добавляем запись с автоинкрементным уникальным индексом. Как узнать
значение последнего индекса?
4. Как взять картинку из BLOB?
5. Какую базу данных лучше всего выбрать?
----------------------------------------------------------------------------
5. Работа с файлами
----------------------------------------------------------------------------
1. Пытаюсь переслать картинку из файла, но она приходит частично, "бьется",
что делать?
2. Почему при работе с csv-файлами теряются некоторые заглавные русские
буквы?
3. При попытке отдать через header("Location: somefile") файл с расширением
pdf, doc, txt, IE открывает их в окне браузера. Как этого избежать?
4. Как заставить браузер предлагать сохранять файл с нужным названием, а не
download.php?
5. Как корректно заставить броузер скачать и записать файл вместо открытия
в окне с поддержкой докачки? (пример скрипта)
6. Как сделать аттачмент к е-мейлy пpи отпpавке его с помощью фyнкции mail?
----------------------------------------------------------------------------
6. Работа с графикой
----------------------------------------------------------------------------
1. Вздумалось мне локальную баннерную сеть написать, да еще и с подсчетом
показов. Вот и проблемка возникла: как из такой строки в HTML
<img src="script.php"> показать картинку? Header() вроде как не проходит?
----------------------------------------------------------------------------
7. Сетевые дела
----------------------------------------------------------------------------
1. Почему с'апложенные jpeg-файлы не отобpажаются? (бьются?). Веб-сервер -
русский Апач.
2. Как опpеделить валидность e-mail?
3. Как определить валидность URL?
4. Как определить размер файла, если известен только его URL?
5. Как правильно перенаправить browser на нужный адрес?
----------------------------------------------------------------------------
8. Безопасность
----------------------------------------------------------------------------
1. Я хочу ограничить доступ к одной из страниц. Хочу, чтобы при попытке
открытия этой страницы браузер у клиента вывешивал окошко и предлагал
ввести логин?
2. Я - hosting provider, как мне организовать безопасность скриптов
виртуальных серверов, т.е. что бы юзер Вася не смог сделать fread()
файла юзера Пети?
----------------------------------------------------------------------------
9. Где взять...
/ 9.1. Документацию
----------------------------------------------------------------------------
1. Где взять документацию по PHP?
2. Информация по написанию модулей для php.
3. Другие полезные ссылки
----------------------------------------------------------------------------
/ 9.2. Скрипты
----------------------------------------------------------------------------
/ 9.3. Редакторы
----------------------------------------------------------------------------
/ 9.4. Хостинг
----------------------------------------------------------------------------
1. Общие вопросы
----------------------------------------------------------------------------
1. Что такое PHP?
2. Как взаимодействуют PHP и HTML?
3. Где взять PHP?
4. Как расшифровывается PHP?
5. Для чего нужен файл php.ini?
6. Подскажите как перехватить средствами PHP переменные JavaScript?
7. Подскажите где скачать Apache+PHP+MySql for Win?
8. Hаписал класс. Хочу выложить его в общее пользование. Как принято
документировать подобные вещи? Где посмотреть?
9. A отладчик PHP в природе существует? Как они работают?
10. Можно ли использовать PHP как замену Perl'а и других
интерпретируемых языков при создании shell-скриптов?
11. Пpи pаботе c сессиями, вываливаетcя cообщение в бpаузеp:
Warning: open(/tmpsess_???, O_RDWR) failed: m (2) in script.php
on line X?
12. Как сделать, что бы вывод из моего скрипта сразу показывался у
пользователя в браузере?
13. Как измерить время с точностью до микpосекунды?
14. Как передать параметры из формы с множественным значением (select
multiple, значение checkbox'ов и т.д)?
15. Как бы мне получить вчеpашнюю дату?
16. Расскажите, чем отличается вызов функции с собакой от вызова без собаки?
17. Функции strtoupper() strtolower() не работают или работают неправильно.
18. Какие специфичные функции не работают под IIS?
19. Имеется форма, где вносится текст с переносом строк, при выводе текста
на страницу строки не переносятся, что делать?
20. Как передать параметры скрипту, если он выполняется из командной строки?
----------------------------------------------------------------------------
> 1. Что такое PHP?
(перевод документации) "PHP, что означает 'PHP: Hypertext Preprocessor'
('PHP: Предварительный Обработчик Гипертекста'), является внедряемым в HTML
языком описания скриптов. Многое из его синтаксиса было позаимствовано из
C, Java и Perl с добавлением некоторых уникальных, специфичных для PHP,
особенностей. Целью создания языка является предоставление web-
разработчикам возможности быстрого создания динамически генерируемых
страниц."
ivan kovalenko, 2:5057/53
> 2. Как взаимодействуют PHP и HTML?
Язык PHP обладает несомненными преимуществами по сравнению с другими
языками программирования, применяемыми для работы с HTML, поскольку именно
для решения такого рода задач он и разрабатывался. Так что не стоит
удивляться тому, что этот язык обеспечивает простое, но при этом весьма
мощное взаимодействие с HTML. Когда браузер запрашивает с Web-сервера
страницу PHP, модуль PHP, прежде чем отправить эту страницу клиенту,
осуществляет ее обработку (интерпретацию). Части данной страницы,
являющиеся обычными инструкциями (тэгами) HTML, передаются клиенту точно
так же, как это происходит при обработке обычного документа HTML. Части,
написанные на языке PHP, обрабатываются PHP-модулем сервера - программой,
предназначенной для интерпретации инструкций PHP. Модуль PHP просматривает
код PHP и выполняет заданные в нем инструкции. Это могут быть, например,
команды отправки электронной почты, доступа к базе данных или
преобразования чисел.
Прежде чем приступить к разработке сценариев PHP, необходимо установить
соответствующее программное обеспечение: Web-сервер Apache и интерпретатор
PHP. Операция обычно проходит быстро и без осложнений. Если же вы
столкнетесь с проблемами, обратитесь к документации, прилагаемой к
программам Apache и PHP.
Dmitry Eroshin, 2:5037/31.13
> 3. Где взять PHP?
Hа сайте производителя: http://www.php.net/downloads.php
ivan kovalenko, 2:5057/53
> 4. Как расшифровывается PHP?
'PHP' - это рекурсивный акроним (аналогия с 'Linux' - 'Linux Is Not UniX')
словосочетания 'PHP: Hypertext Preprocessor' ('PHP: Предварительный
Обработчик Гипертекста'), что успешно отражает общую идеологию его
функционирования. До версии PHP 3.0 название было несколько иным
('PHP/FI') и расшифровывалось как 'Personal Home Page tools / Forms
Interpreter' ('Утилиты для Домашней Страницы / Интерпретатор Форм').
ivan kovalenko, 2:5057/53
> 5. Для чего нужен файл php.ini?
Файл php.ini (или php3.ini, если вы используете PHP3) определяет некоторые
установки, применяемые в PHP по умолчанию. Их можно корректировать в
зависимости от конкретных выполняемых задач. Файл содержит директивы PHP с
соответствующими значениями, позволяющими разрешить либо запретить
определенное средство или установить некоторое свойство (например, цвет
ссылки).
Чтобы посмотреть список этих значений, достаточно вызвать небольшой
сценарий info.php, созданный для проверки инсталляции PHP.
В оперативном руководстве по PHP, размещенным по адресу http://www.php.net,
указаны особенности каждой опции конфигурации и перечислены возможные
значения установок, которые могут быть изменены.
Dmitry Eroshin, 2:5037/31.13
> 6. Подскажите как перехватить средствами PHP переменные JavaScript?
Вопрос абсолютно дурацкий ибо проистекает из полного непонимания Web-
технологии. Скрипты JavaScript выполняются (или не выполняются :)) на
стороне клиента (браузера). Код же PHP выполняется на серверной стороне и к
JavaScript никакого отношения иметь не может.
Dmitry Seleznev, 2:5095/6
> 7. Подскажите где скачать Apache+PHP+MySql for Win?
Hапример здесь:
http://www.dklab.ru/doc/apache/apache_old.html
Vova Rusakevich, 2:454/23.501
> 8. Hаписал класс. Хочу выложить его в общее пользование. Как принято
> документировать подобные вещи? Где посмотреть?
Hапример здесь:
http://phpdocu.sourceforge.net/howto.php
Vova Rusakevich, 2:454/23.501
> 9. A отладчик PHP в природе существует? Как они работают?
Ищи здесь:
http://dd.cron.ru
Vova Rusakevich, 2:454/23.501
>10. Можно ли использовать PHP как замену Perl'а и других интерпретируемых
> языков при создании shell-скриптов?
Можно. И нужно W;) Сокращенный перевод официальной документации:
Выполнение PHP-скриптов из командной строки обычно применяется в тех
случаях, когда вам нужно протестировать настройку PHP или же если вы
собираетесь использовать возможности PHP в других целях, нежели создание
веб-скриптов. ... Обратите внимание, что вы можете перенаправить вывод
результатов выполнения скрипта во внешний файл, используя символ
'больше' ('>'), например,
php -q test.php > test.html
Вы можете выполнять PHP-скрипты в командной строке только в том случае,
если ваш PHP собран как самостоятельное приложение (stand-alone
executable). ...
PHP в качестве самостоятельного приложения может быть использован для
запуска PHP-скриптов в абсолютной независимости от web-сервера. Если вы
работаете в *nix-системе, вам нужно будет добавить специальную строку в
начало каждого скрипта (чтобы система смогла определить, какая программа
должна обрабатывать скрипт) и сделать его исполняемым (rwX).
Hа win-платформах вы можете ассоциировать .php-файлы с приложением php.exe
с помощью двойного щелчка кнопкой мыши в Проводнике (Explorer) или же
создавать пакетные (.bat) файлы для выполнения PHP-скриптов. ...
Пример (script.php):
#!/usr/bin/php -q
# -q используется для запрещения вывода HTTP-заголовков
В вышеприведенный скрипт была добавлена специальная первая строка, которая
указывает на то, что этот файл должен быть запущен с помощью PHP без вывода
HTTP-заголовков. При создании скриптов, предназначаемых для выполнения в
командной строке, вы можете использовать две специальных переменных: $argc
и $argv. Первая - это количество переданных в командной строке аргументов
плюс один (имя выполняемого скрипта). Вторая - массив переданных
аргументов, начинающийся с имени скрипта - с нулевым индексом ($argv[0]).
Пример пакетного (.bat) файла для запуска скрипта на win-платформах
(script.bat):
@c:phpphp.exe -q script.php %1 %2 %3 %4
ivan kovalenko, 2:5057/53
>11. Пpи pаботе c сессиями, вываливаетcя cообщение в бpаузеp:
>Warning: open(/tmpsess_???, O_RDWR) failed: m (2) in script.php on line X?
В php.ini надо прописать путь до места, куда будут сохраняться сессии, по
умолчанию /tmp, что годится для юникса. Для win:
session.save_path = c:tmp
trent
>12. Как сделать, что бы вывод из моего скрипта сразу показывался у
>пользователя в браузере?
Использовать функцию flush(). В связи с особенностями вывода некоторых
браузеров, в том числе IE и Opera 6 рекомендуется послать 256 байт в начале
страницы, вот тестовый скрипт:
юзать будешь так:
<?
$t = new Timer();
?>
в нужном месте делаешь
<?
$t->start();
?>
там, где надо закончить отсчет так:
<?
$t->stop();
?>
ну и в где надо
<?
print $t->elapsed();
?>
Andrey N. Demushkin, drew(a)adx.cjb.net
>14. Как передать параметры из формы с множественным значением (select
>multiple, значение checkbox'ов и т.д)?
Для checkbox'a:
<input type="checkbox" name="id[]" value="0"/>
<input type="checkbox" name="id[]" value="1"/>
для multiple:
<select name="id[]" multiple="multiple">
<option value="0">0</option>
<option value="1">1</option>
</select>
данные из формы придут, как массив $id со значениями value.
trent
>15. Как бы мне получить вчеpашнюю дату?
<?
print date("d/m/Y", mktime(0,0,0,intval(date('n')),
intval(date('j'))-1,intval(date('Y'))));
?>
Kirill Kustov <2:5045/67>
<?
echo date("d/m/Y",time()-86400);
?>
Dmitrik Kolesnikov, 2:463/3141.95
<?
strtotime ("-1 day");
?>
Pavel P, vprin@indiainfo.com
>16. Расскажите, чем отличается вызов функции с собакой от вызова без
>собаки?
Если функция вызывается с собакой, то сообщение об ошибке подавляется.
Пальчуковский Евгений Викторович
>17. Функции strtoupper() strtolower() не работают или работают неправильно.
Попробуйте использовать такую фукцию:
strtoupper()
<?php
function toUpper($content) {
$content = strtr($content, "абвгдеёжзийклмнорпстуфхцчшщъьыэюя",
"АБВГДЕЁЖЗИЙКЛМHОРПСТУФХЦЧШЩЪЬЫЭЮЯ");
return strtoupper($content);
}
?>
>18. Какие специфичные функции не работают под IIS?
Привожу выбранные из маны, такой какой она была на момент 4.1.0
По смыслу это список функций которыми не смогут пользоваться в связке
IIS+PHP.
SeazoN
>19. Имеется форма, где вносится текст с переносом строк, при выводе текста
>на страницу строки не переносятся, что делать?
Дело в том, что при выводе страницы в общем случае игнорируются переносы
строк, что бы начать с новой строки нужно вставить тег или пару
</p><p> по необходимости. Смотри функцию nl2br.
Andy Ice, 2:5012/8.13
>20. Как передать параметры скрипту, если он выполняется из командной
>строки?
php.exe file.php "&pt=1"
Alexey Kolesnichenko
>21. Как выполнять свой скрипт с некоторой периодичностью (скажем каждый
>час)?
Выполнять действия с какой-то периодичность может только программа которая
работает все время. Обычно это операционка. Твой РHР-скрипт запускается
тогда, когда обращаются к web-серверу (Apache) и живет обычно не больше
чем time_limit. Как ты себе представляешь, что бы он делал что-то с
периодичностью раз в час?
Если уж сильно надо на РHР - запускай php.exe script.php -q >> out.log
из at на HТ или из cron'а в юниксах.
Alexey Sviridov, 2:5002/27.800
2. Установка
----------------------------------------------------------------------------
1. Установка PHP в системе Windows.
2. Скрещивание PHP/Win32 и Apache/Win32.
3. Установка PHP >=4.2.2 как модуль Apache 2.0.x под Windows.
----------------------------------------------------------------------------
> 1. Установка PHP в системе Windows.
1. Б броузере набрать http://www.php.net и кликнуть на ссылку Download
2. Перепишите на свой комп файл PHP, подходящий для системы Windows (php3,
php4 или и тот, и другой), щелкнув на нем. Hа компах с системой Windows
легко устанавливаются и PHP3, и PHP4, и даже обе эти версии.
3. Извлеките все файлы из архива во временную папку.
4. Скопируйте все файлы .dll из временной папки, в которую вы поместили
файлы PHP, в папку общесистемных файлов Windows. В системе Windows 95/98
- это папка *:WindowsSystem. В Windows NT - *:WinntSystem.
5. Переименуйте файл php3.ini-dist (или php.ini-dist, если вы используете
PHP4) во временном каталоге в php.ini и скопируйте его в каталог Windows
(*:Windows или *:Winnt, в зависимости от версии системы).
6. Создайте папку на диске C: с именем php3 или php4 в зависимости от
версии.
7. Скопируйте файл php.exe в созданную папку php.
8. Откройте файл httpd.conf, который находится в каталоге *:Program Files
Apache GroupApacheconf. Для редактирование этого файла можно
использовать любой текстовый редактор, но обязательно сохраните данный
файл в виде простого текста, а не в формате .doc или в другом.
9. Добавьте следующие строки в конец файла httpd.conf, если вы используете
10. Если вы устанавливаете только PHP4, добавьте так же следующую строку
AddType application/x-httpd-php .php3
11. Сохраните файл.
12. Перезапустите Web-сервер Apache, щелкнув на соответствующих
пиктограммах его папки. В результате Apache еще раз прочитае файл
httpd.conf и обнаружит, что добавлены функциональные средства PHP.
13. Создайте в папке *:Program FilesApache GroupApachehtdocs сценарий
PHP, состоящий из одной строки. Для его написания можно использовать
любой текстовый редактор. Помните, что данный сценарий должен иметь
расширение .php. Присвойте файлу сценария имя info.php. Вот эта строка:
<? phpinfo(); ?>
14. Откройте броузер и направьте его по адресу http://localhost/info.php
Должна появиться страница PHP.
Помните, что реализация сценария на локальном компьютере зависит от двух
условий: во-первых, надо, чтобы работал Apache, и во-вторых, файл сценария
должен находиться в подпапке htdocs каталога, в котором установлен Apache.
Для вызова сценария и его последующего выполнения достаточно направить
броузер по адресу http://localhost/my_php_script.php
Dmitry Eroshin, 2:5037/31.13
> 2. Скрещивание PHP/Win32 и Apache/Win32.
Предполагается, что вы уже установили PHP и Apache. Для внесения пущей
ясности положим, что PHP установлен в каталоге 'C:HTTPphp', а Apache в
'C:HTTPapache', причем Apache уже настроен и без лишней ругани отзывается
на имя localhost, а необходимые изменения внесены в php.ini.
Теперь определимся, каким образом PHP будет функционировать: в виде
CGI-приложения [1] или как SAPI-модуль Apache [2] (разбор полетов на
предмет различий см.)
1. Hастройка PHP в качестве CGI-приложения.
Откройте Notepad'ом (FAR'ом, NC, WinCmd, и т.п.) файл
C:HTTPapacheconfhttpd.conf и найдите в нем и раскомментируйте (уберите
значок # в начале строки) следующие строчки:
Тестирование.
Теперь перезапустите Apache. Создайте в каталоге C:HTTPapachehtdocs файл
test.php следующего содержания:
<?php phpinfo(); ?>
запустите браузер и перейдите на http://localhost/test.php . Если ваш
браузер отобразил нечто табличное с большим количеством непонятной
информации, примите поздравления. Если вместо этого ваши старания
увенчались 'Error 500 - Internal Server Error', попробуйте прочитать эту
статью немного более внимательно.
ivan kovalenko, 2:5057/53
> 3. Установка PHP >=4.2.2 как модуль Apache 2.0.x под Windows.
0. Прежде всего нужно скачать последние стабильные версии как Apache так и
PHP. PHP лучше скачать по адресу http://snaps.php.net/win32/, где
выбрать последний snapshot.
1. Итак, устанавливаем Apache 2.0.x как обычно.
2. Устанавливаем PHP в каталог c:php (например).
3. Переименовываем файл php.ini-dist в php.ini и правим по вкусу,
4. обязательно не забыв указать путь к extensions, в нашем случае это
extension_dir = c:/php/extensions
5. и каталог с документами, в нашем случае это
doc_root = c:/Program files/Apache Group/Apache2/htdocs.
6. Копируем этот файл и файл php4ts.dll в каталог c:winnt.
7. Меняем расширение у файла c:phpsapiphp4apache2.dll на .so
8. В файле httpd.conf у Apache ищем строки, начинающиеся с LoadModule и
добавляем свою строку, не забыв кавычки,
LoadModule php4_module "c:/php/sapi/php4apache2.so"
9. Там же ищем строку AddType application/x-tar .tgz и ниже добавим свою
AddType application/x-httpd-php .php
10. необязательно: Ищем строки, начинающиеся с AddIcon и добавим .php в
AddIcon /icons/p.gif .pl .py .php
11. Стартуем (рестартуем) Apache
12. Если не запускается, читам Application log в Event Viewer-e и чешем
затылок, думая где ошиблись.
13. Возможно еще придется скопировать файлы из c:phpdlls в
c:winntsystem32, это если с какими-то extensions-ами не запустится.
Вначале пробуйте закомментировав вообще все расширения.
Andy Ice, 2:5012/8.13
3. Hастройка
----------------------------------------------------------------------------
1. Каким образом создать ссылку, типа как у http://lenta.ru/2002/01/09/?
2. Я делаю так, как написано в примерах, но переменные, передаваемые в
скрипт, не видны. Почему?
3. Зачем теперь register_globals=off?
4. У моего хостера стоит register_globals=off, как можно включить
register_globals программно?
----------------------------------------------------------------------------
> 1. Каким образом создать ссылку, типа как у http://lenta.ru/2002/01/09/?
У ленты этот движок основан на mod_rewrite, имнсхо, поскольку там апач
стоит
www.lenta.ru
HTTP/1.1 200 OK
Date: Fri, 11 Jan 2002 14:45:37 GMT
Server: Apache/1.3.14 (Unix) rus/PL30.0
соответственный rewrite rule регекспом - и все ок. а в директории хтмл'ки
складывать - черезчур корявый изврат. 8)
вот пример, как организовать подобное:
мы хотим выводить новости из базы данных по запрошенному ури
w3.lenta.ru/2002/01/11/tv6/ имея таблицу с полями новостей anchor
VARCHAR(255), date date, announce VARCHAR(255), body TEXT; где anchor -
текстовый указатель, date - дата, announce - анонс новости, body - тело
новости.
сразу привожу извинения за длинный регексп - пхп/перловый
^/(d{4}+)/(d{2}+)/(d{2}+)/(.*)/$ не прокатил. видимо модифер d rewrite
engine не понимает - у него там какие-то свои правила паттернов.
прописываем w3.lenta.ru в hosts на ip 192.168.10.1 (ip по вкусу - у кого
как отстроен локальный айпишник)
создаем два файла в корне /wwwroot/htdocs/w3lenta/:
1. этот будет отвечать на запрос w3.lenta.ru и в нем, допустим, строится
листинг по таблице из 10-ти последних новостей, но мы сюда забьем
тестируемый урл.
--- [ index.php ] ---
<a href="/2002/01/11/tv6/">ТВ-6 распадается</a>
--- [ index.php ] ---
2. этот будет выводить новость по date и anchor. кода не прописано, но
сделать select announce, body, date from table where date=$date AND
anchor=$anchor из таблицы новостей, я думаю, трудности никому не
составит. 8)
набираем в ослике w3.lenta.ru, щелкаем линк, и наслаждаемся результатом 8)
данные запрошенной новости: anchor = tv6, date = 2002-01-11
REQUEST_URI: http://w3.lenta.ru/2002/01/11/tv6/
remarks: в реале можно сделать, если админ конфиг пропишет или ты сам
админ. 8)
некоторые феньки rewrit'а (не могу сказать точно какие) работают только
в версии апача выше 1.2 - я тестировал на 1.3.20. категорию прикрутить тоже
несложно - просто соответствующих категориям регекспов налепить, убрав
modifier L (last rule) из всех окромя последнего.
Vladimir N. Zaytcev <2:5015/116>
> 2. Я делаю так, как написано в примерах, но переменные, передаваемые в
>скрипт, не видны. Почему?
Hачиная с PHP версии 4.1 установка register_globals по умолчанию
установлена в Off. Это означает, что к переменным переданным извне,
например так http://some.server.dom/script.php?varname=value, при такой
настройке в скрипте нельзя обращаться напрямую по имени $varname. Вместо
этого надо использовать обращение к элементам специально предопределенных
следующих массивов:
$_GET, $_POST, $_COOKIE, $_SESSION, $_SERVER (в PHP версии от 4.1) или,
соответственно, $HTTP_GET_VARS, $HTTP_POST_VARS, $HTTP_COOKIE_VARS,
$HTTP_SERVER_VARS (в любых версиях PHP).
При этом обращение к переменной приведенной в примере выше будет выглядеть
так:
$_GET['varname'] или $HTTP_GET_VARS['varname']
Serge V. Tarasov
> 3. Зачем теперь register_globals=off?
Это сделано для облегчения написания безопасных скриптов. При разработке
достаточно сложных проектов, когда число используемых переменных велико,
очень легко можно допустить использование неинициализированной переменной,
которая при register_globals=On может быть передана скрипту извне злобным
хацкером. Поэтому, для написания хороших скриптов, рекомендуется обращаться
к входным переменным через предопределенные массивы (при этом программист,
заранее зная, что эти переменные переданы снаружи производит
соответствующие проверки на корректность) и включить error_reporting =
E_ALL (по крайней мере, на этапе написания и тестирования скрипта) для
того, чтобы PHP предупреждал о использовании неинициализированных
переменных.
Безусловно, возможно написание хороших и безопасных скриптов и при
register_globals=On, но:
- это требует значительно более внимательного подхода к написанию;
- эти скрипты не будут корректно работать на хостинге, где
register_globals=Off (в отличие от скриптов, написанных для
register_globals=Off, которые будут корректно работать везде);
ВHИМАHИЕ!
- возможно, что из будущих версий PHP register_globals будет исключен
вообще.
Serge V. Tarasov
> 3. У моего хостера стоит register_globals=off, как можно включить
>register_globals программно?
Так как, вероятно, в следующих версиях register_globals уберут совсем и
поведение PHP будет таким, как при register_globals=off, то рассмотрим этот
вопрос под другим углом.
Поскольку существует множество уже используемых скриптов (надежных и не
очень), которые написаны в расчете на register_globals=On, то добавлением
нескольких строк кода заставим скрипт работать.
В общем случае, надо из предопределенных массивов $_GET, $_POST,
$_COOKIE, $_SESSION, $_SERVER (или какие вам нужны) импортировать значения
в переменные с именами элементов. Hапример так (для переменных получаемых
по GET):
<?
while (list($name, $value)=each($HTTP_GET_VARS)) {
if(isset($$name)) continue;
$$name=$value;
}
?>
Естественно, это негативно сказывается на безопасности, поскольку после
выполнения такого кода у вас станут глобальными все переменные переданные
снаружи (нужные и ненужные), т.е. это все равно, что сделать
register_globals=On.
Serge V. Tarasov
4. Работа с базами данных
----------------------------------------------------------------------------
1. При выборке из базы не правильно сортирует руские буквы.
2. Как перейти c MySQL на PostgreSQL?
3. Добавляем запись с автоинкрементным уникальным индексом. Как узнать
значение последнего индекса?
4. Как взять картинку из BLOB?
5. Какую базу данных лучше всего выбрать?
----------------------------------------------------------------------------
> 1. При выборке из базы не правильно сортирует руские буквы.
Если есть возможность, то запустите mysqld с опцией:
--default-character-set=cp1251" , если нет, то попробуйте послать MySQL
такой запрос: SET CHARACTER SET cp1251_koi8 - это изменит набор символов
для текущего соединения. SET CHARACTER SET DEFAULT - установит обычную
таблицу символов.
Имейте ввиду, что эта настройка действует только для текущего соединения.
Более подробно в RTFM.
trent
> 2. Как перейти c MySQL на PostgreSQL?
Рекомендую http://www.webmasterbase.com/subcats/6
Migrate your site from MySQL to PostgreSQL -- Part 1
Migrate your site from MySQL to PostgreSQL -- Part 2
Vova Rusakevich, 2:454/23.501
> 3. Добавляем запись с автоинкрементным уникальным индексом. Как узнать
>значение последнего индекса?
>>Для MySQL
Есть замечательная функция mysql_insert_id ([идент. соединения]).
Возвращает целое значение, которое и есть необходимый идентификатор,
сгенерированный полем AUTO_INCREMENT в последем операторе INSERT.
Подробно см. в доках по функциям PHP.
Cледует обратить внимание на то, что mysql_insert_id получает число типа
INT, поэтому необходимо быть осторожным при использовании этой функции с
полями типа BIGINT.
Dmitry Seleznev, 2:5095/6
>>Для MSSQL
Hужно сразу после insert выполнить запрос
'select @@IDENTITY newID from Твоя_Таблица'. Получишь идентификатор для
только что вставленной записи.
Подробнее о переменных см. в доках MS SQL.
Andy Ice, 2:5012/8.13
> 4. Как взять картинку из BLOB?
>>Для MSSQL
Просто использовать функции mssql_* не получится, но можно использовать
odbc_*
>>Для ODBC
Должен быть создан так называемый System DSN в ODBC Admin
Вызов: getfoto.php?id=13
<?
$sql = odbc_connect("namedsn", "user", "password") or die('die message');
$query = odbc_exec($sql, "select FOTOFIELD from FOTOTABLE where ID=$id");
if ($fetched = odbc_fetch_row($query)) {
$dbimage = odbc_result($query, "FOTO");
}
else
{
$filename = "./none.jpg"; // Пустая картинка
$fd = fopen ($filename, "rb");
$dbimage = fread ($fd, filesize ($filename));
fclose ($fd);
}
header('Content-type: image/jpeg');
//header('Content-Disposition: attachment; filename='.$id.'.jpg');
print $dbimage;
flush();
odbc_close($sql);
?>
Andy Ice, 2:5012/8.13
> 5. Какую базу данных лучше всего выбрать?
Выбор базы данных (SQL-сервера) зависит от задач, которые планируются.
Andy Ice, 2:5012/8.13
5. Работа с файлами
----------------------------------------------------------------------------
1. Пытаюсь переслать картинку из файла, но она приходит частично, "бьется",
что делать?
2. Почему при работе с csv-файлами теряются некоторые заглавные русские
буквы?
3. При попытке отдать через header("Location: somefile") файл с расширением
pdf, doc, txt, IE открывает их в окне браузера. Как этого избежать?
4. Как заставить браузер предлагать сохранять файл с нужным названием, а не
download.php?
5. Как корректно заставить броузер скачать и записать файл вместо открытия
в окне с поддержкой докачки? (пример скрипта)
6. Как сделать аттачмент к е-мейлy пpи отпpавке его с помощью фyнкции mail?
----------------------------------------------------------------------------
> 1. Пытаюсь переслать картинку из файла, но она приходит частично,
>"бьется", что делать?
Бинарные файлы нужно открывать с ключем "b", иначе в некоторых случаях файл
считается текстовым. Обычно такое происходит под Windows, но если в Вашей
системе параметр "b" не требуется, то он будет игнорироваться, поэтому
рекомендуется его все-таки употреблять. Пример:
<?
$fp = fopen("/home/rasmus/file.txt", "rb");
?>
Andy Ice, 2:5012/8.13
> 2. Почему при работе с csv-файлами теряются некоторые заглавные русские
>буквы?
Потому что csv-файл должен удовлетворять одному, главному условию:
текстовые поля должны быть ограничены кавычками, т.е. пример такого плана:
222, "Фамилия Имя Отчество", "Должность"
Andy Ice, 2:5012/8.13
> 3. При попытке отдать через header("Location: somefile") файл с
>расширением pdf, doc, txt, IE открывает их в окне браузера. Как этого
>избежать?
При отдаче файла через header("Location: somefile"), web сервер отдает еще
Content-type этого файла, который узнается по расширению файла. Информация
о соответствии content-а расширению берется web сервером из
конфигурационного файла mime.types. Броузеры в зависимости от получаемого
Content-type знают что дальше делать с этим файлом. При этом расширение
файла броузеру ни о чем не говорит, и если web сервер отдаст, к примеру,
файл best_music.mp3 с Content-type: application/msword, то, если в системе
клиента установлен MS Word, этот файл будет открыт им.
Для решения проблемы описанной в вопросе существуют два способа:
1. Отредактировать файл mime.types поставив желаемым расширениям файлов
(которые надо скачивать, а не открывать) в соответствие тип
application/octet-stream.
Hедостатки:
- этот путь годится, если Вы яляетесь администратором сервера;
- изменения коснутся всех файлов, тип которых Вы переопределили, даже тех,
которые HАДО открывать в броузере.
2. Отдавать файл клиенту, не посредством header("Location: somefile"), а
организовав собственную процедуру отдачи файла. При этом появляется
возможность динамически менять Content-type, предоставив пользователю
выбор, открыть ли файл в броузере или просто скачать, записав на диск.
Hедостатки:
- бОльшая нагрузка на сервер;
- бОльшие требования к объему RAM на сервере.
Serge V. Tarasov
> 4. Как заставить браузер предлагать сохранять файл с нужным названием, а
>не download.php?
В msdn нашел:
<?
header("Content-Disposition: attachment; filename=work1.doc");
$x = fread(fopen("test.doc", "rb"), filesize("test.doc"));
echo $x;
?>
Alexey Kolesnichenko
> 5. Как корректно заставить броузер скачать и записать файл вместо открытия
>в окне с поддержкой докачки? (пример скрипта)
Предполагается, что $cd - путь к файлу, $fn - имя файла
<?php
$filename = $cd."/".$fn;
if (!file_exists($filename))
{
header ("HTTP/1.0 404 Not Found");
exit;
}
$fsize = filesize($filename);
$ftime = date("D, d M Y H:i:s T", filemtime($filename));
$fd = @fopen($filename, "rb");
if (!$fd){
header ("HTTP/1.0 403 Forbidden");
exit;
}
// Если запрашивающий агент поддерживает докачку
if ($HTTP_SERVER_VARS["HTTP_RANGE"]) {
$range = $HTTP_SERVER_VARS["HTTP_RANGE"];
$range = str_replace("bytes=", "", $range);
$range = str_replace("-", "", $range);
if ($range) {fseek($fd, $range);}
}
$content = fread($fd, filesize($filename));
fclose($fd);
if ($range) {
header("HTTP/1.1 206 Partial Content");
}
else {
header("HTTP/1.1 200 OK");
}
header("Content-Disposition: attachment; filename=$fn");
header("Last-Modified: $ftime");
header("Accept-Ranges: bytes");
header("Content-Length: ".($fsize-$range));
header("Content-Range: bytes $range-".($fsize -1)."/".$fsize);
header("Content-type: application/octet-stream");
print $content;
exit;
?>
Serge V. Tarasov
>6. Как сделать аттачмент к е-мейлy пpи отпpавке его с помощью фyнкции
>mail?
6. Работа с графикой
----------------------------------------------------------------------------
1. Вздумалось мне локальную баннерную сеть написать, да еще и с подсчетом
показов. Вот и проблемка возникла: как из такой строки в HTML
<img src="script.php"> показать картинку? Header() вроде как не проходит?
----------------------------------------------------------------------------
> 1. Вздумалось мне локальную баннерную сеть написать, да еще и с подсчетом
>показов. Вот и проблемка возникла: как из такой строки в HTML
><img src="script.php"> показать картинку? Header() вроде как не проходит?
Хочется самому написать? Смотри PHP Manual в разделе GD Functions. Там
разберешься.
Или взять готовую банерокрутилку (по моему phpAds называеться,
http://www.hostcripts.com, http://php.resourceindex.com/).
Vova Rusakevich, 2:454/23.501
7. Сетевые дела
----------------------------------------------------------------------------
1. Почему с'апложенные jpeg-файлы не отобpажаются? (бьются?). Веб-сервер -
русский Апач.
2. Как опpеделить валидность e-mail?
3. Как определить валидность URL?
4. Как определить размер файла, если известен только его URL?
5. Как правильно перенаправить browser на нужный адрес?
----------------------------------------------------------------------------
> 1. Почему с'апложенные jpeg-файлы не отобpажаются? (бьются?). Веб-сервер -
>русский Апач.
Все дело в том, что русский Апач по умолчанию производит перекодировку
файлов. Так, символ с кодом 0х00 он заменяет на пробел (символ с кодом
0х20).
Для борьбы с этим эффектом нужно добавить в конфигурационный файл Апача
httpd.conf следующее:
<Location />
CharsetRecodeMultipartForms Off
</Location>
Dmitry Seleznev, 2:5095/6
> 2. Как опpеделить валидность e-mail?
<?
function valid_mail ($email) {
if (eregi("^[_.0-9a-z-]+@([0-9a-z][0-9a-z-.]+).([a-z]{2,4}$)",
$email, $check)) {
if (getmxrr($check[1] . "." . $check[2], $mxhosts)) {
return "Valid";
} else {
return "No MX for " . $check[1] . "." . $check[2];
}
} else {
return "Badly formed address";
}
}
?>
Maxim Matyukhin
> 2. Как опpеделить валидность e-mail?
<?
/*
By: Jon S. Stevens jon@clearink.com
Copyright 1998-1999 Jon S. Stevens, Clear Ink
This code has all the normal disclaimers.
It is free for any use, just keep the credits intact.
*/
> 3. Как определить валидность URL?
<?
function check_url($url) {
if (eregi( '^http://', $url)) {
$urlArray = parse_url($url);
if (!$urlArray[port]) $urlArray[port] = '80';
if (!$urlArray[path]) $urlArray[path] = '/';
$sock = fsockopen($urlArray[host], $urlArray[port], &$errnum, &$errstr);
if (!$sock) $res = 'DNS';
else {
$dump .= "GET $urlArray[path] HTTP/1.1rn";
$dump .= "Host: $urlArray[host]rnConnection: closern";
$dump .= "Connection: closern";
fputs($sock, $dump);
while ($str = fgets($sock, 1024)) {
if (eregi("^http/[0-9]+.[0-9]+ ([0-9]{3}) [a-z ]*", $str))
$res[code] = trim(eregi_replace('^http/[0-9]+.[0-9]+([0-9]{3})[a-z]*', "\1", $str));
if (eregi("^Content-Type: ", $str))
$res[contentType] = trim(eregi_replace("^Content-Type: ", "",$str));
}
fclose($sock);
flush();
return $res[code];
}
} else $res = "N/A";
return $res;
}
?>
Dmitry Seleznev, 2:5095/6
> 4. Как определить размер файла, если известен только его URL?
<?
$hostname = "server2.ru"; // Имя сервера
$filename = "/path_to_file/filename.ext"; // Файл, размер которого надо узнать
get_size($hostname, $filename);
// А это сама функция узнавания размера
function get_size($hostname, $filename) {
$end = false;
$fp = fsockopen ($hostname, 80, &$errnr, &$errstr) or
die("$errno:$errstr");
fputs($fp,"HEAD ".$filename." HTTP/1.0nn");
while (!$end) {
$line = fgets($fp, 2048);
if (trim($line) == "") {
$end = true;
} else {
$str = explode(": ", $line);
if ($str[0] == "Content-Length")
print "Size of ".$filename." file ".$str[1]." bytes";
}
}
fclose($fp);
}
?>
Serge V. Tarasov
> 5. Как правильно перенаправить browser на нужный адрес?
Для перенаправления browser на нужный адрес (редирект) нужно
воспользоваться конструкцией вида:
header("Location: " . $url);
Location должен задаваться абсолютным адресом, согласно RFC 2616
(http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.30) :
"14.30 Location The Location response-header field is used to redirect the
recipient to a location other than the Request-URI for completion of the
request or identification of a new resource. For 201 (Created) responses,
the Location is that of the new resource which was created by the request.
For 3xx responses, the location SHOULD indicate the server's preferred URI
for automatic redirection to the resource. The field value consists of a
single absolute URI.
Location = "Location" ":" absoluteURI
An example is:
Location: http://www.w3.org/pub/WWW/People.html"
Alexey Kolesnichenko
8. Безопасность
----------------------------------------------------------------------------
1. Я хочу ограничить доступ к одной из страниц. Хочу, чтобы при попытке
открытия этой страницы браузер у клиента вывешивал окошко и предлагал
ввести логин?
2. Я - hosting provider, как мне организовать безопасность скриптов
виртуальных серверов, т.е. что бы юзер Вася не смог сделать fread()
файла юзера Пети?
----------------------------------------------------------------------------
> 1. Я хочу ограничить доступ к одной из страниц. Хочу, чтобы при попытке
открытия этой страницы браузер у клиента вывешивал окошко и предлагал ввести
логин?
> 2. Я - hosting provider, как мне организовать безопасность скриптов
>виртуальных серверов, т.е. что бы юзер Вася не смог сделать fread() файла
>юзера Пети?
Это делается при помощи диррективы PHP : safe_mode, и параметра
open_basedir.
Пример:
<VirtualHost 195.206.40.162:*>
ServerName tit.irk.ru
LanguagePriority ru en
DocumentRoot /home/users/WWW
<Directory /home/users/WWW>
php_admin_value open_basedir /home/users/WWW
</Directory>
</VirtualHost>
В итоге, если "умный" юзер Вася пытается что-то сделать с файлами за
пределами его (/home/users/WWW) дирректории, то он получает:
Warning: open_basedir restriction in effect. File is in wrong directory.
in /home/users/WWW/ss.pht on line 3
Warning: fopen("/etc/passwd","r") - Operation not permitted in
/home/users/WWW/ss.pht on line 3
За более детальным конфигом с комментариями:
http://www.php4you.kiev.ua/docs/php_limit.html
Vitaliy N. Kravchenko, kvn(@)phbme.ntu-kpi.kiev.ua
Что бы дать юзеру хранить/читать/писать в файлы вне www, но в пределах
доступности скрипта нужно исправить строку:
php_admin_value open_basedir /home/users
Oleg Krasnov, 2:5062/17.77
9. Где взять... / 9.1. Документацию
----------------------------------------------------------------------------
1. Где взять документацию по PHP?
2. Информация по написанию модулей для php.
3. Другие полезные ссылки
----------------------------------------------------------------------------
> 1. Где взять документацию по PHP?
Документацию по PHP можно взять тут: http://www.php.net/docs.php.
Andrey Saterenko
Однако для тех, у кого стоит windows, существует гораздо более удобный и
полезный вариант в .chm формате с комментариями пользователей.
http://weblabor.hu/php-doc-chm/
anatoly techtonik
> 2. Информация по написанию модулей для php.
http://www.zend.com/
http://www.zend.com/apidoc/
Vova Rusakevich, 2:454/23.501
> 3. Другие полезные ссылки
http://www.dklab.ru/ - Лаборатория dk
http://www.phpclub.net/ - PHPClub
9. Где взять... / 9.2. Скрипты
----------------------------------------------------------------------------
1. Где взять готовый скрипт гостевой, форума и т.п.?
----------------------------------------------------------------------------
> 1. Где взять готовый скрипт гостевой, форума и т.п.?
Вот несколько ссылочек:
http://webscript.ru/
http://webscripts.com/
http://cgi.ru/
http://hotscripts.com/
http://cgi-fan.com/
http://www.phorum.org/
http://www.cgi-bin.ru/
9. Где взять... / 9.3. Редакторы
----------------------------------------------------------------------------
1. Это те редакторы которыми я пользовался, наибольшим мне нравится PHP
Coder, хотя остальные тоже ничего, но это уж на любителя. Есть
также парочка других редакторов, но они универсальные типа Context.
----------------------------------------------------------------------------
> 1. Это те редакторы которыми я пользовался, наибольшим мне нравится PHP
>Coder, хотя остальные тоже ничего, но это уж на любителя. Есть также парочка
>других редакторов, но они универсальные типа Context.
9. Где взять... / 9.4. Хостинг
----------------------------------------------------------------------------
1. Какие существуют халявные хостинги c поддержкой PHP?
2. Эти, обычно, нареканий не вызывают
----------------------------------------------------------------------------
> 1. Какие существуют халявные хостинги c поддержкой PHP?
Из наших:
http://www.webservis.ru
http://www.holm.ru
http://www.hut.ru
http://www.agava.ru
http://www.fatal.ru
> 2. Эти, обычно, нареканий не вызывают
http://www.kombat.ru
http://www.zenon.ru
Zubarev Andrey, oistets(a)bogatyr.kz
858 Прочтений • [PHP FAQ конференции fido7.ru.php (php faq html sql mysql postgresql install)] [08.05.2012] [Комментариев: 0]