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

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

16.10.2016, 11:47. Показов 6043. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru