这段代码有效吗?
<a href="#" onclick="<?php session_destroy();?>">Logout</a>
答案 0 :(得分:15)
创建一个名为logout.php的页面
Logout.php_的 _ ___ 强>
<?php
Session_start();
Session_destroy();
header('Location: ' . $_SERVER['HTTP_REFERER']);
?>
您的网页_ _ ____
<a href="Logout.php">Logout</a>
答案 1 :(得分:14)
不,它不是有效的代码。它将在加载php页面时销毁会话。
要在点击时销毁会话,您应该写
<a href="logout.php" >Logout</a>
logout.php中的
session_destroy();
答案 2 :(得分:5)
错误的代码。你可以使用这段代码:
<?php if($_GET['logout']==1) session_destroy(); ?>
<a href="?logout=1">Logout</a>
答案 3 :(得分:4)
在点击链接之前,该代码已经破坏了会话,您应该这样做:
HTML页面:
<a href="sessiondestroy.php">Logout</a>
Sessiondestroy.php:
<?=session_start(); session_destroy(); ?>
答案 4 :(得分:3)
没有它无效... onclick是一个客户端事件。你可以这样做。
<a href="logout.php">logout</a>
并创建一个名为logout.php的文件并包含session_destroy();声明
<?php
session_destroy();
//do other things... like redirect to a deafault/login page
?>
答案 5 :(得分:2)
不,从客户端调用服务器端函数是不合逻辑的,onClick
是在客户端发生的事件,所以,它不能调用session_destroy()
因为它是服务器端(PHP函数) )客户端无法提供
答案 6 :(得分:1)
可以这样做。如果您专注于使用onClick操作,则可以简单地使用AJAX。首先你必须创建一个ajax.php,它看起来像这样:
<?php
//AJAX dynamic callback
if(isset($_GET['action'])){
if($_GET['action'] == 'logout'){
//destroy the session
session_destroy();
echo 'Logout success!';
//redirect the user to a default web page using header
header("location:http://example.com/");
}
}
?>
然后你想要创建一个javascript文件来告诉ajax.php你想要注销:
<script>
function logout()
{
var xmlhttp;
if (window.XMLHttpRequest)
{// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp=new XMLHttpRequest();
}
else
{// code for IE6, IE5
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.onreadystatechange=function()
{
if (xmlhttp.readyState==4 && xmlhttp.status==200)
{
document.getElementById("Logoutbutton").innerHTML=xmlhttp.responseText;
}
}
xmlhttp.open("GET","ajax.php?action=logout",true);
xmlhttp.send();
}
</script>
无论如何,感谢您使用StackOverflox,请报告它是如何进行的,或者如果您需要其他帮助:)
TP