Я хочу установить куки, чтобы пользователи голосовали только один раз в 4 категориях (грустно, бесит, смешно, круто).
Я новичок, поэтому я знаю, что мой код очень неудобен, но это моя первая попытка, и для меня не имеет значения, если у меня есть несколько строк более или менее.
По какой-то причине браузер не загружает файлы voice.php (которые вызываются, когда пользователь выбирает один из вариантов голосования). Я просто не могу найти ошибку … может быть, кто-то сразу ее видит?
[До того, как я вставил файл cookie, файлы кода были загружены идеально, поэтому вызов не имеет значения.]
<?php
require_once('connect.php');
$newsid = $_POST['id'];
if (isset($_POST['submit'])) {
if(isset($_COOKIE['votecookie']) && $_COOKIE['votecookie'] !== 'sad') {
if($_COOKIE['votecookie'] == 'cool') {
$query = mysql_query('UPDATE `index` SET cool=cool-1 WHERE id = {$newsid}');
}
if($_COOKIE['votecookie'] == 'funny') {
$query = mysql_query('UPDATE `index` SET funny=funny-1 WHERE id = {$newsid}');
}
if($_COOKIE['votecookie'] == 'sad') {
$query = mysql_query('UPDATE `index` SET enraging=enraging-1 WHERE id = {$newsid}');
}
setcookie('votecookie', 'sad');
$query = mysql_query('UPDATE `index` SET sad=sad+1 WHERE id = '{$newsid}'');
$hosts = $_SERVER['HTTP_HOST'];
$uris = rtrim(dirname($_SERVER['PHP_SELF']), '/\\');
$extras = 'news.php?id={$newsid}&sad=1';
header('Location: http://$hosts$uris/$extras');
exit;
}
if(!isset($_COOKIE['votecookie']) {
setcookie('votecookie', 'sad');
$query = mysql_query('UPDATE `index` SET sad=sad+1 WHERE id = '{$newsid}'');
$hosts = $_SERVER['HTTP_HOST'];
$uris = rtrim(dirname($_SERVER['PHP_SELF']), '/\\');
$extras = 'news.php?id={$newsid}&sad=1';
header('Location: http://$hosts$uris/$extras');
exit;
}
if(isset($_COOKIE['votecookie']) && $_COOKIE['votecookie'] == 'sad') {
$hosts= $_SERVER['HTTP_HOST'];
$uris = rtrim(dirname($_SERVER['PHP_SELF']), '/\\');
$extras = 'news.php?id={$newsid}&sad=0';
header('Location: http://$hosts$uris/$extras');
exit;
}
}
else {
$hosts= $_SERVER['HTTP_HOST'];
$uris = rtrim(dirname($_SERVER['PHP_SELF']), '/\\');
$extras = 'news.php?id={$newsid}&sad=0';
header('Location: http://$hosts$uris/$extras');
exit;
?>
Если кто-то заинтересован в ответе: вот как я это сделал сейчас (у меня было еще несколько ошибок в моем коде и ошибка в рассуждениях).
<?php
require_once('connect.php');
$newsid = $_POST['id'];
if (isset($_POST['submit'])) {
if(isset($_COOKIE[$newsid]) && $_COOKIE[$newsid] != 'sad') {
if($_COOKIE[$newsid] == 'cool') {
$query = mysql_query("UPDATE `index` SET cool=cool-1 WHERE id = '{$newsid}'");
}
if($_COOKIE[$newsid] == 'funny') {
$query = mysql_query("UPDATE `index` SET funny=funny-1 WHERE id = '{$newsid}'");
}
if($_COOKIE[$newsid] == 'enraging') {
$query = mysql_query("UPDATE `index` SET enraging=enraging-1 WHERE id = '{$newsid}'");
}
$query = mysql_query("UPDATE `index` SET sad=sad+1 WHERE id = '{$newsid}'");
setcookie($newsid, "sad", time() + (10 * 365 * 24 * 60 * 60));
$hosts = $_SERVER['HTTP_HOST'];
$uris = rtrim(dirname($_SERVER['PHP_SELF']), '/\\');
$extras = "news.php?id={$newsid}&sad=1";
header("Location: http://$hosts$uris/$extras");
exit;
}
if(!isset($_COOKIE[$newsid])) {
$query = mysql_query("UPDATE `index` SET sad=sad+1 WHERE id = '{$newsid}'");
setcookie($newsid, "sad", time() + (10 * 365 * 24 * 60 * 60));
$hosts = $_SERVER['HTTP_HOST'];
$uris = rtrim(dirname($_SERVER['PHP_SELF']), '/\\');
$extras = "news.php?id={$newsid}&sad=1";
header("Location: http://$hosts$uris/$extras");
exit;
}
if(isset($_COOKIE[$newsid]) && $_COOKIE[$newsid] == 'sad') {
$hosts= $_SERVER['HTTP_HOST'];
$uris = rtrim(dirname($_SERVER['PHP_SELF']), '/\\');
$extras = "news.php?id={$newsid}&sad=0";
header("Location: http://$hosts$uris/$extras");
exit;
}
}
else {
$hosts= $_SERVER['HTTP_HOST'];
$uris = rtrim(dirname($_SERVER['PHP_SELF']), '/\\');
$extras = "news.php?id={$newsid}&sad=0";
header("Location: http://$hosts$uris/$extras");
exit;
}
?>
Других решений пока нет …