Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
C++. Мастер-класс в задачах и примерах. Авторы: Кузнецов М.В., Симдянов И.В. Социальная инженерия и социальные хакеры. Авторы: Кузнецов М.В., Симдянов И.В. PHP Puzzles. Авторы: Кузнецов М.В., Симдянов И.В. PHP 5. На примерах. Авторы: Кузнецов М.В., Симдянов И.В., Голышев С.В. Объектно-ориентированное программирование на PHP. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

HTML+CSS+JavaScript

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: Кодировка сохранения в MySQL
 
 автор: kireyev   (28.06.2011 в 08:22)   письмо автору
 
 

javascritp, передающий данные в user_edit.php:
$.post('/user_edit.php',{name:name});


user_edit.php:
include_once "connect.php";
$name = str_replace('"','',json_encode ($_POST['name']));
mysql_query("
    UPDATE
        `user`
    SET
        `user`.`name` = '$name',
        `user`.`surname` = 'Иванов'
    WHERE
        `user`.`id` = '1'
    ");


При передаче $name в кириллице в БД записывается: u0412u0430u0441u044f (Вася)
При этом $surname нормально пишится в кириллице: Иванов

Видимо кодировка в javascript нарушается... Как быть?

  Ответить  
 
 автор: cheops   (28.06.2011 в 08:32)   письмо автору
 
   для: kireyev   (28.06.2011 в 08:22)
 

1) В какой кодировке скрипты?
2) В какой кодировке таблицы базы данных?
3) Какой SET NAME используется в connect.php?

  Ответить  
 
 автор: kireyev   (28.06.2011 в 08:36)   письмо автору
 
   для: cheops   (28.06.2011 в 08:32)
 

с 1-м не знаком, как определить-узнать-понять?
<meta http-equiv="content-type" content="text/html; charset=windows-1251"> ???
2. CP1251-general-ci
3. CP1251

  Ответить  
 
 автор: cheops   (28.06.2011 в 08:58)   письмо автору
 
   для: kireyev   (28.06.2011 в 08:36)
 

При AJAX лучше бы использовать UTF-8, кодируя данные перед отправкой и декодируя перед сохранением в базу данных. В противном случае нужно настраивать кодировку HTTP-заголовков, которые возвращает Web-сервер.

  Ответить  
 
 автор: kireyev   (28.06.2011 в 09:08)   письмо автору
 
   для: cheops   (28.06.2011 в 08:58)
 

Где копать незнающим?

  Ответить  
 
 автор: cheops   (28.06.2011 в 09:48)   письмо автору
 
   для: kireyev   (28.06.2011 в 09:08)
 

А что сделать хотите? Если перекодировать в UTF-8, то для этого идеально подойдет iconv(), если настроить кодировки Web-сервера, это лучше сделать через .htaccess и директиву AddDefaultCharset.

  Ответить  
 
 автор: kireyev   (28.06.2011 в 10:11)   письмо автору
 
   для: cheops   (28.06.2011 в 09:48)
 

Спасибо... Как раз нашел решение в iconv() на принимающем файле edit_user.php
$nickname = iconv("UTF-8","CP1251",$_POST['nickname']);

  Ответить  
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования