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 :: Html тэги

 PHP.SU

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


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

> Без описания
Reniksa
Отправлено: 13 Января, 2011 - 11:30:39
Post Id



Новичок


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


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




Здравствуйте. У меня есть скрипт добавления новости на сайт.
Для того чтобы сохранить отступы, я использую функцию nl2br. В общем вот:

CODE (html):
скопировать код в буфер обмена
  1. Текст новости:<br/>
  2. <textarea name="text" id="text" rows=8 cols=70></textarea>
  3. <br/>


после этого значение обрабатывается функцией clear и заносится в базу данных вместе с остальными полями

PHP:
скопировать код в буфер обмена
  1. $text = clear($_POST['text']);
  2. $query = ("INSERT INTO tnews VALUES(NULL,'".$heading."','".$title."','".$subtitle."','".$text."','".$author."','".$img_url."','".$date."','0')");


PHP:
скопировать код в буфер обмена
  1. function clear($string) {
  2. if(strlen($string)==0) { return FALSE; }
  3. else {return nl2br(addslashes(trim($string)));}
  4. }


Но есть возможность поправить новость. А в базу данных уже записана новость с тэгами переноса строки, и в итоге при правке, в поле уже отображается новость с этими тэгами, а при изменении они дублируются. И это происходит при каждом изменении. Как быть? Надеюсь описала не очень скомкано.

PHP:
скопировать код в буфер обмена
  1. $q4 = @mysql_query("SELECT * FROM tnews WHERE id='".$id."'");


CODE (htmlphp):
скопировать код в буфер обмена
  1. Описание новости:<br/>
  2. <textarea name="text" id="text" rows=20 cols=70>'.$r['news'].'</textarea>
 
 Top
Uchkuma
Отправлено: 13 Января, 2011 - 14:52:34
Post Id



Участник


Покинул форум
Сообщений всего: 1539
Дата рег-ции: Март 2010  
Откуда: Киров


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




nl2br надо использовать при выводе на страницу, а не при записи в базу.
 
 Top
Reniksa
Отправлено: 13 Января, 2011 - 19:00:07
Post Id



Новичок


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


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




Спасибо большое, как-то я сама не подумала.
 
 Top
antobra
Отправлено: 13 Января, 2011 - 19:43:01
Post Id


Посетитель


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


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




разрешите вопрос, что значит собачка тут

PHP:
скопировать код в буфер обмена
  1. $q4 = @mysql_query("SELECT * FROM tnews WHERE id='".$id."'");


?
 
 Top
Саныч Модератор
Отправлено: 13 Января, 2011 - 19:50:41
Post Id



Участник


Покинул форум
Сообщений всего: 1365
Дата рег-ции: Июль 2010  
Откуда: Украина, Запорожье


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




игнорирует ошибки


-----
Все возражают против того, что я гений, хотя никто еще так меня не назвал. - Орсон Уэллс
 
 Top
antobra
Отправлено: 13 Января, 2011 - 20:17:33
Post Id


Посетитель


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


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




Саныч пишет:
игнорирует ошибки


спасибо
 
 Top
OrmaJever Модератор
Отправлено: 13 Января, 2011 - 20:37:31
Post Id



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


Покинул форум
Сообщений всего: 7540
Дата рег-ции: Янв. 2010  
Откуда: Чернигов


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




antobra пишет:
что значит собачка тут

дурной тон в програмировании


-----
Если вы хотя бы 3-4 раза не решите всё выкинуть и начать заново - вы явно что-то делаете не так.
 
 Top
JustUserR
Отправлено: 14 Января, 2011 - 14:51:10
Post Id



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


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


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




Reniksa пишет:
@mysql_query("SELECT * FROM tnews WHERE id='".$id."'");
Предполагаемая форма строковой константы целевого SQL-запроса и интерполируемых в нее значений переменных в общем случае не является безопасной - по причине отсутсивя контроля уровня трактовки вложенных интерполируемых значений относительно управляющих и граничных элементов - в случае если ключевое поле является целочисленным то для него необходимо применение функции intval


-----
Сделать можно все что угодно - нужно только старание, терпение и хороший поисковик Улыбка
Безлимитный web-хостинг от 15 рублей за 40 МБ дискового пространства - http://ihost[dot]oks71[dot]ru/
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Программирование на PHP »


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



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

 
Powered by ExBB FM 1.0 RC1. InvisionExBB