Заголовок PHP (Расположение: ...): принудительное изменение URL в адресной строке - PullRequest
53 голосов
/ 19 сентября 2011

В настоящее время я работаю на мобильном сайте с аутентификацией с использованием PHP-сессий с базой данных. У меня есть страница входа с формой, которая отправляется на server_login.php при отправке. Затем php-файл создает некоторые данные сеанса (сохраняются в $ _SESSION) и перенаправляет пользователя обратно на страницу индекса:

header("location:../../index.php");

Новая веб-страница (index.php) загружается правильно; однако, когда заголовок перенаправляет страницу, URL в адресной строке не изменяется; он остается на уровне *http://localhost/php/server/server_login.php* вместо http://localhost/index.php, и поэтому все другие мои ресурсы, использующие относительный путь, не могут быть загружены. Как будто веб-страница все еще думает, что она находится в / php / server вместо /.

Как ни странно, мое другое использование заголовка ("location: ...") в logout.php работает и успешно перенаправляет страницу при изменении URL.

Я убедился, что в моем * server_login.php * нет никаких выходов до перенаправления заголовка (над ним просто вызовы mysql для проверки), и я также использовал ob_start () и ob_end_flush ().

Существуют ли какие-либо методы принудительного изменения URL-адреса в адресной строке (и, таким образом, можно ли решить проблему относительного пути)? Или я что-то не так делаю?

P / S: я использую jQuery Mobile.

РЕДАКТИРОВАТЬ: Вот мой код для перенаправления, которое не меняет URL:

// some other stuff not shown


$sql = "SELECT * FROM $user_table WHERE email = '$myemail' AND password = '$mypassword'";
$login_result = mysql_query($sql, $connection);

$count = mysql_num_rows($login_result);

if ($count == 1) {

    // Successfully verified login information

    session_start();

    if (!isset($_SESSION['is_logged_in'])) {
        $_SESSION['is_logged_in'] = 1;
    }

    if (!isset($_SESSION['email'])) {
        $_SESSION['email'] = $myemail;
    }
    if (!isset($_SESSION['password'])) {
        $_SESSION['password'] = $mypassword;
    }

    // Register user's name and ID
    if ((!isset($_SESSION['name'])) && (!isset($_SESSION['user_id'])))  {
        $row = mysql_fetch_assoc($login_result);
        $_SESSION['name'] = $row['name'];
        $_SESSION['user_id'] = $row['user_id'];
    }

    header("Location: http://localhost:8080/meet2eat/index.php");

} else {
    // Not logged in. Redirect back to login page
    header("Location: http://localhost:8080/meet2eat/php/login.php?err=1");

}

Ответы [ 14 ]

0 голосов
/ 01 декабря 2014

использование

header ("Location: index.php"); // это работа на моем сайте

Подробнее о header () в документации php.

0 голосов
/ 02 августа 2014

У меня есть решение для вас, почему бы вам не использовать Explode, если ваш URL-адрес выглядит как

Url-> website.com/test/blog.php

$StringExplo=explode("/",$_SERVER['REQUEST_URI']);
$HeadTo=$StringExplo[0]."/Index.php";
Header("Location: ".$HeadTo);
0 голосов
/ 23 октября 2013

Вы должны использовать его как header(Location:../index.php), если он находится в другой папке

0 голосов
/ 17 августа 2013

почему все URL этого местоположения?

http://localhost:8080/meet2eat/index.php

вы можете просто использовать

index.php

, если файлы php находятся в той же папке, и этолучше, потому что, если вы хотите разместить файлы или изменить порт, у вас не будет проблем с достижением этого URL.

...