discuz自带ucenter,主要就是用于和其他程序的通信.我们可以下载discuz的ucenter开发手册进行magento和discuz的集成.里面有一些ucenter的一些接口函数和参数说明,没有这个文档,最模板就无法进行下面:

1、把api和uc_client目录放在应用程序的跟目录.

2、修改自己的配置文件(application/config/config.ini),在最后加上下面的代码:代码如下

[ucenter]
uc.UC_ON = 0
uc.UC_CONNECT = mysql
uc.UC_DBHOST = localhost
uc.UC_DBUSER = root
uc.UC_DBPW = vertrigo
uc.UC_DBNAME = ucenter
uc.UC_DBCHARSET = utf8
uc.UC_DBTABLEPRE = ucenter.uc_
uc.UC_KEY = 123456789
uc.UC_API = http://localhost/comsenz/ucenter15
uc.UC_CHARSET = utf-8
uc.UC_IP =
uc.UC_APPID = 1

复制代码

上面的各项一看就知道啥意思了,uc.UC_ON是系统中是否开启ucenter同步的开关,1:打开,0:关闭。注意uc.UC_KEY必须和 ucenter中设置

应用的key一致不然会显示通信失败。

3、修改index.php入口文件,加入配置解析,代码如下:

代码如下

//ucenter配置
Zend_Registry::set('UC_ON',$config->ucenter->uc->UC_ON);
if (Zend_Registry::get('UC_ON')) {
    define('UC_CONNECT', $config->ucenter->uc->UC_CONNECT);         // mysql 是直接连接的数据库, 为了效率, 建议采用 mysql
    define('UC_DBHOST', $config->ucenter->uc->UC_DBHOST);           // UCenter 数据库主机
    define('UC_DBUSER', $config->ucenter->uc->UC_DBUSER);           // UCenter 数据库用户名
    define('UC_DBPW', $config->ucenter->uc->UC_DBPW);               // UCenter 数据库密码
    define('UC_DBNAME', $config->ucenter->uc->UC_DBNAME);           // UCenter 数据库名称
    define('UC_DBCHARSET', $config->ucenter->uc->UC_DBCHARSET);     // UCenter 数据库字符集
    define('UC_DBTABLEPRE', $config->ucenter->uc->UC_DBTABLEPRE);   // UCenter 数据库表前缀
    define('UC_KEY', $config->ucenter->uc->UC_KEY);                 // 与 UCenter 的通信密钥, 要与 UCenter 保持一致
    define('UC_API', $config->ucenter->uc->UC_API);                 // UCenter 的 URL 地址, 在调用头像时依赖此常量
    define('UC_CHARSET', $config->ucenter->uc->UC_CHARSET);         // UCenter 的字符集
    define('UC_IP', $config->ucenter->uc->UC_IP);                   // UCenter 的 IP
    define('UC_APPID', $config->ucenter->uc->UC_APPID);             // 当前应用的 ID
    include './uc_client/client.php';
}

复制代码

好了,准备工作完成了,下面要进行程序开发了。

4、登陆同步的实现,下面的代码有点长,因为我是开始没有集成ucenter,后来新增的ucenter,所以做了兼容性,兼顾了没有开启ucenter 的

登录。

代码如下

//如果开启了ucenter
if ($this->is_uc_on) {
    //通过接口判断登录帐号的正确性,返回值为数组
    list($uid, $username, $password, $email) = uc_user_login($username, $password);
    if($uid > 0) {
        //判断用户是否存在于用户表,不存在则跳转到激活页面
        if($this->user->checkUserValid($username)) {
             //将这些用户信息写入cookie,用于激活页面
             @setcookie('zf_auth', uc_authcode($uid."t".$username."t".$password."t".$email, 'ENCODE'),time()+3600,'/');
             $this->view->securl = $this->view->domain.'/user/activation';
             $this->view->msg = '您需要需要激活该帐号,才能进入本应用程序!';
             echo $this->view->render('success.php');
             exit;
        }
        //用户登陆成功,设置 Cookie
        $udata = array('id'=>$uid,'username'=>$username,'role'=>'member');
        $expire = 86400;
        $this->setCookie($udata,$expire);
                  
        //生成同步登录的代码
        $ucsynlogin = uc_user_synlogin($uid);
        $this->view->securl = $this->view->domain;
        $this->view->msg = '登录成功,正在跳转回首页!';
        echo $this->view->render('success.php');
    } elseif($uid == -1) {
        $this->view->error = "用户不存在,或者被删除!";
        echo $this->view->render('error.php');exit;
    } elseif($uid == -2) {
        $this->view->error = "密码错误!";
        echo $this->view->render('error.php');exit;
    } else {
        $this->view->error = "系统错误,请稍候再试!";
        echo $this->view->render('error.php');exit;
    }
}
else    //没有采用uc的登录方式
{
    $dbAdapter = Zend_Registry::get('dbAdapter');
    $authAdapter = new Zend_Auth_Adapter_DbTable($dbAdapter);
    //$authAdapter->setTableName('bg_user');
    $authAdapter->setTableName(Zend_Registry::get('dbprefix').'user');
    $authAdapter->setIdentityColumn('username');
    $authAdapter->setCredentialColumn('password');
  
    $authAdapter->setIdentity($username);
    $authAdapter->setCredential($password);
  
    $auth = Zend_Auth::getInstance();
    $result = $auth->authenticate($authAdapter);
    if($result->isValid()){
        $data = $authAdapter->getResultRowObject(null,'password');
        //$auth->getStorage()->write($data);
        //写入cookie
        $udata = array('id'=>$data->id,'username'=>$data->username,'role'=>$data->role);
        $expire = 86400;
        $this->setCookie($udata,$expire);
        $this->view->securl = $this->view->domain;
        $this->view->msg = '登录成功,正在跳转回首页!';
        echo $this->view->render('success.php');
    }else{
        //用户名密码
        $this->view->error = "用户名密码错误!";
        echo $this->view->render('error.php');
        exit();
    }
}

好了,同步登录完成,接着就仿照上面的注销,修改密码,修改用户资料等都可以实现了。

magento和discuz(ucenter)整合集成开发思路的更多相关文章

  1. .net mvc通过ucenter和 discuz的整合,nopcommerce ucenter 插件的方式实现

    discuz无疑是目前市面上最好的论坛之一,对于大多数公司来说,用discuz搭建一个论坛肯定是最节约成本的选择,然而我们的会员想要和discuz进行整合的话,只有两种荀泽,一种直接选用discuz的 ...

  2. 【SSH】---【Struts2、Hibernate5、Spring4集成开发】【SSH框架整合笔记】

    Struts2.Hibernate5.Spring4集成开发步骤: 一.导入Jar包(基本的大致有41个,根据实际项目的需求自己添加) antlr-2.7.7.jar aopalliance.jar ...

  3. Spring+SpringMvc+Mybatis框架集成搭建教程三(框架整合测试程序开发)

    框架整合测试程序开发 (1).在mysql数据库中创建t_user表,sql语句如下 CREATE TABLE `t_user` ( `id` bigint(20) NOT NULL AUTO_INC ...

  4. 【超全整理】J2EE集成开发环境MyEclipse使用心得汇总

    一.首先我们为什么需要MyEclipse? 下面允许我做一些简要的介绍: 应该大家都知道另一个MyEclipse的近亲——Eclipse的优点:免费.程序代码排版功能.有中文汉化包.可增设许多功能强大 ...

  5. ucenter 整合外部网站,实现登录等操作

    最近公司网站要出手机版,由于与论坛要有互通,实现会员的共享,由于对discuz不熟悉,起先考虑的是直接读取discuz的用户表,然后进行判断等操作,发现过于复杂,而且安全也不好. 前一段时间进行过论坛 ...

  6. IDE 集成开发环境

    集成开发环境(IDE,Integrated Development Environment )是用于提供程序开发环境的应用程序,一般包括代码编辑器.编译器.调试器和图形用户界面工具.集成了代码编写功能 ...

  7. ENVI/IDL与ArcGIS集成开发的三种途径

    转载:本文来自ENVI5.0-IDL8.2系列产品白皮书_201303.PDF(Esri中国官网可下载)中P7-P10 ENVI 是一个非常开放的平台,提供一个健全的函数库,几乎涵盖ENVI 平台大部 ...

  8. Android常见开发思路

    开发思路 刷新: 重新获取数据 清空list 更新适配器 关闭进度条. 加载更多 1. 重新获取数据 添加list 更新适配器 添加轮播条. 自己设计轮播条View 引入lib库文件 设置轮播条数据. ...

  9. 织梦系统与discuz论坛整合方法

    如何完成dedecms模板系统与discuz论坛整合呢? 这里的整合指会员信息,会员登陆.退出的同步:论坛信息的引用:等等. 首先,我们先来安装织梦(dedecms)系统. 然后,我们在网站根目录下建 ...

随机推荐

  1. 开源牛人 zcbenz

    事情是这样的,微软推出了Visual Studio Code,我很好奇他怎么做跨平台的,所以就找找资料,在他的网站中是这么描述的: Architecturally, Visual Studio Cod ...

  2. Java 正则表达式 向前、向后匹配

    //向后匹配 String a = "I paid $90 for 10 oranges, 12 pears and 8 apples. I saved $5 on "; Patt ...

  3. backbonejs中的模型篇(二)

    一:模型标识符 每个模型都有一个用作唯一标识符的ID属性,以便在不同模型间进行区分.通过id属性我们可以直接访问模型对象当中用于标识符存放的属性,默认属性名为id,但也可以通过设置idAttribut ...

  4. MySQL索引实现

    摘自:http://blog.codinglabs.org/articles/theory-of-mysql-index.html 在MySQL中,索引属于存储引擎级别的概念,不同存储引擎对索引的实现 ...

  5. webApi跨域

    <system.webServer> <httpProtocol> <customHeaders> <add name="Access-Contro ...

  6. bzoj 2330: [SCOI2011]糖果

    #include<cstdio> #include<iostream> using namespace std; ],next[],u[],v[],h,t,a[]; ],f[] ...

  7. SQL Server 自定义字符串分割函数

    一.按指定符号分割字符串,返回分割后的元素个数,方法很简单,就是看字符串中存在多少个分隔符号,然后再加一,就是要求的结果(标量值函数)   create function Func_StrArrayL ...

  8. Oracle连接的若干错误

    用PL/SQL连接Oracle时会抛若干错误,如下: 1.ora-12154:TNS:无法解析指定的连接标识符 答:plsql在%Oracle_Home%\Network\Admin或者c:\inst ...

  9. 【NOIP2015】提高组D1 解题报告

    P1978神奇的幻方 Accepted 描述 幻方是一种很神奇的 N ∗ N 矩阵:它由数字 1,2,3, … … , N ∗ N 构成,且每行.每列及两条对角线上的数字之和都相同. 当 N 为奇数时 ...

  10. 【STL】-迭代器的用法

    初始化: list<char>::iterator pos; 算法: 1. 遍历 for(pos = col1.begin(); pos != col1.end(); ++pos){... ...