У меня есть страница signup.php, содержащая логин через кнопку facebook. структура страницы - это что-то вроде этого
<?php
if(!isset($_SESSION['logged_in']))
{
echo '<div id="results">';
echo '<!-- results will be placed here -->';
echo '</div>';
echo '<div id="LoginButton">';
echo '<a href="#" rel="nofollow" class="fblogin-button" onClick="javascript:CallAfterLogin();return false;">Login with Facebook</a>';
echo '</div>';
}
else
{
echo 'Hi '. $_SESSION['user_name'].'! You are Logged in to facebook, <a href="?logout=1">Log Out</a>.';
}
?>
Код ajax, используемый на этой странице, вызывает другую страницу process_facebook.php и обрабатывает данные на сервере. код, используемый для ajax на странице signup.php,
<script type="text/javascript">
window.fbAsyncInit = function() {
FB.init({
appId: '<?php echo $appId; ?>',
cookie: true,xfbml: true,
channelUrl: '<?php echo $return_url; ?>channel.php',
oauth: true
});
};
(function() {
var e = document.createElement('script');
e.async = true;e.src = document.location.protocol +'//connect.facebook.net/en_US/all.js';
document.getElementById('fb-root').appendChild(e);}());
function CallAfterLogin(){
FB.login(function(response) {
if (response.status === "connected")
{
LodingAnimate(); //Animate login
FB.api('/me', function(data) {
if(data.email == null)
{
//Facbeook user email is empty, you can check something like this.
alert("You must allow us to access your email id!");
ResetAnimate();
}else{
AjaxResponse();
}
});
}
},
{scope:'<?php echo $fbPermissions; ?>'});
}
//functions
function AjaxResponse()
{
//Load data from the server and place the returned HTML into the matched element using jQuery Load().
$( "#results" ).load( "process_facebook.php" );
}
//Show loading Image
function LodingAnimate()
{
$("#LoginButton").hide(); //hide login button once user authorize the application
$("#results").html('<img src="img/ajax-loader.gif" /> Please Wait Connecting...'); //show loading image while we process user
}
//Reset User button
function ResetAnimate()
{
$("#LoginButton").show(); //Show login button
$("#results").html(''); //reset element html
}
</script>
Теперь проблема заключается в том, что страница process_facebook.php работает с данными fb на бэкэнд и после этого перенаправляется обратно на страницу signup.php и отображает данные, напечатанные на странице process_facebook.php(необязательно). Я хочу, чтобы вместо перенаправления с страницы process_facebook.php на страницу signup.php и отображения ее данных, я хочу перенаправить на другую страницу, а не только новые данные должны загрузиться с новой страницы, но url также должен получить изменено. (например, www.example.com/app/signup.php следует изменить на www.example.com/app/profile.php)
я забыл упомянуть, но я попытался использовать header() для перенаправления, но он просто извлекает данные на странице profile.php, но показывает URL-адрес www.example.com/app/signup.php. Теперь проблема в нем заключается в том, что если я обновляю страницу по какой-либо причине, тогда загружаются данные старой страницы signup.php