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

Форум PHP

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

 

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

вид форума:
Линейный форум (новые сообщения вниз) Структурный форум

тема: проверка на вредность вводимых значений пользователем

Сообщения:  [1-10]   [11-14] 

 
 автор: Slo_Nik   (05.01.2012 в 21:28)   письмо автору
 
   для: Василий   (05.01.2012 в 21:15)
 

всё надо к месту проверять/экранировть/всячески обрабатывать
если у Вас данные из массива get не идут в базу, то и не надо их обрабатывать mysql_real_escape_string()
если Вы получаете в get данные от пользователя и хотите вывести их на странице, то возможно будет достаточно обработать функцией htmlspecialchars() если это строки и intval() если это число

<?php 
// для вывода в браузер, это касается и данных из БД, которые вносил туда пользователь
$title = isset($_GET['title']) ? htmlspecialchars($_GET['title']) : null;
// для записи в БД
$title = isset($_POST['title']) ? mysq_real_escape_string($_POST['title']) : null// или то значение, которое по умолчанию назначено полю в БД
// хотя я делаю обработку прямо в запросе к БД,
$query sprintf("INSERT INTO `table`  (`title`) VALUES('%s')"mysql_real_escape_string($title));

  Ответить  
 
 автор: Василий   (05.01.2012 в 21:15)   письмо автору
 
   для: cheops   (05.01.2012 в 20:51)
 

если мы

первая проверка:
if  (isset($_POST['title']))         {$title = $_POST['title']; if ($title == '') {unset ($title);}  }
if  (isset($_POST['id_pu']))          {$id_pu = $_POST['id_pu']; if ($id_pu == '') {unset ($id_pu);}}


вторая проверка:
$_GET['id_pu'] = intval($_GET['id_pu']);
$_GET['title'] = mysql_escape_string($_GET['title']); 


потом заносим в БД
$result = mysql_query ("insert pu SET title='$title', id_pu=" . mysql_real_escape_string($id_pu) . " 


то не пойму для чего вторая проверка? $_GET['id_pu'], $_GET['title'] никак не используется при внесении в базу

  Ответить  
 
 автор: cheops   (05.01.2012 в 20:51)   письмо автору
 
   для: Василий   (05.01.2012 в 20:48)
 

В общем да... только false - это преобразуется в пустую строку, может быть не удобно следить. Немного выше приведена конструкция типичного использования этой функции
<?php 
  
if (!get_magic_quotes_gpc()) 
  { 
    
$_GET['text'] = mysql_escape_string($_GET['text']); 
  } 
?>
Расшифровывается это так - если режим отключен - осуществляем экранирование, если включен - ничего не делаем.

  Ответить  
 
 автор: Василий   (05.01.2012 в 20:48)   письмо автору
 
   для: cheops   (05.01.2012 в 20:38)
 

вот достаточно будет узнать?
<?php
echo get_magic_quotes_gpc(); ?>

  Ответить  
 
 автор: cheops   (05.01.2012 в 20:39)   письмо автору
 
   для: Василий   (05.01.2012 в 20:35)
 

mysql_escape_string() экранирует кавычки, после того, как вы пропустите целочисленное значение через функцию intval() там останутся только цифры - нечего экранировать... можете пропустить и их через mysql_escape_string() для единообразия, но это лишняя работа.

  Ответить  
 
 автор: cheops   (05.01.2012 в 20:38)   письмо автору
 
   для: Василий   (05.01.2012 в 20:34)
 

>как узнать включен ли режим "магических кавычек" на сервере?
Для этого используется функция get_magic_quotes_gpc() - она возвращает true, если режим включен, и false в противном случае.

  Ответить  
 
 автор: Василий   (05.01.2012 в 20:35)   письмо автору
 
   для: Василий   (05.01.2012 в 20:34)
 

почему Вы не предложили целочисленные значения пропускать через функцию mysql_escape_string?

  Ответить  
 
 автор: Василий   (05.01.2012 в 20:34)   письмо автору
 
   для: cheops   (05.01.2012 в 20:27)
 

как узнать включен ли режим "магических кавычек" на сервере?

  Ответить  
 
 автор: cheops   (05.01.2012 в 20:27)   письмо автору
 
   для: Василий   (05.01.2012 в 20:24)
 

Если режим "магических кавычек" на сервере отключен, а код не будет использоваться на других серверах, где он может быть включен, да, правильно.

  Ответить  
 
 автор: Василий   (05.01.2012 в 20:24)   письмо автору
 
   для: cheops   (05.01.2012 в 20:10)
 

ТОгда так

первая проверка:
if  (isset($_POST['title']))         {$title = $_POST['title']; if ($title == '') {unset ($title);}  }
if  (isset($_POST['id_pu']))          {$id_pu = $_POST['id_pu']; if ($id_pu == '') {unset ($id_pu);}}


вторая проверка:
$_GET['id_pu'] = intval($_GET['id_pu']);
$_GET['title'] = mysql_escape_string($_GET['title']); 

потом заносим в БД
$result = mysql_query ("insert pu SET title='$title', id_pu=" . mysql_real_escape_string($id_pu) . "


Правильно?

  Ответить  

Сообщения:  [1-10]   [11-14] 

Форум разработан IT-студией SoftTime
Rambler's Top100
вверх

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