SMF Support > Italiano (Italian)

Redirect sbagliato di SSI.php dopo login

(1/3) > >>

gfr1991:
Salve ragazzi, ho un problema.
Ho implementato sul mio sito il codice per permettere il login tramite il database del forum, come da file ssi.php. Però ho un problema: in sostanza, quando una persona prova a fare login sul mio sito viene rimandata al forum invece che alla pagina dove ha effettuato il login. L'unico modo per far funzionare il tutto è andare sul forum, fare logout e quindi rifare login tramite sito. Spero possiate aiutarmi, ecco il codice che ho inserito:
 
--- Code: ---<?php
require("D:\inetpub\webs\accentosulladcom\public\simple\SSI.php"); 

if ($context['user']['is_guest'])
{echo <<<EOD
<nav1>
<ul>
<li id="login">
<a id="login-trigger" href="#">
Log in <span>&#38;#x25BC;</span>
</a>
<div id="login-content">
<form action="http://www.accentosullad.com/public/simple/index.php?action=login2" method="post" accept-charset="ISO-8859-1">
<fieldset id="inputs">
<input id="user" type="text" name="user" placeholder="Username" required>   
<input id="passwrd" type="password" name="passwrd" placeholder="Password" required>
</fieldset>
<fieldset id="actions">
<input type="submit" id="submit" value="Accedi">
<label><input type="checkbox" name="cookielength" value="-1" checked="checked">Rimani collegato</label>
</fieldset>
</form>
</div>                     
</li>
<li id="signup">
<a href="">Registrati</a>
</li>
</ul>
</nav1>
EOD;
}
else
{
//You can show other stuff here.  Like ssi_welcome().  That will show a welcome message like.
//Hey, username, you have 552 messages, 0 are new.
echo '<nav1>', '<ul>',  '<li id="login">', '<a id="login-trigger">', " Ciao ", $context['user']['name'] , '</a>', '</li>', '<li id="signup">', ssi_logout(), '</li>', '</ul>', '</nav1>';
}
$_SESSION['login_url']='http://accentosullad.com/'.$_SERVER['PHP_SELF'];
$_SESSION['logout_url']='http://accentosullad.com/'.$_SERVER['PHP_SELF'];
?> 
--- End code ---

emanuele:
mmm...prova qualcosa tipo:

--- Code: ---$_SESSION['old_url'] = !empty($_SERVER['HTTP_REFERER']) ? $_SERVER['HTTP_REFERER'] : '';
--- End code ---
Però ti consiglio di mettere un po' più di controlli, altrimenti ad esempio se uno sbaglia il login verrebbe re-indirizzato sulla pagina del login...
Fai qualche prova e vedi. ;)

gfr1991:
Ciao, innanzitutto ti ringrazio per l'attenzione e la risposta rapida. Ti chiedo una specificazione: Dove dovrei inserire l'indirizzo di redirect?
Ah, ho scoperto un altro problema. Ammettendo che io sia loggato al forum perchè magari ho impostato il log permanente; se alla sessione successiva io sono connesso al forum, sul sito non viene mostrato. Quindi sul sito verrò autenticato come "guest", sul forum invece sarò loggato.
C'è qualche modo per ovviare (anche) a questo problema? Sembra come se SSI.php non sia in grado di riconoscere se io sia loggato o meno.

emanuele:
SSI deve riconoscere se sei loggato, quindi ora il punto è: come stai determinando se sei loggato o meno nel tuo codice?
Per caso stai usando "sub-domini" differenti? (ad esempio forum.tuosito.it per il forum e www.tuosito.it per il sito?) In tal caso dovresti abilitare l'opzione dei cookie indipendenti dal sub-dominio (admin > configurazione > impostazioni server > cookies e sessione).

gfr1991:
Ciao, il sito si trova in una cartella (public/simple/) e il sito per ora si trova in una cartella diversa (prova/), mentre successivamente sarà in root. Provo come mi hai detto e vedo se funziona. :)

Navigation

[0] Message Index

[#] Next page

Go to full version