PHP: различия между версиями
Misha (обсуждение | вклад) (→Как при подключении к MSSQL базе с кодировкой CP1251, а выводить данные в UTF8?) |
Misha (обсуждение | вклад) (→При выводе поля типа datetime, оно выводится уже форматированным) |
||
Строка 42: | Строка 42: | ||
В php.ini установить переменную | В php.ini установить переменную | ||
<pre>mssql.datetimeconvert = Off</pre> | <pre>mssql.datetimeconvert = Off</pre> | ||
+ | ===Знакомство с PEAR:: Spreadsheet_Excel_Writer (установка и устранение ошибок)=== | ||
+ | ====Установка==== | ||
+ | <pre>#apd-get install pear | ||
+ | # pear install -f OLE | ||
+ | # pear install -f Spreadsheet_Excel_Writer</pre> | ||
+ | ====Документация==== | ||
+ | #[http://phpclub.ru/detail/article/Excel_Writer Создание таблиц Excel средствами PHP] | ||
+ | #[http://pear.php.net/package/Spreadsheet_Excel_Writer/docs Документация] | ||
+ | ====Устранение ошибок==== | ||
+ | 1. <pre>Deprecated: Call-time pass-by-reference has been deprecated in /usr/share/pear/Spreadsheet/Excel/Writer/Worksheet.php on line 2490</pre> | ||
+ | Редактируем файл '''Spreadsheet/Excel/Writer/Worksheet.php''' строка 2489<br /> | ||
+ | Было<pre>$string=$header.$data; | ||
+ | $this->_append(&$string, true);</pre> | ||
+ | Стало<pre>$this->_append($header.$data, true);</pre><br /> | ||
+ | '''2. Ошибка открытия excel файла в office 2010 в w7 и w8'''.<br /> | ||
+ | Редактируем файл '''/usr/share/pear/OLE/PPS/Root.php''' строка 623 :<br /> | ||
+ | Было<pre>fwrite($FILE, pack("V", 1));</pre> | ||
+ | Стало<pre>fwrite($FILE, pack("V", $num_sb_blocks));</pre> |
Версия 12:32, 28 марта 2014
Буду записывать проблемы, с которыми я столкнулся и их решение
Содержание
- 1 Настройки, которые я сделал при переходе на php 5.3
- 2 FAQ
- 2.1 Вопрос
- 2.2 Message: Function set_magic_quotes_runtime() is deprecated
- 2.3 Warning: date() [function.date]: It is not safe to rely on the system's timezone settings. You are *required* to use the date.timezone setting or the date_default_timezone_set() function
- 2.4 Как при подключении к MSSQL базе с кодировкой CP1251, а выводить данные в UTF8?
- 2.5 При выводе поля типа datetime, оно выводится уже форматированным
- 2.6 Знакомство с PEAR:: Spreadsheet_Excel_Writer (установка и устранение ошибок)
Настройки, которые я сделал при переходе на php 5.3
/etc/php.ini
log_errors = on error_reporting = E_ALL & ~E_NOTICE & ~E_STRICT display_errors = on post_max_size = 200M upload_max_filesize = 200M ; Если не указать тайм зону, то будут сыпаться ошибки. date.timezone = Europe/Moscow ; заремарить следующую строку, иначе письма будут терять поле FROM ;mail.add_x_header = On
FAQ
Вопрос
Есть страничка на которой отмечается около 120 checkbox'ов. С помощью функции
print_r($_REQUEST);
просматриваю их состояние после ввода. Так вот вводится только 100 или 101 отмеченный чекбокс, остальные пропадают, те их нет в выводе, хотя тоже отмечены.
Ответ
Отредактируйте строки в конфигурационном файле /etc/php.d/Z98_suhosin.ini
suhosin.request.max_vars 500 suhosin.post.max_vars 500
Message: Function set_magic_quotes_runtime() is deprecated
При переносе сервера, появилась ошибка Message: Function set_magic_quotes_runtime() is deprecated
Решение
Эта функция считается устаревшей в 5.3, а в 6.0 ее вообще не будет. Один из вариантов. Поставить перед функцией set_magic_quotes_runtime() знак @.
Warning: date() [function.date]: It is not safe to rely on the system's timezone settings. You are *required* to use the date.timezone setting or the date_default_timezone_set() function
При переносе сервера, появилась ошибка При переносе сервера, появилась ошибка Message: Function set_magic_quotes_runtime() is deprecated ...
Решение
В php.ini прописать
date.timezone = Europe/Moscow
Как при подключении к MSSQL базе с кодировкой CP1251, а выводить данные в UTF8?
При выводе данных из таблиц MSSQL все русские буквы стали знаками вопроса.
Решение
В php.ini установить переменную
mssql.charset = "UTF8"
При выводе поля типа datetime, оно выводится уже форматированным
При выводе поля типа datetime, оно выводится уже форматированным, а надо как есть.
Решение
В php.ini установить переменную
mssql.datetimeconvert = Off
Знакомство с PEAR:: Spreadsheet_Excel_Writer (установка и устранение ошибок)
Установка
#apd-get install pear # pear install -f OLE # pear install -f Spreadsheet_Excel_Writer
Документация
Устранение ошибок
1.
Deprecated: Call-time pass-by-reference has been deprecated in /usr/share/pear/Spreadsheet/Excel/Writer/Worksheet.php on line 2490
Редактируем файл Spreadsheet/Excel/Writer/Worksheet.php строка 2489
Было
$string=$header.$data; $this->_append(&$string, true);
Стало
$this->_append($header.$data, true);
2. Ошибка открытия excel файла в office 2010 в w7 и w8.
Редактируем файл /usr/share/pear/OLE/PPS/Root.php строка 623 :
Было
fwrite($FILE, pack("V", 1));
Стало
fwrite($FILE, pack("V", $num_sb_blocks));