Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Проблема с кодировкой PHP5 + MySQL

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Описание: та информация на русском языке которая извлекается с базы данных, представляется в виде "???? ??????? ???? ????? ??????" то есть явно руская кодировка
bavv
Отправлено: 21 Апреля, 2007 - 12:05:52
Post Id


Новичок


Покинул форум
Сообщений всего: 11
Дата рег-ции: Февр. 2007  
Откуда: KIEV


Помог: 0 раз(а)




При разработке сайта, я пользовался следующей связкой:
PHP 4.4.2 + MySQL 4 и Apache 2.2
Все работало нормально, единственное, PHP работал в режиме CGI, то есть не как служба apache.
Теперь возникла необходимость в подключении PHP как службы (это сваязано с вопросами аутентификации). Поэтому, так-как Apache упорно не хотел подключать библиотеку php4apache2.dll (я их перепробывал несколько штук), я поставил PHP 5.2.1
в котором есть библиотека php5apache2_2.dll которорая в свою очередь стала нормально. Далее подключил необходимые библиотеки MySQL и возникла следующая проблема:
та информация на русском языке которая извлекается с базы данных, представляется в виде "???? ??????? ???? ????? ??????" то есть явно руская кодировка не распознается.
В БД вся информация в win-1251
Может кто сталкивался с таким и знает решение?
 
 Top
evgenijj
Отправлено: 21 Апреля, 2007 - 13:14:38
Post Id



Участник


Покинул форум
Сообщений всего: 1212
Дата рег-ции: Авг. 2006  
Откуда: Москва


Помог: 10 раз(а)




После соединения с сервером БД выполнить запрос
 
 Top
valenok
Отправлено: 21 Апреля, 2007 - 13:18:22
Post Id



Здесь могла бы быть ваша реклама


Покинул форум
Сообщений всего: 4574
Дата рег-ции: Июль 2006  
Откуда: Israel


Помог: 3 раз(а)




В новых версиях MySQL (начиная с 4.1.0) изменился порядок работы с национальными кодировками, поэтому старый код может вызывать появление в таблице базы данных знаков вопроса '????????' вместо русского текста. Для того, чтобы этого не возникало в начало PHP-скрипта, после установки соединения с базой данных, следует поместить следующие строки:
PHP:
скопировать код в буфер обмена
  1.  
  2. <?PHP
  3.   mysql_query ("set character_set_client='cp1251'");
  4.   mysql_query ("set character_set_results='cp1251'");
  5.   mysql_query ("set collation_connection='cp1251_general_ci'");
  6. ?>
  7.  


-----
Truly yours, Sasha.
 
My status
 Top
bavv
Отправлено: 28 Апреля, 2007 - 10:46:09
Post Id


Новичок


Покинул форум
Сообщений всего: 11
Дата рег-ции: Февр. 2007  
Откуда: KIEV


Помог: 0 раз(а)




может кому интересно и поможет кому-то еще, для того чтобы не устанавливать кодировку после каждого соединения.
На локальной машине я установил в my.ini следующую строку.
skip-character-set-client-handsh ake
которая указывает серверу игнорировать кодировку указанную клиентом.

Спасибо всем за отзывчивость.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« SQL и Архитектура БД »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB