PHP « Знаки вопроса вместо русских символов

При генерации страницы на основе данных из БД, вместо русских символов отображаются знаки вопроса:

/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .html4strict.geshi_code {font-family:monospace;} .html4strict.geshi_code .imp {font-weight: bold; color: red;} .html4strict.geshi_code .kw2 {color: #000000; font-weight: bold;} .html4strict.geshi_code .kw3 {color: #000066;} .html4strict.geshi_code .es0 {color: #000099; font-weight: bold;} .html4strict.geshi_code .br0 {color: #66cc66;} .html4strict.geshi_code .sy0 {color: #66cc66;} .html4strict.geshi_code .st0 {color: #ff0000;} .html4strict.geshi_code .nu0 {color: #cc66cc;} .html4strict.geshi_code .sc-1 {color: #808080; font-style: italic;} .html4strict.geshi_code .sc0 {color: #00bbdd;} .html4strict.geshi_code .sc1 {color: #ddbb00;} .html4strict.geshi_code .sc2 {color: #009900;} .html4strict.geshi_code span.xtra { display:block; }

??? ?????? ? 16.10.2009 ???? ??????
 

Настораживает что русские символы возвращаются не в виде абракадабры, свидетельствовавшей бы о неправильной кодировке, а просто в виде плэйсхолдеров... такое впечатление будто что то в цепочке php->pdo->php->apache напрочь теряется при виде не ANSI символов.

Использую код:
/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .php.geshi_code {font-family:monospace;} .php.geshi_code .imp {font-weight: bold; color: red;} .php.geshi_code .kw1 {color: #b1b100;} .php.geshi_code .kw2 {color: #000000; font-weight: bold;} .php.geshi_code .kw3 {color: #990000;} .php.geshi_code .co1 {color: #666666; font-style: italic;} .php.geshi_code .co2 {color: #666666; font-style: italic;} .php.geshi_code .co3 {color: #0000cc; font-style: italic;} .php.geshi_code .co4 {color: #009933; font-style: italic;} .php.geshi_code .coMULTI {color: #666666; font-style: italic;} .php.geshi_code .es0 {color: #000099; font-weight: bold;} .php.geshi_code .es1 {color: #000099; font-weight: bold;} .php.geshi_code .es2 {color: #660099; font-weight: bold;} .php.geshi_code .es3 {color: #660099; font-weight: bold;} .php.geshi_code .es4 {color: #006699; font-weight: bold;} .php.geshi_code .es5 {color: #006699; font-weight: bold; font-style: italic;} .php.geshi_code .es6 {color: #009933; font-weight: bold;} .php.geshi_code .es_h {color: #000099; font-weight: bold;} .php.geshi_code .br0 {color: #009900;} .php.geshi_code .sy0 {color: #339933;} .php.geshi_code .sy1 {color: #000000; font-weight: bold;} .php.geshi_code .st0 {color: #0000ff;} .php.geshi_code .st_h {color: #0000ff;} .php.geshi_code .nu0 {color: #cc66cc;} .php.geshi_code .nu8 {color: #208080;} .php.geshi_code .nu12 {color: #208080;} .php.geshi_code .nu19 {color:#800080;} .php.geshi_code .me1 {color: #004000;} .php.geshi_code .me2 {color: #004000;} .php.geshi_code .re0 {color: #000088;} .php.geshi_code span.xtra { display:block; }

$pdo = new PDO('...');
   
$sql = 'SELECT * FROM tbl;';

$rs = $pdo->query($sql)->fetchAll(PDO::FETCH_ASSOC);

print_r($rs);
 

кодировка MySQL-базы - cp1251, apache на оттдачу похоже получает уже "?...?", потому как смена кодировки сервера (AddDefaultCharset) никак не влияет на результат.

Подскажите, чем можно делу помочь.

1 ответов


Можно попробовать сразу после соединения с БД выполнить такой запрос


SET NAMES cp1251
 

$base = new PDO('mysql:host=localhost;dbname=pdo', $user, $pass) or die('у нас не установленна система pdo');
$base->exec('SET NAMES utf8');


Вам, при создании таблицы, а еще лучше самой БД. Нужно создать в кодировке CHARSET=utf8 COLLATE=utf8_unicode_ci

Данные естественно придется в базу записать заново. Старые конвертировать, вроде не получится.



...
$sql = 'SELECT * FROM tbl;';
$pdo->query('SET NAMES cp1251');
$rs = $pdo->query($sql)->fetchAll(PDO::FETCH_ASSOC);
...
 
Да, теперь похоже на правду ;)

Насколько я понял, проблема заключается в том, что PHP-эшный(PDO-шный?) mysql-клиент работает одному богу известно в какой кодировке. Пробовал изменять дефолтную кодировку в php.ini, но похоже на кодировку в которой работает mysql-клиент это никакова влияния не оказывает...

Хотя вот для mssql-клиента, судя по найденому в php.ini параметру mssql.charset, такая опция предусмотрена. Вот бы и для mysql или PDO найти что нибудь подобное...