php ucword,ThinkPHP3.1.2整合UCenter详解(二)

这篇博客详细介绍了如何在ThinkPHP3.1.2中整合UCenter,包括复制相关文件、创建配置文件、配置uc.php、在UCenter后台添加应用等步骤。在配置过程中遇到的db_mysql.class.php文件缺失的问题,通过修改uc.php文件并引入正确的数据库类文件得以解决,最终实现通信成功。
摘要由CSDN通过智能技术生成

在ThinkPHP3.1.2整合UCenter详解(一) 中我们安装完了WBlog3.1.2、UCenter_Home_2.0_SC_UTF8和UCenter 1.6.0三个程序后。接下来接着上一篇讲。找到下载的UCenter 1.6.0,把 advanced 目录里面的

uc_client 和 examples下面的api 文件夹复制到网站根目录wblog1下,和ThinkPHP在同一目录。找到项目W3note的配置文件夹wblog1/ Conf/,在其新建一个UCenter的配置文件 config_ucenter.php ,然后在WBlog1\W3note\Lib\ORG目录下新建一个UCenter的通讯处理类文件UcService.class.php,我们先不要管文件里面写什么代码,后面将会讲到。好了到这里已经把后面要操作的目录和文件都布局好了。为了理清目录和文件之间的层次关系,我把目录和文件制成目录树列出来:

wblog1根目录

|  –  index.php//前台入口文件

|  –  admin.php

|  –  W3note//前台项目

|           |  – Lib

|           |       |  – ORG

|           |       |       |  –UcService.class.php //UCenter的通讯处理类文件

|           |  – Conf//W3note项目的配置目录

|           |       |  –config_ucenter.php //UCenter的配置文件

|           |

|  –  Admin

|  –  ThinkPHP //thinkphp3.1.2核心包和一些扩展

|  –  install

|  –  api

|       | –  uc.php

|

|  –  uc_client

|  –  ucenter

|  –  uh

这样我们就可以一目了然了。

现在开始api目录里面的uc.php 配置了,首先打开这个文件,找到36行的位置这一行代码

1

require_onceDISCUZ_ROOT.'./config.inc.php';

把'./config.inc.php'这一部分替换成'./W3note/Conf/config_ucenter.php'

往下找还会看到几处的'./config.inc.php',按照上面的操作全部替换掉。这样做目的是把前面建的配置文件config_ucenter.php导进来。  接下来我登录http://127.0.0.1/wblog1/ucenter,在打开左边菜单“应用管理”这一项,然后添加一个新应用,这时我们发现好多东西要填!

照着下面操作就是了。先看应用类型,因为这是我们自己开发的程序,所以就选其它吧,再看应用名称,随便填,只要不超过20字节就行了,我这里填wblog。接下来是应用的主URL,这里填网站的主页http;//127.0.0.1/wblog1,注意了,后面没有“/”。至于应用的其他URL还有应用IP这两项就跳过,不用管它了。接下来是通信密钥,就按其旁边的提示填就是了,我这里填abc123456。往下是应用的物路径,提示说默认为空,那就留空吧,还有查看个人资料页面地址也留空吧。接下来是应用接口文件名称,默认为uc.php,保持原状吧。继续往下看,标签单条显示模板还有标签模板标记说明这两项也不用理它,跳过。是否开启同步登录,选是;是否接受通知也选是吧。终于填完了,那就点击提交吧!

还记得前面在uc.php导入的文件config_ucenter.php吗,里面可是一片空白啊,现在我们就来放些配置信息进去。刚才我们填好的信息提交后,会在提交按钮下面的“应用的UCenter配置信息”下面生成了一些配置信息,我们直接把它复制,然后粘帖到config_ucenter.php,保存。

网上很多教程到这里就表示通信成功了,在这里我非常惊讶!因为通信并未成功!我在这里折腾了一些时间,后来仔细检了uc.php文件的代码,发现59行:

1

require_onceDISCUZ_ROOT.'./include/db_mysql.class.php';

我在布局的目录中始终找不到db_mysql.class.php,后来发现db_mysql.class.php存UCenter_1.6.0_SC_UTF8\advanced\examples\include目录中,这就是问题所在!因为我们之前复制的只是UCenter_1.6.0_SC_UTF8\advanced\examples\中的api文件。

解决这一问题的办法就是把上面的代码修改为

1

require_onceDISCUZ_ROOT.'./uc_client/lib/db.class.php';

导入的数据库类文件变了,那么我们也要对其所涉及的内容作相应的修改,在uc.php59行的下面如

1

$GLOBALS['db'] =newdbstuff;

2

$GLOBALS['db']->connect($dbhost,$dbuser,$dbpw,$dbname,$pconnect, true,$dbcharset);

3

$GLOBALS['tablepre'] =$tablepre;

修改为

1

$GLOBALS['db'] =newucclient_db;

2

$GLOBALS['db']->connect(UC_DBHOST, UC_DBUSER, UC_DBPW, UC_DBNAME, UC_DBCONNECT, true, UC_DBCHARSET);

3

$GLOBALS['tablepre'] = UC_DBTABLEPRE;//关键

上面数据库的链接信息的静态变量来自config_ucenter.php。

好了,我们回到后台ucenter刷新一下页面,发现什么---通信成功了!

如果按上面的操作还未通信成功的,请留言,有空我会回复!

本文首发网志博客,欢迎转载!转载请注明本文地址,谢谢。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值