Qeephp调整ucenter实现单点登陆之个人PHP项目与Ucenter整合

WBOY
发布: 2016-06-13 11:37:31
原创
1022 人浏览过

Qeephp整合ucenter实现单点登陆之个人PHP项目与Ucenter整合

前言

要实现使用ucenter单点登陆,则首先需要部署一个ucenter项目

一、下载ucenter程序

去Discuz官网下载一个ucenter程序

http://www.comsenz.com/downloads/install/ucenter

我下载的是下面这个版本的。

UCenter_1.6.0_SC_UTF8.zip


二、安装程序

php的安装环境我就不说了,将下载下来的ucenter程序部署完成。

我顺便部署了一下我的qeephp程序,这个和个人项目都是一样的,先保证运行正常。

我的配置:

ucenter域名:http://ucenter.webplus3.com

我的项目域名:http://www.nj-jz.com


三、开始整合

1、UCenter_1.6.0_SC_UTF8.zip解压

2、将advancedexamplesapi文件夹下的uc.php文件拷贝到你网站的根目录下的api文件夹中,若没有api则新建一个api文件夹(api文件夹一定要在网站的根目录中)

3、将advancedexamples文件夹下的include文件夹拷贝到你项目的根目录。文件夹内包含一个文件叫db_mysql.class.php,这是连接数据库的类。

4、将uc_client文件夹整个复制到你网站根目录,uc_client之前说了是接口代码,现在根目录已经有include和uc_client两个文件夹了。

5、复制advancedexamples文件夹内的config.inc.php到你网站的根目录,这是配置UCenter的配置文件。

6、在ucenter后台中添加新应用,截图如下:


其他属性默认,点击“提交”,保存应用!

此时返回应用列表,通信状态应该是失败的!

别急,我们再修改一下配置文件。


四、修改ucenter配置

1.编辑应用,在应用提交按钮的下方会有一段配置


将这段配置信息拷贝到第(三)2步提到的uc.php文件的最上方。

添加后的文件前20行(其中2-15行是拷贝过来的配置)如下:

<?phpdefine('UC_CONNECT', 'mysql');define('UC_DBHOST', 'localhost');define('UC_DBUSER', 'root');define('UC_DBPW', '12344');define('UC_DBNAME', 'web3_ucenter');define('UC_DBCHARSET', 'utf8');define('UC_DBTABLEPRE', '`web3_ucenter`.uc_');define('UC_DBCONNECT', '0');define('UC_KEY', '123456');define('UC_API', 'http://ucenter.webplus3.com');define('UC_CHARSET', 'utf-8');define('UC_IP', '');define('UC_APPID', '2');define('UC_PPP', '20');define('IN_DISCUZ', TRUE);define('UC_CLIENT_VERSION', '1.5.0');	//note UCenter 版本标识define('UC_CLIENT_RELEASE', '20081031');
登录后复制

同时按照这段配置信息更改第5步中说的config.inc.php文件里面相应的参数,使其与ucenter生成的配置信息保持一致。

<pre name="code" class="php"><?phpdefine('UC_CONNECT', 'mysql');// 连接 UCenter 的方式: mysql/NULL, 默认为空时为 fscoketopen()// mysql 是直接连接的数据库, 为了效率, 建议采用 mysql//数据库相关 (mysql 连接时, 并且没有设置 UC_DBLINK 时, 需要配置以下变量)define('UC_DBHOST', 'localhost');// UCenter 数据库主机define('UC_DBUSER', 'root');// UCenter 数据库用户名define('UC_DBPW', '12344');// UCenter 数据库密码define('UC_DBNAME', 'web3_ucenter');// UCenter 数据库名称define('UC_DBCHARSET', 'utf8');	// UCenter 数据库字符集define('UC_DBTABLEPRE', 'web3_ucenter.uc_');	// UCenter 数据库表前缀//通信相关define('UC_KEY', '123456');// 与 UCenter 的通信密钥, 要与 UCenter 保持一致define('UC_API', 'http://ucenter.webplus3.com');// UCenter 的 URL 地址, 在调用头像时依赖此常量define('UC_CHARSET', 'utf-8');	// UCenter 的字符集define('UC_IP', '');	// UCenter 的 IP//当 UC_CONNECT 为非 mysql 方式时, 并且当前应用服务器解析域名有问题时, 请设置此值define('UC_APPID', 2);	// 当前应用的 IDdefine('UC_PPP', '20');//同步登录 Cookie 设置$cookiedomain = ''; 			// cookie 作用域$cookiepath = '/';			// cookie 作用路径
登录后复制
以上步骤弄完后,回头再去看看你的ucenter后台,更新下缓存,再瞅瞅应用管理里面,看是不是已经通信成功了呢??


相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!