zoukankan      html  css  js  c++  java
  • ucenter的单点登录

    所谓单点登录,无非就是几个站点共用一个用户中心,实现同步登陆,同步退出。

    服务器端:Loog SSO 。

    客服端: ucenter,说实话dz商业化确实让php发展了不少。

    ucenter 基本原理:
    说说ucenter的单点登录
    其实最终还是 用户去登录 只是采用了ajax 用户不会发现。

    我们来看看和ucenter的具体程序:
    config.php

    PHP代码
    1. define('UC_CONNECT', 'mysql');    // 连接 UCenter 的方式: mysql/NULL, 默认为空时为fscoketopen()   
    2. //数据库相关 (mysql 连接时, 并且没有设置 UC_DBLINK 时, 需要配置以下变量)   
    3. define('UC_DBHOST', 'localhost');            // UCenter 数据库主机   
    4. define('UC_DBUSER', 'root');                // UCenter 数据库用户名   
    5. define('UC_DBPW', '123');                    // UCenter 数据库密码   
    6. define('UC_DBNAME', 'ucenter');                // UCenter 数据库名称   
    7. define('UC_DBCHARSET', 'utf8');                // UCenter 数据库字符集   
    8. define('UC_DBTABLEPRE', 'ucenter.uc_');        // UCenter 数据库表前缀   
    9. define('UC_KEY', 'safefewfef');                // 与 UCenter 的通信密钥, 要与 UCenter 保持一致   
    10. define('UC_API', 'http://www.taoav.com/uc');// UCenter 的 URL 地址, 在调用头像时依赖此常量   
    11. define('UC_CHARSET', 'utf-8');                // UCenter 的字符集   
    12. define('UC_IP', '127.0.0.1');                // UCenter 的 IP, 当 UC_CONNECT 为非 mysql 方式时, 并且当前应用服务器解析域名有问题时, 请设置此值   
    13. define('UC_APPID', '3');                    // 对应到ucenter当前应用的 ID  
    14. define('UCDOMAIN','http://www.taoav.com/');    //   域名设置   
    15.      
    16. //一些 Cookie 设置   
    17. $_UC = array();   
    18. $_UC["cookiedomain"] = '';             // cookie 作用域   
    19. $_UC["cookiepath"] = '/';            // cookie 作用路径   
    20. $_UC["cookiepre"] = 'uc_';     // cookie 前缀   
    21. $_UC["cookietime"] = '31536000';    //cookie 作用时间   

    配置文件写好后,到ucenter后台里面添加一个应用记住是自定义的 ‘UC_KEY’必须和config.php里面相同
    接下来就是你的主目录下的api/uc.php
    例如应用url 填写为 http://www.taoav.com 那么我就有对应的http://www.taoav.com/api/uc.php
    如果要自定义的话 请确认你的对应关系。

    最重要的就是api/uc.php ,同步登录就是访问各个应用的uc.php 关于这个dz已经给了demo
    developguide

    PHP代码
    1. define('API_DELETEUSER',0);        //note 用户删除 API 接口开关   
    2. define('API_RENAMEUSER', 0);        //note 用户改名 API 接口开关   
    3. define('API_GETTAG', 0);        //note 获取标签 API 接口开关   
    4. define('API_SYNLOGIN', 1);        //note 同步登录 API 接口开关   
    5. define('API_SYNLOGOUT', 1);        //note 同步登出 API 接口开关   
    6. define('API_UPDATEPW', 0);        //note 更改用户密码 开关   
    7. define('API_UPDATEBADWORDS', 0);    //note 更新关键字列表 开关   
    8. define('API_UPDATEHOSTS', 0);        //note 更新域名解析缓存 开关   
    9. define('API_UPDATEAPPS', 0);        //note 更新应用列表 开关   
    10. define('API_UPDATECLIENT', 0);        //note 更新客户端缓存 开关   
    11. define('API_UPDATECREDIT', 0);        //note 更新用户积分 开关   
    12. define('API_GETCREDITSETTINGS', 0);    //note 向 UCenter 提供积分设置 开关   
    13. define('API_GETCREDIT',0);        //note 获取用户的某项积分 开关   
    14. define('API_UPDATECREDITSETTINGS', 0);    //note 更新应用积分设置 开关   

    这些参数都是向别的应用提供的功能开关

    最后关于 自己的页面如何同步登录 别的应用

    PHP代码
    1. include_once '../config.php';   
    2. include_once '../uc_client/client.php';   
    3.      
    4. 你的验证登录部分   
    5. list($uid, $username, $password) = uc_user_login($_POST[username], $_POST[password]);//进入ucenter验证   
    6. $ucsynlogin = uc_user_synlogin($uid);//同步登录   
    7. echo $ucsynlogin;//因为是ajax 要echo   

    只用php,康盛的解决方案是比较不错的了,而且利用了p3p头实现了 不同域名 单点登录
    缺点就是采用ajax 客服端请求 ,如果有10个以上应用,登录速度就慢下来了。这时候就可以考虑下七夜的Loong SSO
    了解了以上的东东 php的CMS和ucenter通信 就不难了

  • 相关阅读:
    Oracle中优化SQL的原则(转贴)
    Oracle的分页查询
    Oracle中存储过程和Sql语句的优化重点
    oracle中sql语句的优化
    Oracle中优化SQL的原则(转贴)
    Oracle group by 用法实例详解
    Oracle中group by用法
    一本超越期待的 C++ 书——简评《Boost程序库完全开发指南:深入C++“准”标准库》
    以小见大——那些基于 protobuf 的五花八门的 RPC(2)
    BizTalk请求JAVA的Web Service报错
  • 原文地址:https://www.cnblogs.com/jthb/p/5086617.html
Copyright © 2011-2022 走看看