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

Ошибка - Warning: session_start() [function.session-start]: Cannot send session cookie - headers already sent

24.05.2017, 15:28. Показов 1375. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день!!! Хочу реализовать регистрацию и авторизацию пользователей. Вроде все правильно делаю. Не могу понять из-за чего ошибка вылезает. Буду благодарен помощи!!!
PHP/HTML
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
57
58
59
60
61
<?php
    class User {
 
        private $db;
 
        private static $user = null;
 
        private function __construct() {
            $this->db = new mysqli("localhost", "Admin", "123", "mybase");
            $this->db->query("SET NAMES 'utf8'");
        }
 
        public static function getObject() {
            if(self::$user === null) self::$user = new User();
                return self::$user;
        }
 
 
        public function regUser($login, $password) {
            if($login == "" || $password == "") return false;
 
            $password = md5($password);
            return $this->db->query("INSERT INTO `users` (`login`, `password`, `regdate`) VALUES('$login', '$password', '".time()."')");
        }
 
        private function checkUser($login, $password) {
            $result_set = $this->db->query("SELECT `password` FROM `users` WHERE `login`='$login'");
            $user = $result_set->fetch_assoc();
            $result_set->close();
 
            if(!$user) return false;
            return $password === $user["password"];
        }
 
        public function isAuth() {
            session_start();
            $login = $_SESSION["login"];
            $password = $_SESSION["password"];
 
            return $this->checkUser($login, $password);
        }
 
        public function login($login, $password) {
            $password = md5($password);
 
            if($this->checkUser($login, $password)) {
                session_start();
 
                $_SESSION["login"] = $login;
                $_SESSION["password"] = $password;
 
                return true;
            }
            else return false;
        }
 
        public function __destruct() {
            if($this->db) $this->db->close();
        }
    }
?>
Это класс User

Добавлено через 17 секунд
PHP/HTML
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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
<?php
    require_once "lib/user_class.php";
    $user = User::getObject();
    $auth = $user->isAuth();
 
    if(isset($_POST["reg"])) {
        $login = $_POST["login"];
        $password = $_POST["password"];
        
        $reg_success = $user->regUser($login, $password);
    }
    elseif(isset($_POST["auth"])) {
        $login = $_POST["login"];
        $password = $_POST["password"];
 
        $auth_success = $user->login($login, $password);
 
        
        if($auth_success) {
            header("Location: index.php");
            exit;
        };
    };
 
    
?>
<!DOCTYPE html>
<html>
<head>
    <title>Регистрация и авторизация пользователя</title>
 
    <!-- meta tags -->
    <meta charset="UTF-8">
    <meta name="description" content="">
    <meta name="keywords" content="">
    <meta name="viewport" content="width=device-width, initial-scale=1">
 
    <!-- style links -->
    <link rel="shortcut icon" href="" type="image/x-icon">
    <link rel="stylesheet" href="">
 
    <!-- script link -->
    <script src="" type="text/javascript"></script>
 
    <!-- [if lt IE 9] >
    <script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
    <![endif] -->
</head>
<body>
    <?php
                        if($auth) {
                            echo "Здравствуйте".$_SESSION["login"];
                        }else{
                            echo '<h2>Регистрация пользователя</h2>
                            <form action="index.php" method="post" name="register">
                                <table>
                                    <tr>
                                        <td>Логин:</td>
                                        <td>
                                            <input type="text" name="login">
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>Пароль:</td>
                                        <td>
                                            <input type="password" name="password">
                                        </td>
                                    </tr>
                                    <tr>
                                        <td colspan="2">
                                            <input type="submit" name="reg" value="Зарегестрироваться">
                                        </td>
                                    </tr>
                                </table>
                            </form>
 
                            <h2>Авторизация пользователя</h2>
                            <form action="index.php" method="post" name="auth">
                                <table>
                                    <tr>
                                        <td>Логин:</td>
                                        <td>
                                            <input type="text" name="login">
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>Пароль:</td>
                                        <td>
                                            <input type="password" name="password">
                                        </td>
                                    </tr>
                                    <tr>
                                        <td colspan="2">
                                            <input type="submit" name="auth" value="Войти">
                                        </td>
                                    </tr>
                                </table>
                            </form>';
                        };
    ?>
    
    
    <!-- Live reload -->
    <script>document.write('<script src="http://' + (location.host || 'localhost').split(':')[0] + ':35729/livereload.js?snipver=1"></' + 'script>')
    </script>
</body>
</html>
Добавлено через 35 секунд
И соответственно html
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
24.05.2017, 15:28
Ответы с готовыми решениями:

Warning: session_start() [function.session-start]: Cannot send session cookie - headers already sent
У меня на компе все ОК, но после загрузки на хост получаю предупреждения и нечего не работает Warning: session_start() : Cannot send...

Warning: session_start() [function.session-start]: Cannot send session cookie - headers already sent
Открыл движок а точне файл index.php та начало кода &lt;?php /** * Файл index.php расположен в корне CMS является единственной...

Warning: session_start() [function.session-start]: Cannot send session cookie - headers already sent by
session_start(); if (!isset($_SESSION)) $_SESSION=0; echo &quot;вы обновили страницу &quot;.$_SESSION++.&quot; раз. &quot;; echo &quot;&lt;br&gt;&lt;a...

9
 Аватар для Пифагор
2172 / 1655 / 840
Регистрация: 10.01.2015
Сообщений: 5,207
24.05.2017, 16:56
Что означает предупреждение "headers already sent"
0
1 / 1 / 1
Регистрация: 18.11.2016
Сообщений: 38
24.05.2017, 18:05
session_start(); 42 строка , запиши это после <?php и попробуй.
0
 Аватар для Vdekameron
0 / 0 / 0
Регистрация: 14.01.2013
Сообщений: 73
25.05.2017, 13:12  [ТС]
Цитата Сообщение от Пифагор Посмотреть сообщение
Что означает предупреждение "headers already sent"
Мне помогла эта статья. Но помогло только вставка ob_start();
А без нее все-равно не могу понять почему(( Извините может туплю(( просто механизм не могу понять. Не могли бы вы как для "особо одаренного" объяснить. что происходит и откуда вылазит ошибка.
Заранее большое спасибо!
Миниатюры
Ошибка - Warning: session_start() [function.session-start]: Cannot send session cookie - headers already sent  
0
 Аватар для Vdekameron
0 / 0 / 0
Регистрация: 14.01.2013
Сообщений: 73
25.05.2017, 13:13  [ТС]
Цитата Сообщение от Пифагор Посмотреть сообщение
Что означает предупреждение "headers already sent"
Мне помогла эта статья. Но помогло только вставка ob_start();
А без нее все-равно не могу понять почему(( Извините может туплю(( просто механизм не могу понять. Не могли бы вы как для "особо одаренного" объяснить. что происходит и откуда вылазит ошибка.
Заранее большое спасибо!

Добавлено через 51 секунду
Цитата Сообщение от Miraliko Посмотреть сообщение
session_start(); 42 строка , запиши это после <?php и попробуй.
в 42 строке нет нигде у меня session_start()
0
 Аватар для Пифагор
2172 / 1655 / 840
Регистрация: 10.01.2015
Сообщений: 5,207
25.05.2017, 13:22
Vdekameron, нет необходимости прописывать session_start() в каждом методе, так как стандартные функции доступны из любого места кода. К сведению: поэтому у Вас и появлялась ошибка Cannot send session cookie - headers already sent. Какой-то метод уже подключил session_start(), а Вы пытаетесь его подключить еще раз и создается конфликт.
Достаточно прописать session_start() 1 раз в начале файла, в котором будут использоваться сессионные переменные.
0
 Аватар для Vdekameron
0 / 0 / 0
Регистрация: 14.01.2013
Сообщений: 73
29.05.2017, 09:26  [ТС]
Цитата Сообщение от Пифагор Посмотреть сообщение
Достаточно прописать session_start() 1 раз в начале файла, в котором будут использоваться сессионные переменные.
Прописал session_start() вначале файла
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
57
58
59
60
61
62
<?php
    session_start();
    class User {
 
        private $db;
 
        private static $user = null;
 
        private function __construct() {
            $this->db = new mysqli("localhost", "Admin", "123", "mybase");
            $this->db->query("SET NAMES 'utf8'");
        }
 
        public static function getObject() {
            if(self::$user === null) self::$user = new User();
                return self::$user;
        }
 
 
        public function regUser($login, $password) {
            if($login == "" || $password == "") return false;
 
            $password = md5($password);
            return $this->db->query("INSERT INTO `users` (`login`, `password`, `regdate`) VALUES('$login', '$password', '".time()."')");
        }
 
        private function checkUser($login, $password) {
            $result_set = $this->db->query("SELECT `password` FROM `users` WHERE `login`='$login'");
            $user = $result_set->fetch_assoc();
            $result_set->close();
 
            if(!$user) return false;
            return $password === $user["password"];
        }
 
        public function isAuth() {
            //session_start();
            $login = $_SESSION["login"];
            $password = $_SESSION["password"];
 
            return $this->checkUser($login, $password);
        }
 
        public function login($login, $password) {
            $password = md5($password);
 
            if($this->checkUser($login, $password)) {
                //session_start();
 
                $_SESSION["login"] = $login;
                $_SESSION["password"] = $password;
 
                return true;
            }
            else return false;
        }
 
        public function __destruct() {
            if($this->db) $this->db->close();
        }
    }
?>
Добавлено через 3 минуты
Но 22 строка, где отправляется заголовки вызывает ошибку- Warning: Cannot modify header information - headers already sent by (output started at S:\home\4.mysql\5.autorisationauntificat ion\practice\lib\user_class.php:68) in S:\home\4.mysql\5.autorisationauntificat ion\practice\index.php on line 22
HTML5
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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
<?php
    //ob_start();
    require_once "lib/user_class.php";
    
    $user = User::getObject();
    $auth = $user->isAuth();
 
    if(isset($_POST["reg"])) {
        $login = $_POST["login"];
        $password = $_POST["password"];
        
        $reg_success = $user->regUser($login, $password);
    }
    elseif(isset($_POST["auth"])) {
        $login = $_POST["login"];
        $password = $_POST["password"];
 
        $auth_success = $user->login($login, $password);
 
        
        if($auth_success) {
            header("Location: index.php");
            exit;
        };
    };
?>
<!DOCTYPE html>
<html>
<head>
    <title>Регистрация и авторизация пользователя</title>
 
    <!-- meta tags -->
    <meta charset="UTF-8">
    <meta name="description" content="">
    <meta name="keywords" content="">
    <meta name="viewport" content="width=device-width, initial-scale=1">
 
    <!-- style links -->
    <link rel="shortcut icon" href="" type="image/x-icon">
    <link rel="stylesheet" href="">
 
    <!-- script link -->
    <script src="" type="text/javascript"></script>
 
    <!-- [if lt IE 9] >
    <script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
    <![endif] -->
</head>
<body>
<?php
                    if($auth) {
                        echo "Здравствуйте".$_SESSION["login"]."(<a href='lib/logout.php'>Выход</a>)";
                    }else{
                        echo '<h2>Регистрация пользователя</h2>
                        <form action="index.php" method="post" name="register">
                            <table>
                                <tr>
                                    <td>Логин:</td>
                                    <td>
                                        <input type="text" name="login">
                                    </td>
                                </tr>
                                <tr>
                                    <td>Пароль:</td>
                                    <td>
                                        <input type="password" name="password">
                                    </td>
                                </tr>
                                <tr>
                                    <td colspan="2">
                                        <input type="submit" name="reg" value="Зарегестрироваться">
                                    </td>
                                </tr>
                            </table>
                        </form>
 
                        <h2>Авторизация пользователя</h2>
                        <form action="index.php" method="post" name="auth">
                            <table>
                                <tr>
                                    <td>Логин:</td>
                                    <td>
                                        <input type="text" name="login">
                                    </td>
                                </tr>
                                <tr>
                                    <td>Пароль:</td>
                                    <td>
                                        <input type="password" name="password">
                                    </td>
                                </tr>
                                <tr>
                                    <td colspan="2">
                                        <input type="submit" name="auth" value="Войти">
                                    </td>
                                </tr>
                            </table>
                        </form>';
                    };
?>
    
    
    <!-- Live reload -->
    <script>document.write('<script src="http://' + (location.host || 'localhost').split(':')[0] + ':35729/livereload.js?snipver=1"></' + 'script>')
    </script>
</body>
</html>
0
Эксперт PHP
4925 / 3920 / 1620
Регистрация: 24.04.2014
Сообщений: 11,441
29.05.2017, 09:34
Цитата Сообщение от Vdekameron Посмотреть сообщение
output started at S:\home\4.mysql\5.autorisationauntificat ion\practice\lib\user_class.php:68
Вот самое интересное место в ошибке headers already sent. Именно в этом файле на этой строке начинается вывод тела ответа и заканчивается возможность отправлять заголовки.
0
 Аватар для Vdekameron
0 / 0 / 0
Регистрация: 14.01.2013
Сообщений: 73
29.05.2017, 09:54  [ТС]
Цитата Сообщение от Jewbacabra Посмотреть сообщение
Вот самое интересное место в ошибке headers already sent. Именно в этом файле на этой строке начинается вывод тела ответа и заканчивается возможность отправлять заголовки.
Эммм как это можно поправить? Извините за тугодумность
0
Эксперт PHP
4925 / 3920 / 1620
Регистрация: 24.04.2014
Сообщений: 11,441
29.05.2017, 10:04
Vdekameron, выводить сначала все заголовки, и только потом тело ответа. Все.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
29.05.2017, 10:04
Помогаю со студенческими работами здесь

Warning: session_start() [function.session-start]: Cannot send session cookie - headers already sent
Пытаюсь сделать корзину товаров, проблема с session_start выдает вот такую ошибку: Warning: session_start() : Cannot send session cookie -...

Warning: session_start() [function.session-start]: Cannot send session cache limiter - headers already sent
И опять я, не прошло и дня как я столкнулся с новой проблемой (старую решил сам, очень я невнимательный ) но уже просидев несколько часов с...

Warning: session_start() [function.session-start]: Cannot send session cache limiter - headers already sent
Ребят, я полный краб в php пока что ) При входе в админку вордпреса белый экран и Notice: Use of undefined constant ddsg_language -...

Warning: session_start() [function.session-start]: Cannot send session cookie
Warning: session_start() : Cannot send session cookie - headers already sent by (output started at /home/olzsu/public_html/index.php:1) in...

Warning: session_start() [function.session-start]: Cannot send session cache limiter - headers already sent (output started at S:\home\test_saint\www\
выдает такую ошибку &quot;Warning: session_start() : Cannot send session cache limiter - headers already sent (output started at...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru