Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [php] Sesja oparta o session.trans_sid=1
Forum PHP.pl > Forum > PHP
Cezar708
Witam.

Muszę identyfikator sesji przesyłać w linku, nie mogę używać cookies.

do tego celu porobiłem sobie 2 proste testy:

TEST 1:

pliki:

header.php
  1. <?php
  2. ini_set("session.use_cookies", "Off");
  3. ini_set("session.use_trans_sid", "On");
  4. ?>


test1.php
  1. <?php
  2. include('header.php');
  3. $_SESSION['test'] = 'to jest testowa zmienna';
  4. ?>
  5. <a href="test2.php"> Sprawdz drugi skrypt </a>


test2.php
  1. <?php
  2. include('header.php'); 
  3. echo isset($_SESSION['test']) ? $_SESSION['test'] : "Nic w sessji nie ma :(";
  4. ?>


po wywołaniu pliku test1.php nie ma żadnego problemu, po kliknięciu na linka; "Sprawdz drugi skrypt" pojawia się prawidłowa wartość z sesji czyli: "to jest testowa zmienna"


TEST 2:
jednak jeśli zmienimy plik
test1.php
na treść:
  1. <?php
  2. include('header.php'); 
  3. $_SESSION['test'] = 'to jest testowa zmienna';
  4. header("Location: test2.php");
  5. ?>


... czyli zamiast linka do drugiego pliku jest po prostu przekierowanie... to sesja przestaje działać...

oczywiście rozwiązanie:
  1. <?php
  2. //...
  3. header("Location: test2.php?" . session_name() . "=" . session_id());
  4. ?>


nie wchodzi w grę.

Stąd pytanie:

Czy jest jakaś możliwość "zmuszenia" php aby poprawnie zmieniał adresy przekierowań w headerze? Czyli tak aby zachowywał się podobnie jak przy generowaniu adresu?

Pozdrawiam
Cezar708
Babcia@Stefa
Może to ci pomoże:
  1. <?php
  2. function HeaderLocation($Location)
  3. {
  4.  $Temp = explode('?', $Location);
  5. header("Location: ".$Temp[0]."?" . session_name() . "=" . session_id()."&".$Temp[1]);
  6. ?>


Pozdrawiam, WebNuLL(Babcia@Stefa)
Roly
Daj na początku session_start() i powinno zadziałać...
Cezar708
Cytat(Babcia@Stefa @ 19.08.2008, 17:52:24 ) *
Może to ci pomoże:
  1. <?php
  2. function HeaderLocation($Location)
  3. {
  4.  $Temp = explode('?', $Location);
  5. header("Location: ".$Temp[0]."?" . session_name() . "=" . session_id()."&".$Temp[1]);
  6. ?>


Pozdrawiam, WebNuLL(Babcia@Stefa)


Jasne... mogę pozmieniać kod w całym systemie... ale nie o to chodzi, ponieważ chcę aby kod był działający poprawnie i bezpiecznie również dla ustawień z wyłączonym trans_sid, co przy Twoim rozwiązaniu nie pasuje. Poza tym, za każdym razem jak będę pisał jakiegoś redirecta będę musiał dopisywać. Wiem że mogę dopisać nową funkcję, która to za mnie załatwi... i w zasadzie tak to robię, ale pytanie jest takie, czy PHP potrafiłby to jakoś automatycznie załatwić tak jak jest automatycznie z wygenerowanymi linkami.

Cytat(Roly @ 19.08.2008, 17:55:56 ) *
Daj na początku session_start() i powinno zadziałać...

winksmiley.jpg ... to chyba nie tego kalibru problem winksmiley.jpg


Pozdrawiam
Kicok
http://pl.php.net/manual/pl/session.constants.php
  1. <?php
  2.  
  3. function headerLocation( $location )
  4. {
  5. if( !empty( SID ) )
  6. {
  7. $location .= ( strpos( $location, '?' ) === false ? '?' : '&' ) . SID;
  8. }
  9.  
  10. header( "Location: $location" );
  11. }
  12.  
  13. ?>



Innego sposobu nie ma. PHP nie wstawia automatycznie SID do linków w header" title="Zobacz w manualu PHP" target="_manual, więc będziesz musiał ręcznie pozamieniać wszystkie: header( 'Location: aaa.php' ) na: headerLocation( 'aaa.php' ) w swoim skrypcie.
Jeśli znasz się na wyrażeniach regularnych to możesz to zrobić przy pomocy tego programu: http://www.abacre.com/afr/
Cezar708
no trudno... niestety sad.gif trza będzie pozmieniać kody sad.gif

Pozdrawiam
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.