|
|
|
|
|
для: nikita2206
(12.06.2009 в 14:20)
| | Да нет вовсе.
Наплыв этого шаблона if(isset($_POST['name'])) $name = $_POST['name']; последнее время участился.
Хотелось ответить именно такими словами.
Правда вместо них лезли другие "Что ж ты делаешь, баран?! Ты же создаешь код, который в половине случаев оставляет переменную не инициализированной! О какой надежности после этого можно говорить?!" . А они здесь не приветствуются.
На всякий случай акцентирую, вышеприведенное - не Слонику персонально. Кодеров с таким подходом здесь десять на дюжину. | |
|
|
|
|
|
|
|
для: Trianon
(12.06.2009 в 10:47)
| | ммм сарказм | |
|
|
|
|
|
|
|
для: Slo_Nik
(12.06.2009 в 00:22)
| | Таким подходом Вы, фактически, низводите методы кодирования на php5 до уровня методов кодирования на php3. Со всеми вытекающими оргвыводами в плане надежности кода.
И только потому, что когда-то напоролись на старый (с лет пять не апгрейдившимся софтом) хостинг. | |
|
|
|
|
|
|
|
для: nikita2206
(12.06.2009 в 00:39)
| | >> if(isset($_POST['name'])) $name = $_POST['name'];
>... проверяем существует ли элемент массива $_POST под ключём name, далее если существует то создаётся переменная $name, но заметте, если не существует, то $name не создаётся, если есть логика, то несложно понять, что это действие не имеет ни какой практической пользы, разве что, переменная теперь с более коротким именем…
>тогда, я думаю, было бы гораздо разумней написать, например, так:
>$name = @$_POST['name'];
Золотая мысль.
Почему-то большинству здесь активно присутствующих в голову не приходит. | |
|
|
|
|
|
|
|
для: scva
(12.06.2009 в 00:25)
| | нет не так, и еще, используйте по возможности одинарные кавычки вместо двойных и соответственно конкатенацию…
вот так правильно:
<?
mysql('INSERT INTO `order` ( `id` , `name` )VALUES ('.$id.', "'.$_POST['soname'].'")');
|
P.S. хорошо хоть то, что используете наклонные кавычки в mysql) | |
|
|
|
|
|
|
|
для: Slo_Nik
(12.06.2009 в 00:22)
| | я думаю вы заблуждаетесь и не нашли реальной причины проблемы…
просто смотрите что сдесь делается: сначала проверяем существует ли элемент массива $_POST под ключём name, далее если существует то создаётся переменная $name, но заметте, если не существует, то $name не создаётся, если есть логика, то несложно понять, что это действие не имеет ни какой практической пользы, разве что, переменная теперь с более коротким именем…
тогда, я думаю, было бы гораздо разумней написать, например, так:
$name = @$_POST['name'];
или, если уж заняться нечем, то так:
$name = array_key_exist($_POST, 'name') ? $_POST['name'] : exit('Some variables was not submited to this script.'); | |
|
|
|
|
|
|
|
для: scva
(12.06.2009 в 00:25)
| | попробуй так сделать и тебе выдаст ошибку | |
|
|
|
|
|
|
|
для: nikita2206
(12.06.2009 в 00:14)
| | INSERT INTO `order` ( `id` , `name` )VALUES ('$id','$_POST['soname']') так что ли | |
|
|
|
|
|
|
|
для: nikita2206
(12.06.2009 в 00:14)
| | легче конечно использовать $_POST['name'], но есть возможность, что на некоторых хостах может не сработать.
а вот
<?php
if(isset($_POST['name'])) $name = $_POST['name'];
?>
|
сработает всегда.
я с такой фигнёй раз столкнулся. | |
|
|
|
|
|
|
|
для: scva
(12.06.2009 в 00:09)
| | я тебе привёл пример запроса.
определить переменные естественно надо до запроса.
в начале ты используешь короткие теги "<? ?>", а потом "<?php ?>", сделай одинаково | |
|
|
|
|