веб-кодизм: на клиенте utf-8, шлём POST-запрос в *php...

php веб-программирование обработка utf-8 веб-кодирование

я понимаю у большинства - утро субботы - никого нет в "живых", но всё-таки......

Короче на клиенте страница с UTF-8 кодировкой, клиент вбивает данные на родном языке, данные после JS-функции escape() летят POST-запросом в PHP и приходят в него в виде ".......%u043D%u043D%u043D...." - с точки зрения PHP - мультибайтная кодировка (и это так и есть).
Я до того как узнал про функции mb_.....() сделал целый блок, который вручную перекодировал мультибайты в буквы, но это всё-таки идиотизм, т.к. делаем мультиязычность и на все языки спец-блоки писать - тупо.

Подскажите кто-нибудь пожалуйста - чем мультиязычно перекодить входящую кашу в буквы и символы?
Задача при обработке - вычленить в пришедших данных теги и запрещённые символы, всё остальное полетит в БД.

Хостинг на Линуксе, и локалхост тоже, дома локаль utf-8, на хостере наверное локаль вынь1251 (судя по идиотской просьбе хостера делать всё на этой кодировке), но не факт. Что там внутреннее в роли кодировки у PHP я не знаю.

И да - я не прошу писать за меня код. Прошу подсказать советами как мне правильно обработать мультиязычные данные в кодировке UTF-8.

Примечание:
и да теги хотелось убирать обычными PHP-функциями, да и всю остальную обработку тоже... Понятно что можно написать всё в виде if+strpos+substr и прочая, но это ж "не наш метод"....

Примечание:
Елена Левина: а разве есть аналоги strip_tags() для мультибайтных кодировок?
И непонятно как возъюзать mb_ereg_replace() чтобы отыскать там допустим строчку:
\n - [^a-z]
(как пример! пишу сонным мозгом уже)) )

Примечание:
Скажите хотя-бы - mb_ereg_replace() латиницу и символы сам найдёт в мультибайтной каше??

Примечание:
Елена Левина: и у хостера и у меня - PHP-5 более или менее свежие, с этим всё норм

Примечание:
to Leax and Dexif БЛАГОДАРЮ ВАС за ответы!!!

сонной головой таки сразу всё не прокомментирую - прошу простить!!!
Насчёт iconv - э-э.. есть-же PHP-шная ф-я преобразования кодировок? mb_convert_encoding()
Насчёт кодировки скриптов - всё в 1251, но по include подгружаю и utf-8.
В тех, что в 1251 - только латиница. (в т.ч. комменты) В тех что utf-8 - самые разные символы разных языков.
Думаю, если перевести все скрипты в utf-8 ничего не изменится - хостинг всё "кушает" нормально, не кашляет.
Весь код пишется тоже в Linux-е ессно. Виндовс тут рядом не валялся, если не считать упоминание хостером вендозной кодировки. Так - везде Linux.

Примечание:
БЛАГОДАРЮ всех, кто ответил и помог мне в разрешении задачи!

Leax!!! Отдельно благодарю ВАС за помощь!!! Именно Ваш ответ стал ключевым.
(долго-ж я я переваривал всю инфу - то ли старею, то ли действительно тема такая непростая - utf8+многоязычность+безопасность )) )

Всем:
mb_internal_encoding("UTF-8"); почему-то не работает на моём локалхосте, соответственно нет возможности и что-либо проверять с этой функцией.
mb_regex_encoding("UTF-8"); эта функция должна лишь возвращать кодировку, используемуюдля mb_-функций. Тоже не работает.

ОДНАКО при этом система нормально работает в регулярках с mb-кодировкой UTF-8.
Я сделал так: с клиента летит из encodeURIComponent, на сервере преобразовываем с помощью urldecode. После этого string-переменная нормально прогоняется через strip_tags(). После чего, для пущей надёжности прогоняю через htmlspecialchars()
На хостинге тоже всё работает.
Ответы:
так а чем не устраивают обычные mbstring-функции?
хостинг-то их поддерживает?
Здравствуйте.
Сначала немного теории.
Для организации нужной Вам escape-последовательности можно использовать одну из 3 ф-й JavaScript:
- escape
- encodeURI
- encodeURIComponent
> Скажите хотя-бы - mb_ereg_replace() латиницу и символы сам найдёт в мультибайтной каше??
Кстати насчёт кодировки самих скриптов...
В винде очень сложно работать с юникодом по крайней мере в XP незнаю как там в гламурных вистах и семёрках...
У меня была проблема когда перешёл на linux... решил все скрипты свои перевести в юникод... но начал переводить в винде... (там написал что всё удачно преобразовано...) грузанувшись в линукс (где юникод - родной) я понял что винда всёже скрипты сохранила в какой-то смеси кодировок... пришлось повозится с этим...
и ещё... iconv это конечно круто... но если будет много запросов - то получится большая нагрузка на сервак... ибо преобразование кодировок само по себе для сервера дело не очень лёгкое... проще и выгоднее преобразовать все скрипты в utf-8..
преобразование кодировок в линухе описано здесь: http://exgraphics.info/index.php?modules=shownews&id=295
вместо escape() в js используйте encodeURIComponent()
Хм... смешение кодировок в 1 проекте - не правильный путь... то что хостер рекомендует или просит... - это не всегда правильно... а иногда это даже смешно когда на хосте стоит linux просить использовать 1251...
не понял в чём проблема то
посетитель шлёт вам данные в UTF-8 вы из сохраняете в UTF-8 и выдаёте в таком же виде
все допольны и ничего не нужно конвертировать


16 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.