金沙贵宾会官网|金沙贵宾会登录-官网

【A】金沙贵宾会官网超高的返奖率为娱乐者提供资金保障,所以金沙贵宾会登录官网更加的方便了你的娱乐,申请88元彩金,因为在当中不仅仅只有游戏。

php的sso单点登陆完毕格局,登入验证示例代码

日期:2019-09-26编辑作者:网络安全

 代码如下

本文实例讲述了php的sso单点登录实现方法。分享给大家供大家参考。具体分析如下:

复制代码 代码如下:

 

这里详细讲到了几点:
1、点击登录跳转到SSO登录页面并带上当前应用的callback地址
2、登录成功后生成COOKIE并将COOKIE传给callback地址
3、callback地址接收SSO的COOKIE并设置在当前域下再跳回到应用1即完成登录
4、再在应用程序需要登录的地方嵌入一个iframe用来实时检测登录状态,代码如下:
index.php 应用程序页面:

<html>
<head>
<title>Login</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>

<?php
//index.php 应用程序页面
header('Content-Type:text/html; charset=utf-8');
$sso_address = ''; //你SSO所在的域名
$callback_address = ']
                    .str_replace('index.php','',$_SERVER['SCRIPT_NAME'])
                    .'callback.php'; //callback地址用于回调设置cookie

复制代码 代码如下:

<body>
<form name="form1" method="post" action="login.php">
<table width="300" border="0" align="center" cellpadding="2" cellspacing="2">
<tr>
<td width="150"><div align="right">用户名:</div></td>
<td width="150"><input type="text" name="username"></td>
</tr>
<tr>
<td><div align="right">密码:</div></td>
<td><input type="password" name="passcode"></td>
</tr>
<tr>
<td><div align="right">Cookie保存时间:</div></td>
<td><select name="cookie" id="cookie">
<option value="0" selected>浏览器进程</option>
<option value="1">保存1天</option>
<option value="2">保存30天</option>
<option value="3">保存365天</option>
</select></td>
</tr>
</table>
<p align="center">
<input type="submit" name="Submit" value="Submit">
<input type="reset" name="Reset" value="Reset">
</p>
</form>
</body>
</html>

if(isset($_COOKIE['sign'])){
    exit("欢迎您{$_COOKIE['sign']} <a href="login.php?logout">退出</a>");
}else{
    echo '您还未登录 <a href="'.$sso_address.'?callback='.$callback_address.'">点此登录</a>';
}
?>
<iframe src="<?php echo $sso_address ?>?callback=<?php echo $callback_address ?>" frameborder="0"  width="0" height="0"></iframe>

<?php 
header('Content-Type:text/html; charset=utf-8'); 
$sso_address = ''; //你SSO所在的域名 
$callback_address = '] 
                    .str_replace('index.php','',$_SERVER['SCRIPT_NAME']) 
                    .'callback.php'; //callback地址用于回调设置cookie
 
if(isset($_COOKIE['sign'])){ 
    exit("欢迎您{$_COOKIE['sign']} <a href="login.php?logout">退出</a>"); 
}else{ 
    echo '您还未登录 <a href="'.$sso_address.'?callback='.$callback_address.'">点此登录</a>'; 

?>
<iframe src="<?php echo $sso_address ?>?callback=<?php echo $callback_address ?>" frameborder="0"  width="0" height="0"></iframe>

复制代码 代码如下:

<?php
//login.php SSO登录页面
header('Content-Type:text/html; charset=utf-8');
if(isset($_GET['logout'])){
    setcookie('sign','',-300);
    unset($_GET['logout']);
    header('location:index.php');
}

login.php SSO登录页面:

<?php
@mysql_connect("localhost", "root","1981427") //选择数据库之前需要先连接数据库服务器
or die("数据库服务器连接失败");
@mysql_select_db("test") //选择数据库mydb
or die("数据库不存在或不可用");
//获取用户输入
$username = $_POST['username'];
$passcode = $_POST['passcode'];
$cookie = $_POST['cookie'];
//执行SQL语句
$query = @mysql_query("select username, userflag from users "
."where username = '$username' and passcode = '$passcode'")
or die("SQL语句执行失败");
//判断用户是否存在,密码是否正确
if($row = mysql_fetch_array($query))
{
if($row['userflag'] == 1 or $row['userflag'] == 0) //判断用户权限信息是否有效
{
switch($cookie) //根据用户的选择设置cookie保存时间
{
case 0: //保存Cookie为浏览器进程
setcookie("username", $row['username']);
break;
case 1: //保存1天
setcookie("username", $row['username'], time()+24*60*60);
break;
case 2: //保存30天
setcookie("username", $row['username'], time()+30*24*60*60);
break;
case 3: //保存365天
setcookie("username", $row['username'], time()+365*24*60*60);
break;
}
header("location: main.php"); //自动跳转到main.php
}
else
{
echo "用户权限信息不正确";
}
}
else
{
echo "用户名或密码错误";
}
?>

if(isset($_POST['username']) && isset($_POST['password'])){
    setcookie('sign',$_POST['username'],0,'');
    header("location:".$_POST['callback']."?sign={$_POST['username']}");
}

复制代码 代码如下:

复制代码 代码如下:

if(empty($_COOKIE['sign'])){
?>

<?php 
header('Content-Type:text/html; charset=utf-8'); 
if(isset($_GET['logout'])){ 
    setcookie('sign','',-300); 
    unset($_GET['logout']); 
    header('location:index.php'); 
}
 
if(isset($_POST['username']) && isset($_POST['password'])){ 
    setcookie('sign',$_POST['username'],0,''); 
    header("location:".$_POST['callback']."?sign={$_POST['username']}"); 
}
 
if(emptyempty($_COOKIE['sign'])){ 
?>
 
<form method="post"> 
<p>用户名:<input type="text" name="username" /></p> 
<p>密  码:<input type="password" name="password" /></p> 
<input type="hidden" name="callback" value="<?php echo $_GET['callback']; ?>" /> 
<input type="submit" value="登录" /> 
</form>
 
 
<?php 
}else{ 
    $query = http_build_query($_COOKIE); 
    echo "系统检测到您已登录 {$_COOKIE['sign']} <a href="{$_GET['callback']}?{$query}">授权</a> <a href="?logout">退出</a>"; 

?>

<?php
session_start();
if(isset($_COOKIE['username']))
{
@mysql_connect("localhost", "root","1981427") //选择数据库之前需要先连接数据库服务器
or die("数据库服务器连接失败");
@mysql_select_db("test") //选择数据库mydb
or die("数据库不存在或不可用");
//获取Session
$username = $_COOKIE['username'];
//执行SQL语句获得userflag的值
$query = @mysql_query("select userflag from users "
."where username = '$username'")
or die("SQL语句执行失败");
$row = mysql_fetch_array($query);
//获得用户权限信息
$flag = $row['userflag'];
//根据userflag的值输出不同的欢迎信息
if($flag == 1)
echo "欢迎管理员".$_SESSION['username']."登录系统";
if($flag == 0)
echo "欢迎用户".$_SESSION['username']."登录系统";
echo "<a href="logout.php" href="logout.php">注销</a>";
}
else
{
echo "您没有权限访问本页面";
}
?>

<form method="post">
<p>用户名:<input type="text" name="username" /></p>
<p>密  码:<input type="password" name="password" /></p>
<input type="hidden" name="callback" value="<?php echo $_GET['callback']; ?>" />
<input type="submit" value="登录" />
</form>

callback.php 回调页面用来设置跨域COOKIE:

复制代码 代码如下:

<?php
}else{
    $query = http_build_query($_COOKIE);
    echo "系统检测到您已登录 {$_COOKIE['sign']} <a href="{$_GET['callback']}?{$query}">授权</a> <a href="?logout">退出</a>";
}
?>

复制代码 代码如下:

<?php
setcookie("username");
echo "注销成功";
?>

<?php
//callback.php 回调页面用来设置跨域COOKIE
header('Content-Type:text/html; charset=utf-8');
if(empty($_GET)){
    exit('您还未登录');
}else{
    foreach($_GET as $key=>$val){
        setcookie($key,$val,0,'');
    }
    header("location:index.php");
}
?>

<?php 
header('Content-Type:text/html; charset=utf-8'); 
if(emptyempty($_GET)){ 
    exit('您还未登录'); 
}else{ 
    foreach($_GET as $key=>$val){ 
        setcookie($key,$val,0,''); 
    } 
    header("location:index.php"); 
}
?>

您可能感兴趣的文章:

  • PHP如何读取由JavaScript设置的Cookie
  • php读取javascript设置的cookies的代码
  • php中cookie的使用方法
  • PHP setcookie设置Cookie用法(及设置无效的问题)
  • PHP之COOKIE支持详解
  • PHP会话控制:Session与Cookie详解
  • 在PHP中设置、使用、删除Cookie的解决方法
  • php使用cookie实现记住登录状态
  • PHP5中Cookie与 Session使用详解
  • php中如何同时使用session和cookie来保存用户登录信息
  • PHP setcookie() cannot modify header information 的解决方法
  • PHP与JavaScript针对Cookie的读写、交互操作方法详解

<?php
//connect.php 用来检测登录状态的页面,内嵌在页面的iframe中
header('Content-Type:text/html; charset=utf-8');
if(isset($_COOKIE['sign'])){
    $callback = urldecode($_GET['callback']);unset($_GET['callback']);
    $query = http_build_query($_COOKIE);
    $callback = $callback."?{$query}";
}else{
    exit;
}
?>
<html><script type="text/javascript">top.location.href="<?php echo $callback; ?>";</script></html>

connect.php 用来检测登录状态的页面,内嵌在页面的iframe中:

 

复制代码 代码如下:

<?php
header('Content-Type:text/html; charset=utf-8'); 
if(isset($_COOKIE['sign'])){ 
    $callback = urldecode($_GET['callback']);unset($_GET['callback']); 
    $query = http_build_query($_COOKIE); 
    $callback = $callback."?{$query}"; 
}else{
    exit; 

?>
<html><script type="text/javascript">top.location.href="<?php echo $callback; ?>";</script></html>

希望本文所述对大家的php程序设计有所帮助。

您可能感兴趣的文章:

  • php实现的SSO单点登录系统接入功能示例分析
  • SSO单点登录的PHP实现方法(Laravel框架)
  • PHP版单点登陆实现方案的实例
  • PHP实现用户异地登录提醒功能的方法【基于thinkPHP框架】
  • thinkPHP5项目中实现QQ第三方登录功能
  • PHP在同一域名下两个不同的项目做独立登录机制详解
  • ThinkPHP实现登录退出功能
  • php面向对象的用户登录身份验证
  • PHP实现的注册,登录及查询用户资料功能API接口示例
  • PHP第三方登录—QQ登录实现方法
  • PHP简单实现单点登录功能示例

本文由金沙贵宾会官网发布于网络安全,转载请注明出处:php的sso单点登陆完毕格局,登入验证示例代码

关键词:

php跨域调用json的例子,php利用json数据实现跨域操

:某网站后台用php脚本得到一个JSON格式的数据,交给前台javascript进行处理,使用JSON实现数据的跨域调用 后台profil...

详细>>

php打印输出棋盘的实现方法,php入门学习知识点

php教程 打印乘法口绝表代码 刚才php是经常老师会要我们做这个的题目,今天我再做一次打印乘法口绝 复制代码 代码...

详细>>

php面向对象的封装性说明,php面向对象全攻略

?php教程 /*  * 封装性:面向对象三大特性之一  *  *1.就是把对象的成员(属性,方法)结合成一个独立的相同单位,并尽...

详细>>

php页面缓存方法小结,PHP页面缓存实现的方法总

} } ob_start():页面缓存开始的标志,此函数一下的内容直至ob_end_flush()或者ob_end_clean()都保存在页面缓存中; ob_get_co...

详细>>