Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.83/29: Рейтинг темы: голосов - 29, средняя оценка - 4.83
0 / 0 / 0
Регистрация: 06.06.2016
Сообщений: 22

Добавление комментария на отдельной странице со статьей

16.10.2016, 11:47. Показов 6210. Ответов 52
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет! Я тут новичок но у меня возникла одна проблема. Хочу создать "Добавление комментария на отдельной странице со статьей", но не получается. Как сделать так чтобы например можно было добавлять коммент по айдишник статьи, я сделал но не получается.
ПОДСКАЖИТЕ ПОЖАЛУЙСТА, заранее спасибо
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
16.10.2016, 11:47
Ответы с готовыми решениями:

Сделать, чтобы то, что выводит php в отдельной странице, выводил в диалоговом окне на главной странице
Есть форма <form method=post action=/preorder.php> <div class="row half"> <div class=6u> <input name=name placeholder="Имя"...

Добавление комментария в файл
В файле находится скрипт. Создать выходной файл, в который переписать содержимое исходного кода, добавив в конце каждой строчки комментарий...

Добавление комментария макросом
Ребят....сделал, чтобы к ячейке строки циклом привязывались комментарии с картинками. но размеры маленькие.приходиться руками в настройках...

52
Почетный модератор
Эксперт по компьютерным сетямЭксперт Windows
 Аватар для magirus
28049 / 15785 / 983
Регистрация: 15.09.2009
Сообщений: 67,752
Записей в блоге: 78
16.10.2016, 11:49
выкладывай что сделал. форумчане поправят.
0
Эксперт PHP
5755 / 4134 / 1508
Регистрация: 06.01.2011
Сообщений: 11,276
16.10.2016, 11:59
Цитата Сообщение от Mr CaT Посмотреть сообщение
сделать так чтобы например можно было добавлять коммент по айдишник статьи
Обычная связка "один ко многим". В таблице "comments" добавляете поле "article_id" и пишете туда ID статьи из таблицы "articles". И "foreign key" с "on delete cascade" установите на поле "article_id", чтобы при удалении статьи не нужно было вручную удалять комментарии, относящиеся к ней.
0
0 / 0 / 0
Регистрация: 06.06.2016
Сообщений: 22
16.10.2016, 15:40  [ТС]
Но как сделать так чтобы по `article_id` добавлялись комменты именно к этой статьи?
Я вставил
HTML5
1
<input type="hidden" name="article_id">
и
PHP
1
2
3
4
5
if(isset($_POST["add"])) {
    $article_id = $_POST["article_id"];
    $comment = $_POST["comment"];
    $name  = $_POST["name"];
}
Что дальше делать подскажите, я PHP нормально понимаю, но с этим у меня проблема
0
94 / 94 / 68
Регистрация: 26.03.2015
Сообщений: 248
16.10.2016, 17:15
Цитата Сообщение от Mr CaT Посмотреть сообщение
Что дальше делать подскажите
Устанавливаете соединение с базой данных, экранируете спецсимволы в comment и name, проверяете, что статья с идентификатором article_id существует, добавляете новую запись в таблицу с комментариями, закрываете соединение с базой данных, делаете редирект на статью с article_id.
Если будут вопросы, пишите
0
0 / 0 / 0
Регистрация: 06.06.2016
Сообщений: 22
16.10.2016, 19:47  [ТС]
Все сделал но комментарий добавляется во всех статья, а мне надо чтобы на отдельных статьях были отдельные комментарии
0
 Аватар для fanatikus
1932 / 1523 / 703
Регистрация: 17.11.2012
Сообщений: 6,585
16.10.2016, 22:13
Цитата Сообщение от Mr CaT Посмотреть сообщение
<input type="hidden" name="article_id">
а value где?
HTML5
1
<input type="hidden" name="article_id" value="<?php echo $article_id;?>">
Добавлено через 1 минуту
Цитата Сообщение от Mr CaT Посмотреть сообщение
Все сделал
и вы думаете, что нам видно что вы там сделали?
0
930 / 846 / 190
Регистрация: 28.11.2013
Сообщений: 3,621
16.10.2016, 22:43
Цитата Сообщение от Mr CaT Посмотреть сообщение
Все сделал но комментарий добавляется во всех статья, а мне надо чтобы на отдельных статьях были отдельные комментарии
Вы должны выводить на странице (страницах) статьи только относящиеся к ней комментарии. Например после такой выборки:
SQL
1
2
3
4
5
6
SELECT `site_comments`.*,`site_author`.`id` `author_id`,`site_author`.`name` `author_name`
FROM `site_comments`
LEFT JOIN `site_author` USING (`author`)
WHERE `article_id`={$page['article_id']} AND `published`
ORDER BY `time`
LIMIT {($pn-1)*$pp},{$pp}
author_id – это слаг автора для аватара и т.п. Если не нужен, можете убрать. Числовой id автора находится в поле author, если не понятно.
0
0 / 0 / 0
Регистрация: 06.06.2016
Сообщений: 22
17.10.2016, 11:53  [ТС]
А переменная $pp откуда появилась?
И стоит написать
HTML5
1
<input type="hidden" name="article_id" value="<?php echo $article_id;?>">
0
930 / 846 / 190
Регистрация: 28.11.2013
Сообщений: 3,621
17.10.2016, 13:00
$pn и $pp – это т.с. условные обозначения. Последняя строка нужна только для многостраничных или подгружаемых порциями комментариев. $pn – номер страницы/порции, $pp – макс. кол-во комментариев на странице/в порции.

Добавлено через 8 минут
Цитата Сообщение от Mr CaT Посмотреть сообщение
И стоит написать
Стоит, если требуется. Если POST-обработчик встраивается в каждую статейную страницу, то скрытое поле без надобности. Числовой id статьи и прочее определяются точно также, как при GET-запросе. Кстати, это же дает автоматический контроль идентификатора – не нужно отдельно проверять его корректность.
0
0 / 0 / 0
Регистрация: 06.06.2016
Сообщений: 22
17.10.2016, 15:26  [ТС]
Notice: Undefined variable: id in A:\home\dvizhok.ru\oop\comment.php on line 35
[Денвер: показать возможную причину ошибки]
Notice: Undefined variable: page in A:\home\dvizhok.ru\oop\comment.php on line 27

Notice: Undefined variable: pn in A:\home\dvizhok.ru\oop\comment.php on line 27

Notice: Undefined variable: pp in A:\home\dvizhok.ru\oop\comment.php on line 27

Notice: Undefined variable: pp in A:\home\dvizhok.ru\oop\comment.php on line 27

Вот ошибка, а вот код:
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
<?php
    ini_set("display_errors", 1);
    error_reporting(E_ALL);
 
    /* The Comment Class */
    class Comment {
        
        private $mysqli;
        
        private static $mycomment = null; //It's means that I can add more and more comments
        
        /* Connecting... */
        
        public function __construct() {
            $this->mysqli = new Mysqli('localhost', 'root', '', 'cms');
            $this->mysqli->query("SET NAMES 'utf8'");
        }
        
        public static function getComment() {
            if(self::$mycomment === null) self::$mycomment = new Comment();
            return self::$mycomment;
        }
        
                    /*Comment Functions*/
        public function viewComment($name, $comment)
        {
            $this->mysqli->query("SELECT `text_comment``.*.`id`,`name` FROM `articles` LEFT JOIN `text_comment`` USING (`name`) WHERE `article_id`={$page['article_id']} AND `published` ORDER BY `id` LIMIT {($pn-1)*$pp},{$pp}");
        }
        
        
        public function addComment($name, $comment) 
        {
            if($name =="") return false;
            if($comment =="") return false;
            $this->mysqli->query("UPDATE `articles` SET `name` = '$name', `text_comment` = '$comment' WHERE(`id` = '$id')");
            
        }
        /* Closing the connection */
        
        public function __destruct() {
            if($this->mysqli) $this->mysqli->close();
        }
    
    
    
    
    
    
    
    
    
    
    }
 
 
?>
0
 Аватар для fanatikus
1932 / 1523 / 703
Регистрация: 17.11.2012
Сообщений: 6,585
17.10.2016, 15:35
Цитата Сообщение от Mr CaT Посмотреть сообщение
public function viewComment($name, $comment) { $this->mysqli->query("SELECT `text_comment``.*.`id`,`name` FROM `articles` LEFT JOIN `text_comment`` USING (`name`) WHERE `article_id`={$page['article_id']} AND `published` ORDER BY `id` LIMIT {($pn-1)*$pp},{$pp}"); }
откуда эти переменные возьмутся в функции?
Цитата Сообщение от Mr CaT Посмотреть сообщение
public function addComment($name, $comment)
{
if($name =="") return false;
if($comment =="") return false;
$this->mysqli->query("UPDATE `articles` SET `name` = '$name', `text_comment` = '$comment' WHERE(`id` = '$id')");

}
$id тоже самое
0
0 / 0 / 0
Регистрация: 06.06.2016
Сообщений: 22
17.10.2016, 15:56  [ТС]
fanatikus, Я написал неверно вот верный скрипт:
PHP
1
2
3
4
5
public function addComment($name, $comment)
{
if($name =="") return false;
if($comment =="") return false;
$this->mysqli->query("INSERT INTO `articles` (`name`, `text_comment`) VALUES('$name', '$comment') ")
Но все равно ошибка
0
 Аватар для fanatikus
1932 / 1523 / 703
Регистрация: 17.11.2012
Сообщений: 6,585
17.10.2016, 16:20
Цитата Сообщение от Mr CaT Посмотреть сообщение
Но все равно ошибка
какая?
0
276 / 201 / 143
Регистрация: 22.01.2016
Сообщений: 637
17.10.2016, 17:11
Цитата Сообщение от fanatikus Посмотреть сообщение
какая?
в конце последней строки ; что ли не хватает
Цитата Сообщение от Mr CaT Посмотреть сообщение
'$comment') ")
0
0 / 0 / 0
Регистрация: 06.06.2016
Сообщений: 22
17.10.2016, 17:31  [ТС]
Цитата Сообщение от fanatikus Посмотреть сообщение
какая?
Вот такая
Notice: Undefined variable: page in A:\home\dvizhok.ru\oop\comment.php on line 27
[Денвер: показать возможную причину ошибки]
Notice: Undefined variable: pn in A:\home\dvizhok.ru\oop\comment.php on line 27

Notice: Undefined variable: pp in A:\home\dvizhok.ru\oop\comment.php on line 27

Notice: Undefined variable: pp in A:\home\dvizhok.ru\oop\comment.php on line 27

Добавлено через 30 секунд
Цитата Сообщение от mrNTF Посмотреть сообщение
в конце последней строки ; что ли не хватает
Поставил но все равно ошибка
0
 Аватар для fanatikus
1932 / 1523 / 703
Регистрация: 17.11.2012
Сообщений: 6,585
17.10.2016, 17:38
вы прикалываетесь?
те же ошибки(неопределенные переменные), на которые я обратил ваше внимание выше в посте.
0
0 / 0 / 0
Регистрация: 06.06.2016
Сообщений: 22
18.10.2016, 12:22  [ТС]
fanatikus, miketomlin мне написал скрипт.
А как тогда сделать "Добавление статьи на отдельной странице со статьей"? Объясните пожалуйста
0
930 / 846 / 190
Регистрация: 28.11.2013
Сообщений: 3,621
18.10.2016, 12:31
Я вам примерный запрос написал, а не скрипт.

Цитата Сообщение от Mr CaT Посмотреть сообщение
А как тогда сделать "Добавление статьи на отдельной странице со статьей"?
Статьи? Вы уверены, что не описались?
0
 Аватар для fanatikus
1932 / 1523 / 703
Регистрация: 17.11.2012
Сообщений: 6,585
18.10.2016, 12:35
Цитата Сообщение от Mr CaT Посмотреть сообщение
miketomlin мне написал скрипт.
если вы о посте выше, то это просто пример sql запроса. его не нужно тупо вставлять в свой код. нужно понять что он делает и подогнать под себя.
Цитата Сообщение от Mr CaT Посмотреть сообщение
А как тогда сделать "Добавление статьи на отдельной странице со статьей"?
покажите структуру таблиц где хранятся статьи и комментарии.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
18.10.2016, 12:35
Помогаю со студенческими работами здесь

Добавление комментария к файлу
Есть простейший файлообменник, заливаем файл, добавляем комментарий к файлу. Соответственно в папку заливается наш файл и текстовый...

Добавление комментария к ячейке по условию
Добрый день. Помогите, пожалуйста, написать макрос. Суть задачи следующая: есть список клиентов, где некоторые клиенты могут...

Удаленное добавление комментария на сайт
я хочу сделать со своего сайта добавление комментария на другой сайт,т.е разместил текстбокс поставил кнопку отправить,а что дальше делать...

Добавление комментария, используя POST запрос
Добрый день. Пытаюсь добавить комментарий в инстаграм, ошибок никаких нет, но ничего не добавляется, а в ответ приходит просто...

Добавление комментария под видео на youtube.com
Нужна прога для добавления комментария под видео на ютубе по нажатию кнопки: в Edit1 вводим url страницы видео, в Edit2 сам текст...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru