Posted April 24, 201212 yr comment_3166 Добрый день! Форум 3.3.0. Автоматически заменяет буквы "И" и "Ш" на "�?". Как это исправить? Заранее спасибо! 07. Tango.mp3
April 24, 201212 yr comment_3167 yanker,в админцентре: Поддержка --> Управление базой данных --> Значения системных настроек. Сравни свои переменные с теми, какие должны быть: character_set_client..........utf8 character_set_connection..utf8 character_set_database.....utf8 character_set_results........utf8 character_set_server.........utf8 character_set_system.......utf8
April 24, 201212 yr Author comment_3170 character_set_client cp1251 character_set_connection cp1251 character_set_database utf8 character_set_results cp1251 character_set_server cp1251 character_set_system utf8 Как можно изменить эти настройки?
April 24, 201212 yr comment_3171 Попробуй в conf_global.php прописать: @mysql_query("SET NAMES 'utf8'"); @mysql_query("SET collation_connection='utf8_general_ci'"); @mysql_query("SET collation_server='utf8_general_ci'"); @mysql_query("SET character_set_client='utf8'"); @mysql_query("SET character_set_connection='utf8'"); @mysql_query("SET character_set_results='utf8'"); @mysql_query("SET character_set_server='utf8'"); [/CODE]
April 28, 201212 yr Author comment_3373 Написал хостеру, получил ответ! Регулировать кодировку сайта Вы можете при помощи файла .htaccess - __www.htaccess.net.ru/doc/AddType-charset/CharsetDefault.php. В .htaccess прописал AddDefaultCharset utf8, ошибка осталась. Может не то прописал?
April 28, 201212 yr comment_3374 Добавь туда вот это: AddDefaultCharset utf-8 <IfModule mod_charset.c> CharsetRecodeMultipartForms Off CharsetSourceEnc utf-8 </IfModule> [/CODE]
April 28, 201212 yr comment_3390 Система - Системные настройки - Безопасность - Удалять коды chr(0xCA) при вводе? должно стоять на "нет"
May 2, 201212 yr Author comment_3533 Этот параметр стоит на "Нет". Хостер еще написал : Изменить инструкции сервера по кодировке интерпретации содержимого броузером, Вы можете разместив в каталоге сайта файл .htaccess с соответствующие директивы: AddDefaultCharset utf-8 AddCharset utf-8 <ifModule mode_charset.c> CharsetSourceEnc utf-8 CharsetDefault unf-8 </ifModule> php_value default_charset "utf-8" Все делаю как надо, а ошибка все равно остается.
May 2, 201212 yr Author comment_3538 character_set_client cp1251 character_set_connection cp1251 character_set_database utf8 character_set_results cp1251 character_set_server cp1251 character_set_system utf8 В conf_global.php надо что-то прописывать?
May 3, 201212 yr Author comment_3595 __forums.modx.com/thread/63038/1055-1088-1086-1073-1083-1077-1084-1072-1089-1073-1091-1082-1074-1072-1084-1080-1048-1080-1096#dis-post-371987 Это как то можно применить к ipb?
May 3, 201212 yr comment_3601 в config_global.php найти: $INFO['sql_tbl_prefix'] = 'ibf_'; Ниже добавить: $INFO['sql_charset'] = 'utf8'; [/code]
May 4, 201212 yr Author comment_3632 прописываю в config_global.php $INFO['sql_charset'] = 'utf8'; выдает ошибку Your settings could not be read by IP.Board. This is a fatal error and IP.Board cannot function while this issue persists. This issue is generally caused by changing your character set in the ACP to one that does not support data stored in the rest of your settings, or by restoring a database backup/completing a server transfer and importing your database tables using the wrong character set or collation. You should contact IPS Technical Support for further assistance.[/code] если прописываю [CODE]$INFO['sql_charset'] = '';[/code] то отображается, но ошибки с "И" и "Ш" остаются!
May 4, 201212 yr comment_3647 Обязательно сделайте бекап БД. Судя по всему тут получился так называемый "дважды" utf-8 Скорее всего неотображаемые символы "побились" в самой БД и вас спасёт только замена обратно на читаемые. /* * Исправление кодировки букв "ш" и "И" в MYSQL * автор: Nc_Soft * 18.07.09 */ /* Частенько встречается при переносе бд, либо при шаманстве с кодировками буквы "ш" и "И" оказываются битыми (речь идет о utf-8 конечно) буква "ш" = chr(209).chr(63) / правильно chr(209).chr(136) буква "И" = chr(208).chr(63) / правильно chr(208).chr(152) Чтобы пофиксить делаем 2 запроса */ UPDATE `имя_таблицы` SET `поле` = REPLACE( `поле`, CONCAT( CHAR(209), CHAR(63) ), CONCAT( CHAR(209), CHAR(136) ) ); UPDATE `имя_таблицы` SET `поле` = REPLACE( `поле`, CONCAT( CHAR(208), CHAR(63) ), CONCAT( CHAR(208), CHAR(152) ) ); Например исправим буквы во всех сообщениях: это таблица posts и поле post, соответственно вам надо сделать два запроса: UPDATE `posts` SET `post` = REPLACE( `post`, CONCAT( CHAR(209), CHAR(63) ), CONCAT( CHAR(209), CHAR(136) ) ); и UPDATE `posts` SET `post` = REPLACE( `post`, CONCAT( CHAR(208), CHAR(63) ), CONCAT( CHAR(208), CHAR(152) ) ); Лучше всего это делать в phpMyAdmin, тк будет выведен результат запроса и станет понятно, исправляются символы или нет. Далее в ACP нужно удалить из Кеша все посты (сообщения). После этого эти буквы в сообщениях должны отображаться правильно. Отпишитесь о результатах на примере таблиц постов. Если все успешно - подскажу по таблицам, что и где править. Обязательно сделайте бекап БД.
May 5, 201212 yr Author comment_3691 Затронуто строк: 0 (запрос занял 0.0079 сек.) SQL-запрос: UPDATE `mba22m_posts` SET `post` = REPLACE( `post` , CONCAT( CHAR( 209 ) , CHAR( 63 ) ) , CONCAT( CHAR( 209 ) , CHAR( 136 ) ) ) ; Затронуто строк: 0 (запрос занял 0.0064 сек.) SQL-запрос: UPDATE `mba22m_posts` SET `post` = REPLACE( `post` , CONCAT( CHAR( 208 ) , CHAR( 63 ) ) , CONCAT( CHAR( 208 ) , CHAR( 152 ) ) ) ;
May 7, 201212 yr comment_3911 БД судя по результатам без ошибок. Надо смотреть настройки хостинга, имхо.
April 15, 201311 yr comment_27724 yanker,в админцентре: Поддержка --> Управление базой данных --> Значения системных настроек. Сравни свои переменные с теми, какие должны быть: Вот и я попал на эти Ш и И ! Проверил у меня так: character_set_client cp1251 character_set_connection cp1251 character_set_database cp1251 character_set_filesystem binary character_set_results cp1251 character_set_server cp1251 character_set_system utf8 character_sets_dir /.ro/usr/local/mysql/share/mysql/charsets/ collation_connection cp1251_general_ci collation_database cp1251_general_ci collation_server cp1251_general_ci Как исправить? Подскажите пожалуйста. Попробуй в conf_global.php прописать: @mysql_query("SET NAMES 'utf8'"); @mysql_query("SET collation_connection='utf8_general_ci'"); @mysql_query("SET collation_server='utf8_general_ci'"); @mysql_query("SET character_set_client='utf8'"); @mysql_query("SET character_set_connection='utf8'"); @mysql_query("SET character_set_results='utf8'"); @mysql_query("SET character_set_server='utf8'"); Куда это добавить? В смысле просто в конец? Или в начало? Edited April 15, 201311 yr by madbatman
April 16, 201311 yr comment_27775 Короче вот способ который помог мне: 1) Сливаем бд SypexDumper2) Распаковываем архив, открываем файл bla-bla-bla.sql текстовым редактором с поддержкой utf, например Bred3.3) Заменяем все вхождения CHARSET=cp1251 или CHARSET=winows-1251 на CHARSET=utf8.4) Файл -> Сохранить как... -> (Кодировка: utf8, Тип файла: Все файлы, и сохраняем в этот же файл.3) заливаем файл bla-bla-bla.sql обратно в папку бэкап и восстанавливаем в НОВУЮ базу из него SypexDumperом Edited April 16, 201311 yr by madbatman
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.