Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: функции INET_ATON, INET_NTOA

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
alexandr
Отправлено: 17 Декабря, 2009 - 04:19:09
Post Id



Новичок


Покинул форум
Сообщений всего: 10
Дата рег-ции: Июль 2009  


Помог: 0 раз(а)




Предыстория:
для регистрации на сайте создаем в mysql таблицу users(смотри рисунок).
В ней в столбце user_ip стоит преобразованный IP адрес клиента- по функции
INET_ATON(). INET_ATON(127.0.0.1)=2130706433 условно говоря.
Попытка с помощью запроса в пхп
преобразовать данное число обратно в IP с помощью функции INET_NTOA(user_ip) возвращает тоже самое число 2130706433. ????
Я уже запрос упростил донельзя
PHP:
скопировать код в буфер обмена
  1.  
  2. $query=mysql_query('SELECT *,INET_NTOA(user_ip) FROM users WHERE user_id =29');
  3. $userdata = mysql_fetch_assoc($query);
  4. echo $userdata['user_ip']."<br>";
  5.  

Однако в phpmyadmin все работает правильно, т.е.
запрос SELECT INET_NTOA(user_ip) FROM users WHERE user_id =29
выводит 127.0.0.1
Непонятно!
Прикреплено изображение (Нажмите для увеличения)
таблица.JPG

(Отредактировано автором: 17 Декабря, 2009 - 04:25:48)



-----
Есть более спокойные методы заработать на жизнь, чем forex.
 
 Top
OverNik
Отправлено: 17 Декабря, 2009 - 05:25:14
Post Id



Частый гость


Покинул форум
Сообщений всего: 182
Дата рег-ции: Янв. 2008  


Помог: 0 раз(а)




А так пытались? Ведь mysql_fetch_array и mysql_fetch_assoc не совсем похожи...
PHP:
скопировать код в буфер обмена
  1.  
  2. $query=mysql_query('SELECT *,INET_NTOA(user_ip) FROM users WHERE user_id =29');
  3. $userdata = mysql_fetch_array($query);
  4. echo $userdata['user_ip']."<br>";
  5.  

(Отредактировано автором: 17 Декабря, 2009 - 05:26:58)

 
 Top
Ch_chov
Отправлено: 17 Декабря, 2009 - 06:45:31
Post Id



Постоянный участник


Покинул форум
Сообщений всего: 2121
Дата рег-ции: Июль 2008  
Откуда: из города


Помог: 90 раз(а)




А почему вы решили что в $userdata['user_ip'] не должно находится 2130706433 ?


CODE (sql):
скопировать код в буфер обмена
  1. SELECT `user_id`, `user_login`, `user_password`, INET_NTOA(user_ip) AS `user_ip` FROM `users` WHERE `user_id` = 29
 
 Top
Champion Супермодератор
Отправлено: 17 Декабря, 2009 - 08:54:31
Post Id



Активный участник


Покинул форум
Сообщений всего: 4350
Дата рег-ции: Авг. 2008  
Откуда: Москва


Помог: 57 раз(а)




Ну-ка
CODE (sql):
скопировать код в буфер обмена
  1. SELECT user_ip, inet_ntoa(user_ip) FROM users LIMIT 10

и нам станет яснее.
 
 Top
Мелкий Супермодератор
Отправлено: 17 Декабря, 2009 - 11:35:22
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




OverNik пишет:
А так пытались? Ведь mysql_fetch_array и mysql_fetch_assoc не совсем похожи...

Ну как раз для ассоциативного массива mysql_fetch_assoc правильнее указывать.

alexandr, вы обращаетесь к исходному полю. Чтобы получить поле после выполнения функции, к нему обращаться и надо
PHP:
скопировать код в буфер обмена
  1. $query=mysql_query('SELECT *,INET_NTOA(user_ip) as ip FROM users WHERE user_id =29');
  2. $userdata = mysql_fetch_assoc($query);
  3. echo $userdata['ip']."<br>";


-----
PostgreSQL DBA
 
 Top
Champion Супермодератор
Отправлено: 17 Декабря, 2009 - 12:24:50
Post Id



Активный участник


Покинул форум
Сообщений всего: 4350
Дата рег-ции: Авг. 2008  
Откуда: Москва


Помог: 57 раз(а)




Да, alexandr, ты ж не указал алиаса никакого у inet_ntoa(user_ip). А обращаешься как раз к самому user_ip, а не к тому, что функция с ним сделала
 
 Top
alexandr
Отправлено: 17 Декабря, 2009 - 18:27:13
Post Id



Новичок


Покинул форум
Сообщений всего: 10
Дата рег-ции: Июль 2009  


Помог: 0 раз(а)




Не понял

Ch_chov попал в яблочко. Да вообше в $userdata['user_ip'] как раз и будет это число, другого не утверждал.

(Отредактировано автором: 17 Декабря, 2009 - 18:38:43)



-----
Есть более спокойные методы заработать на жизнь, чем forex.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« SQL и Архитектура БД »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB