Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.93/98: Рейтинг темы: голосов - 98, средняя оценка - 4.93
0 / 0 / 0
Регистрация: 07.07.2012
Сообщений: 24

Кодировка при передаче данных методом GET

22.07.2012, 13:37. Показов 19985. Ответов 17
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет! Есть проблема следующего рода...

Вписываю в адресную строку браузера: http://prime/qwe.php?text=привет

qwe.php:
PHP
1
2
3
4
5
6
if (isset($_GET['text']))
{
$Text = $_GET['text'];
 
mysql_query("INSERT INTO `table1` VALUES ('', '{$Text}')");
}
Проблема в том что в таблицу значение $_GET['text'] не записывается вместо него пустота. Выяснил что проблема в кодировке так как $_GET['text'] не UTF-8 а база и таблица в UTF-8.

Как решить проблему?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
22.07.2012, 13:37
Ответы с готовыми решениями:

кодировка при передаче POST
Здравствуйте. Передаю форму post методом, после передачи за место русских букв получается что-то вроде %D1%8B%D0%B2%D0% . В чем дело не...

Кодировка данных при считывании их из input методом serialize() jQuery
Доброго времени суток! Ситуация следующая: пытаюсь организовать обновление данных в базе. Для этого получаю поиском в форму с input...

Кодировка символов при передаче в COM-порт
Собственно проблема в том, что при попытке оправить строку в порт получаю точки между символами, а при выводе в Message.Show все правильно....

17
Почетный модератор
Эксперт HTML/CSSЭксперт PHP
 Аватар для KOPOJI
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
22.07.2012, 14:04
в начале скрипта
PHP
1
header("Content-type: text/html; charset=utf-8");
в .htaccess прописать
Bash
1
 AddDefaultCharset UTF-8
сразу после установления соединения с сервером мускула
MySQL
1
mysql_query("SET NAMES utf8");
и должно быть все нормально
0
0 / 0 / 0
Регистрация: 07.07.2012
Сообщений: 24
22.07.2012, 16:02  [ТС]
Цитата Сообщение от KOPOJI Посмотреть сообщение
в начале скрипта
PHP
1
header("Content-type: text/html; charset=utf-8");
в .htaccess прописать
Bash
1
 AddDefaultCharset UTF-8
сразу после установления соединения с сервером мускула
MySQL
1
mysql_query("SET NAMES utf8");
и должно быть все нормально
В том то и дело что всё это есть.
0
Почетный модератор
Эксперт HTML/CSSЭксперт PHP
 Аватар для KOPOJI
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
22.07.2012, 16:06
1. попробуй сначала просто вывести
PHP
1
 var_dump($Text);
2. mod_rewrite пашет?
3. если все ок - вывести текст запроса...
PHP
1
var_dump("INSERT INTO `table1` VALUES ('', '{$Text}')");
0
0 / 0 / 0
Регистрация: 07.07.2012
Сообщений: 24
22.07.2012, 16:20  [ТС]
Вот при передаче AJAX`ом передаётся заголовок с кодировкой:

JavaScript
1
2
Request.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8');
Request.send('text=' + encodeURIComponent(text));
Поэтому всё ОК. А когда обращаешься через адресную строку то текст в кодировке windows-1251 видимо это браузер отправляет этот заголовок автоматически.

Так вот как мне тогда сделать так чтобы скрипт qwe.php принимал всегда в UTF-8 ? Проблема...

Добавлено через 6 минут
Цитата Сообщение от KOPOJI Посмотреть сообщение
1. попробуй сначала просто вывести
PHP
1
 var_dump($Text);
2. mod_rewrite пашет?
3. если все ок - вывести текст запроса...
PHP
1
var_dump("INSERT INTO `table1` VALUES ('', '{$Text}')");
var_dump($Text):

HTML5
1
string(6) "������"
mod_rewrite пашет!

PHP
1
var_dump("INSERT INTO `table1` VALUES ('', '������')");
Добавлено через 2 минуты
Короче вместо � квадратики

Добавлено через 2 минуты
Если сделать так:

PHP
1
$Text = iconv("windows-1251", "UTF-8", $Text);
то:

string(12) "привет"
0
Почетный модератор
Эксперт HTML/CSSЭксперт PHP
 Аватар для KOPOJI
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
22.07.2012, 17:26
ну так и переводи перед запросом
0
91 / 91 / 13
Регистрация: 14.07.2012
Сообщений: 539
22.07.2012, 17:44
DFS_i, строчка должна кодироваться функцией urlencode
0
0 / 0 / 0
Регистрация: 07.07.2012
Сообщений: 24
22.07.2012, 17:58  [ТС]
Цитата Сообщение от KOPOJI Посмотреть сообщение
ну так и переводи перед запросом
Да это тупость кодировать каждый переданный параметр да и может быть так что кодировка будет НЕ windows-1251

Добавлено через 7 минут
Цитата Сообщение от pyramida Посмотреть сообщение
DFS_i, строчка должна кодироваться функцией urlencode
Делаю запрос: http://prime/qwe.php?text=%EF%F0%E8%E2%E5%F2

PHP
1
2
3
4
5
6
7
8
header('Content-type: text/html; charset=UTF-8');
 
if (isset($_GET['text']))
{
$Text = $_GET['text'];
 
var_dump($Text);
}
Результат:

string(6) "������"

string(6) говорит о том что это не UTF-8 потому что если бы строка была в UTF-8 то было бы string(12) и квадратиков небыло бы.

Какие ещё предложения есть?
0
 Аватар для Vovan-VE
13210 / 6599 / 1041
Регистрация: 10.01.2008
Сообщений: 15,069
22.07.2012, 18:03
Цитата Сообщение от DFS_i Посмотреть сообщение
А надо было ?text=%D0%BF%D1%80%D0%B8%D0%B2%D0%B5%D1% 82 .
0
 Аватар для c4boomb
198 / 166 / 23
Регистрация: 20.04.2011
Сообщений: 750
Записей в блоге: 1
22.07.2012, 18:35
Загуглил за 5 мин, может поможет.
PHP
1
2
3
4
5
6
7
8
9
10
11
12
 function detectUTF8($string)
 {
 return preg_match('%(?:
 [\xC2-\xDF][\x80-\xBF] # non-overlong 2-byte
 |\xE0[\xA0-\xBF][\x80-\xBF] # excluding overlongs
 |[\xE1-\xEC\xEE\xEF][\x80-\xBF]{2} # straight 3-byte
 |\xED[\x80-\x9F][\x80-\xBF] # excluding surrogates
 |\xF0[\x90-\xBF][\x80-\xBF]{2} # planes 1-3
 |[\xF1-\xF3][\x80-\xBF]{3} # planes 4-15
 |\xF4[\x80-\x8F][\x80-\xBF]{2} # plane 16
 )+%xs', $string);
 }
0
0 / 0 / 0
Регистрация: 07.07.2012
Сообщений: 24
22.07.2012, 20:53  [ТС]
Цитата Сообщение от c4boomb Посмотреть сообщение
Загуглил за 5 мин, может поможет.
PHP
1
2
3
4
5
6
7
8
9
10
11
12
 function detectUTF8($string)
 {
 return preg_match('%(?:
 [\xC2-\xDF][\x80-\xBF] # non-overlong 2-byte
 |\xE0[\xA0-\xBF][\x80-\xBF] # excluding overlongs
 |[\xE1-\xEC\xEE\xEF][\x80-\xBF]{2} # straight 3-byte
 |\xED[\x80-\x9F][\x80-\xBF] # excluding surrogates
 |\xF0[\x90-\xBF][\x80-\xBF]{2} # planes 1-3
 |[\xF1-\xF3][\x80-\xBF]{3} # planes 4-15
 |\xF4[\x80-\x8F][\x80-\xBF]{2} # plane 16
 )+%xs', $string);
 }
Я так понял что эта функция определяет в UTF-8 ли строка так ведь?

Добавлено через 30 секунд
И как она мне может помочь?
0
 Аватар для c4boomb
198 / 166 / 23
Регистрация: 20.04.2011
Сообщений: 750
Записей в блоге: 1
22.07.2012, 21:08
ты проверяеш строка ютф или нет , если нет конвертируеш в ютф ))
0
0 / 0 / 0
Регистрация: 07.07.2012
Сообщений: 24
22.07.2012, 21:22  [ТС]
Цитата Сообщение от c4boomb Посмотреть сообщение
ты проверяеш строка ютф или нет , если нет конвертируеш в ютф ))
Я тоже об этом подумал, но вот в чём беда... для того чтобы перекодировать в UTF-8 нужно знать в какой кодеровке строка.

PHP
1
$Text = iconv("windows-1251", "UTF-8", $Text);
А если она НЕ в windows-1251 а в другой?
0
Почетный модератор
Эксперт HTML/CSSЭксперт PHP
 Аватар для KOPOJI
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
22.07.2012, 21:28
http://www.php.net/manual/ru/f... coding.php

Добавлено через 2 минуты
вообще urldecode() должна нормально справляться с этим..
0
0 / 0 / 0
Регистрация: 07.07.2012
Сообщений: 24
22.07.2012, 21:36  [ТС]
Цитата Сообщение от KOPOJI Посмотреть сообщение
http://www.php.net/manual/ru/f... coding.php

Добавлено через 2 минуты
вообще urldecode() должна нормально справляться с этим..
О, и я только что на mb_detect_encoding наткнулся ))) буду пробовать... Спасибо. Если чё напишу ещё...
0
Почетный модератор
Эксперт HTML/CSSЭксперт PHP
 Аватар для KOPOJI
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
22.07.2012, 21:45
для нее должен быть установлен модуль mb_string (Multi byte string)
0
0 / 0 / 0
Регистрация: 07.07.2012
Сообщений: 24
22.07.2012, 22:03  [ТС]
Цитата Сообщение от KOPOJI Посмотреть сообщение
http://www.php.net/manual/ru/f... coding.php

Добавлено через 2 минуты
вообще urldecode() должна нормально справляться с этим..
PHP
1
2
3
4
5
6
7
8
if (isset($_GET['text']))
{
$Text = $_GET['text'];
 
echo mb_detect_encoding($Text)."<br/>";
 
var_dump($Text);
}
Результат:

UTF-8
string(6) "������"
0
Почетный модератор
Эксперт HTML/CSSЭксперт PHP
 Аватар для KOPOJI
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
22.07.2012, 22:15
значит у вас кодировка самого файла windows-1251 или не прописан header,meta и в .htaccess пусто насчет кодировки (или наоборот, windows-1251)

Добавлено через 59 секунд
у меня вообще без всяких там urldecode и т.п. нормально выводит русский текст из адресной строки через $_GET(кодировка везде utf-8)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
22.07.2012, 22:15
Помогаю со студенческими работами здесь

Кодировка при передаче из динамического окна
Ситуация: Форма заполнения рисуется локальным ява скриптом function SmsForm(to,name,text){ s='&lt;html&gt;&lt;META...

Кодировка в при передаче текста виджету через setText()
Динамически создается объект (QWidget) При его создании динамически добавляется текст функцией setText(). Текст добавляется на русском. ...

Выводит ошибку при передаче переменной методом $_GET
Вот у меня выводится содержимое каталога, каждый файл это ссылка, ну по коду поймете что она делает: &lt;?php $dir =...

При передаче значения методом GET слетает оформление CSS
Здравствуйте! Ситуация такая. На одной странице, назовем ее index.php, присутствует ссылка такого вида: &lt;a...

Обрезается строка запрос при передаче параметров методом get
Здравствуйте! Я пишу asp.net приложение, которому при вызове должны передаватся много параметров методом get. И гдето видимо стоит...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
18
Ответ Создать тему
Новые блоги и статьи
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 05.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 17.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru