下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、基于 UC 的 PHP 产品免激活整合文 / 刘鹏本文将以 UCenter 、 UCHome 、 Discuz !、 SupeSite 为基础进行讲解,文中提及的方法同样适用 于其它非康盛产品,只要是通过 UCenter 进行整合的,都可用文中提到的方法。下面我就和大家一起 学习一下吧。一、安装产品安装 UCenter 的过程就不必多讲了,大家应该在无数次的实践中已经可以做到闭着眼装了。所以 我们此步略过。其他产品的安装才是我们重点要了解的。为了更快捷的完成产品的安装, UCenter (以下简称 UC )中为我们提供了应用管理的功能,每 个产品对于 UC 来说,都是一个应用。我们通过 UC
2、提供的应用管理功能来安装其他产品。我们在输入框中输入需要安装的应用的安装地址,然后点击安装。点击安装按钮之后我们将进入 SupeSite 的安装过程,在安装过程中系统会自动把 UC 的信息获取 到,然后写入相应的表中。整个流程完成之后,我们返回应用管理功能,会看到这样的信息。系统提示我们安装了那个应用,访问地址是什么。然后通信状态告诉我们成功。这种 情况下,我们的 SupeSite 就安装好了。其他的应用我们也按照这个步骤来安装,需要注意 的是,我们需要把所有的应用的数据库都指向同一个数据库,当然也可以分开,但是个人 建议合在一起比较好。上图告诉我们,三个应用都已经安装好了,而且通信都成功,所
3、以目前三个应用已经可以实现同步 登陆了。我们实际中到网站中去做测试,我们在 SupeSite 登陆后,我们发现在其他的应用中我们需要刷新 一次,然后我们就能看到我们的个人信息了。同时我们发现三个应用的登陆已经同步完成。我们在任何一个应用中点击退出,再到其他应用中刷新一下,我们会看到,所有的应用都已经是未 登陆状态。 至此, 最简单的同步登陆设置已经完成。 但是本文所要讲述的, 可不仅仅是这一点点东西哦, 更进一步的东西,我们慢慢道来。二、用户注册现在这种情况下, 我们在不同的应用进行注册操作, 我们会发现注册后可以在注册的应用正常登陆, 如果在 SupeSite 注册,登录后,我们去访问 Di
4、scuz !,我们会发现 Discuz !要求我们进行激活,点击 激活后我们会进行一次登陆的操作。此次登陆操作结束之后,我们以后就可以进行正常的同步登陆,而 不需要再进行其他操作了。现在我们要解决的就是激活和需要再登录一遍的问题。在此之前,我们需要了解一下问题产生的原 因。我们要注意下以下四个表:Cdb_membersSupe_membersUchome_member Uc_members当我们在不同的产品的注册接口进行注册以后,都会向 uc_members 和本产品的 members 表里 写入用户信息,并不向其他的用户表写入信息。而已知的每一个产品都是可以独立使用的。也就是说我 们需要向每
5、一个用户表中写入用户信息。当然这个信息不能随便写入,要遵守一定的规则。所有的用户 ID 都应该与 UC 中的用户 ID 一致,从而达到同步操作。 有用户信息关联表的,要激活关联表中的信息。除 UC 的密码字段有效外,其他应用的密码字段无效。 统一用户验证必须使用 UC 的接口,而不是应用本身的接口。我们将以 UCHome 为例进行修改/ 更新本地用户库inserttable( member , $setarr , 0, true );/ 开通空间 include_once (S_ROOT . ./source/function_space.php );$s我pa们ce打=开 spsaocue_
6、rcoep/edno(_re$gnieswteuri.dph,p $username , 0, $email );我们看到有注释告诉我们更新本地用户库,也就是说这个方法是将刚才的注册信息写入 uchome_member 表中的地方。我们需要做的呢就是把向 SupeSite 和 Discuz !中用户表写入数据的 语句放在这里执行。/ 添加数据 function inserttable ( $tablename , $insertsqlarr , $returnid =0 , $replace = false , $silent =0 ) global $_SGLOBAL ;$insertkey
7、sql = $insertvaluesql = $comma = ;foreach ( $insertsqlarr as $insert_key = $insert_value ) $insertkeysql .= $comma . .$insert_key . ;$insertvaluesql .= $comma . .$insert_value . ;$comma = , ;$method = $replace ? REPLACE : INSERT ;$_SGLOBAL db - query ( $method . INTO .tname( $tablename ). ( .$insert
8、keysql .) VALUES ( .$insertvaluesql .) , $silent ?SILENT :);if ( $returnid & ! $replace ) return $_SGLOBAL db - insert_id (); 我们首先打开 source/function_common.php如上脚本所示的这个函数,我们需要为他做一个小手术,让他更符合我们的要求。/ 添加数据function inserttable ( $tablename , $insertsqlarr , $returnid =0 , $replace = false , $silent =0 $d
9、b = uchome ) global $_SGLOBAL ;$insertkeysql = $insertvaluesql = $comma = ;foreach ( $insertsqlarr as $insert_key = $insert_value ) $insertkeysql .= $comma . .$insert_key . ;$insertvaluesql .= $comma . .$insert_value . ;$comma = , ;$method = $replace ?REPLACE : INSERT ; if ($db = uchome )$_SGLOBAL d
10、b - query ( $method . INTO .tname( $tablename ). ( .$insertkeysql .) VALUES ( . $insertvaluesql .) , $silent ? SILENT :); else $_SGLOBAL db - query ( $method . INTO .$tablename . ( .$insertkeysql .) VALUES ( .$insertvaluesql .) , $silent ?SILENT : );if ( $returnid & ! $replace ) return $_SGLOBAL db
11、- insert_id (); 经过上面修改之后,这个函数就可以为我们提供便捷的数据库操作了。/ 更新本地用户库inserttable( member , $setarr , 0, true );/ 插入到 states 表中inserttable( states , $setarr_states , 0, true );inserttable( supe_member , $setarr , 0, true , 0 ,supesite ); / 更新 supesite 用户库inserttable( cdb_member , $setarr_cdb , 0,false ,0,discuz )
12、; / 更新 discuz 用户库以后我们只要按上图的方法向里面传参数就可以加入相应的数据了,至于 $setarr 这个数组都有什 么,还希望读者自己去研究,毕竟有可供参考的了。现在我们也只是实现了一次注册,所有的应用都可用,也就是说我们已经实现了基于 UCHOME 的 单点注册登陆,现在注册完成了,我们还需要调用一下全局登陆的方法。我们通过实际的操作发现,注册完成后, UCHome 会自动跳向 space.php 。所以接下来我们就要 在 space.php 做文章。我们在 space.php 的最后加上红圈中的两行代码,首先我们要把 UC 的操作接口文件加载进来, 然后调用全局登陆方法,
13、把当前用户的 ID 传过去。 这样以后, 会返回一个字符串, 我们将其存放在 $login 这个变量中。 我们需要把这个字符串输出才能实现全局登陆, 如果我们在这里直接 echo $login 的话, 这个字符串会出现在页面的最上面一行,会造成页面的整体偏移,所以我们将他输出到我们希望他出现的地方。我们选择了 header.htm$login我们选择在 标签结束的时候输出这行字符串,这样的话,页面就不会出现问题,这行字 符串的具体内容有心的读者请自己去看吧。我就不截图给大家了。所有的操作执行到现在,我们已经可以在注册的时候向各个应用同时写入用户数据,避免了激活的 操作;同时我们也调用了全局登陆的方法,使得注册成功就可以在各个应用同时登录。本文的目的也就 达到了。其中还有一些技巧和方法在此留点儿悬念,让大家自己去思考。最后我们总结一下,首先我们需要 UC 的支持,让所有的应用在 UC 下通信成功,然后去修改一个 应用的注册文件,在写入数据库的时候分别向其他表写入数据
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 图书馆卫生间管理规定
- 纪录片编剧服务协议
- 体育运动区房产交易样板
- 研发部门休假管理方案
- 学校地暖工程服务合同
- 旅游推广记者站管理办法
- 电力设施电子招投标竞争格局
- 精密仪器电焊工招聘合同
- 墙绘施工合同公园景观墙绘
- 房屋户外景观水景施工合同
- “麦语言”函数手册
- 五年级上册数学教案-平行四边形的认识- 沪教版
- 2022年五子棋活动记录
- 10t单梁起重机安装方案
- 临床医疗教学之127:冠心病合并心房颤动患者抗栓管理中国专家共识2020版课件
- 腰椎间盘突出区域定位及意义
- 天蓝色商务发展历程时间轴PPT模板课件
- 急腹症(课堂PPT)
- 某市康复医院建立的可行性报告
- 配位化学 第2章 配合物的结构和成键理论
- 化妆品半成品成品检验规程
评论
0/150
提交评论