精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2011-01-25
最后修改:2011-01-25
之前网站结合的是一个基于jsp的论坛,对于相同的平台,所以用户接入不是什么问题。因为总总原因,现决定采用discuz的解决方案。 第一:关于discuz版本,目前discuz最新的发布版本是discuz!x 1.5。较之前7.0版本前,与之相关最大的区别就是以往用来做用户接入的api更换了。7.0之前是passport。实现的原理与我们之前结合jsp论坛有点类似,论坛在注册 登录 退出3个关键的地方,会在url后带一系列参数,简单的描述,实质就是调用的注册,登录都是主站的。相当于隐藏了论坛自身的登录注册等模块,只是把主站的用户数据按照规则同时写入论坛,另外同步好两个站点直接的cookie,session就好了。呵呵,个人感觉这种实现其实蛮好的,论坛只是依附在主站上。认证登录都很统一。但在目前sns大行其道的年代,网站也不仅仅只局限跟自己交互,总希望更好的扩展,聚合更多的东西。所以才有了如下的解决方案--ucenter。这里把它从discuz独立出来。事实上康盛也确实把它作为一个独立的产品发布的。 第二:java网站结合uc,首先明确uc的概念 UCenter 简介 UCenter 的中文意思就是“用户中心”,其中的 U 代表 User 也代表 You,取其中的含义就是“用户中心”,或者说“你(最终用户)的中心”。UCenter 是今后 Comsenz 旗下各个产品之间信息直接传递的一个桥梁,通过 UCenter 站长可以无缝整合 Comsenz 系列产品,甚至其它更多的第三方应用程序,实现用户的一站式登录,个人信息、积分等的统一管理。 第三:uc的java api http://code.google.com/p/discuz-ucenter-api-for-java/ 操作步骤: 1:设置通信,进uc后台配置http://faq.comsenz.com/usersguide 2:修改自己的网站,将上面提到的java api中的代码或者jar包添加到自己的项目中,着重配置好config.properties # # ================================================ # * Discuz! Ucenter API for JAVA # ================================================ # UC comunication settings # # #uc server url UC_API = http://192.168.1.109/bbs/uc_server #你的uc api接口地址 #uc ip address UC_IP = 192.168.1.109 #key UC_KEY = ********* #跟上步设置的私匙 key一样 #appid UC_APPID = 2 #应用id #connect mode: default value is "" UC_CONNECT = mysql 3:修改注册 登录 退出相关代码 注册-- Client uc = new Client(); String $returns = uc.uc_user_register(user.getUsername(), "***", user.getEmail()); int $uid = Integer.parseInt($returns); if ($uid <= 0) { if ($uid == -1) { System.out.print("用户名不合法"); } else if ($uid == -2) { System.out.print("包含要允许注册的词语"); } else if ($uid == -3) { System.out.print("用户名已经存在"); } else if ($uid == -4) { System.out.print("Email 格式有误"); } else if ($uid == -5) { System.out.print("Email 不允许注册"); } else if ($uid == -6) { System.out.print("该 Email 已经被注册"); } else { System.out.print("未定义"); } } else { System.out.println("OK:" + $returns); } 登录-- Client e = new Client(); String result = e.uc_user_login("username", "password"); LinkedList[String> rs = XMLHelper.uc_unserialize(result); if(rs.size()>0){ int $uid = Integer.parseInt(rs.get(0)); String $username = rs.get(1); String $password = rs.get(2); String $email = rs.get(3); if($uid > 0) { System.out.println("登录成功"); System.out.println($username); System.out.println($password); System.out.println($email); String $ucsynlogin = e.uc_user_synlogin($uid); System.out.println("登录成功"+$ucsynlogin); //本地登陆代码 //TODO ... .... } else if($uid == -1) { System.out.println("用户不存在,或者被删除"); } else if($uid == -2) { System.out.println("密码错"); } else { System.out.println("未定义"); } }else{ System.out.println("Login failed"); System.out.println(result); } $ucsynlogin 这里着重注意下这里,在你的action或者servlet类中得到调用接口返回的该字符串值, <script type="text/javascript" src="http://192.168.1.109/bbs/api/uc.php?time=1295926163&code=c8d08KSlEZlDk4tTsjChzRYzZp2EpUierc%2FS3NLnFUviig8HvTnDNymm080JxI8Byl%2F1TW%2FveKQRlR14Io9pvR9eMD1F%2FAH3l1tuzWt3Rw9MQLrK5Lz0q8eMn5%2BAae92YBwwNlWiFWHyfyh%2FzUNC%2FA3HFnEgdX%2F61IwV" reload="1"></script><script type="text/javascript" src="http://www.***.com/api/uc.php?time=1295926163&code=8a5b92lMQgq2AOw7mnIr3hlDJz5NGbKYnePP7987khS40SJquzXL2BYDiBSrTVYGb5XkZw18tc0w4ICeueEL91lLCqC7gMFopnhecbXtMZekpb0%2FRcb7P0eLWmNhlCKF5yb6zbBuT4SyAs8eJ9rBwasUCcohh5Ch475M" reload="1"></script>这段是要输出到页面的,一定!其实原理就是相当于让浏览器去访问下自己应用与另外一个应用,分别同步下双方的cookie等操作。 res.setContentType("text/html"); res.setCharacterEncoding("utf-8"); res.getWriter().write("成功登陆论坛" + $ucsynlogin);最后注意这里输出后页面不要随便跳转到新的页面。这个很重要。所以我在action中return返回的是null。 登出-- //登出同步 Client uc = new Client(); //setcookie('Example_auth', '', -86400); //生成同步退出的代码 String $ucsynlogout = uc.uc_user_synlogout(); System.out.println("退出成功"+$ucsynlogout); if ($ucsynlogout != null) { HttpServletResponse res = getResponse(); System.out.println($ucsynlogout); res.reset(); res.setContentType("text/html"); res.setCharacterEncoding("utf-8"); res.getWriter().write("成功登出" + $ucsynlogout); return null; } 基本上,就是如上面那些步骤咯。 还是比较简单的。 参考链接 http://www.iteye.com/topic/750323 http://code.google.com/p/discuz-ucenter-api-for-java/ http://faq.comsenz.com/usersguide 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2011-01-25
整合不錯。不過Java代碼中混合php的命名方式,感覺很不舒服。
|
|
返回顶楼 | |
发表时间:2011-01-25
uc思想值得借鉴,是整合和统一的关键一步
|
|
返回顶楼 | |
发表时间:2011-01-26
xnnyygn 写道 整合不錯。不過Java代碼中混合php的命名方式,感覺很不舒服。
呵呵,是的,不过 偶尔有点这样的变量 代码更醒目,也不错 |
|
返回顶楼 | |
发表时间:2011-01-26
人月神话 写道 uc思想值得借鉴,是整合和统一的关键一步
确实,什么东西都是在发展,不过uc还是很对问题,有待完善 |
|
返回顶楼 | |
发表时间:2011-01-26
xnnyygn 写道 整合不錯。不過Java代碼中混合php的命名方式,感覺很不舒服。
确实 同感 不舒服 |
|
返回顶楼 | |
发表时间:2011-02-10
前一段时间研究过uc整合的问题,其中关于用户密码修改的问题,在传递密码时,参数带过去的值是空值,这一点我过康盛的人,他们说不推荐修改密码,所以他们这里功能还没做。那请问你是如何处理这里的呢?
|
|
返回顶楼 | |
发表时间:2011-02-11
chris_zcl 写道 前一段时间研究过uc整合的问题,其中关于用户密码修改的问题,在传递密码时,参数带过去的值是空值,这一点我过康盛的人,他们说不推荐修改密码,所以他们这里功能还没做。那请问你是如何处理这里的呢?
更新用户资料 integer uc_user_edit(string username , string oldpw , string newpw , string email [, bool ignoreoldpw, integer questionid , string answer]) 函数参数 参数 含义 string username 用户名 string oldpw 旧密码 string newpw 新密码,如不修改为空 string email Email,如不修改为空 bool ignoreoldpw 是否忽略旧密码 1:忽略,更改资料不需要验证密码 0:(默认值) 不忽略,更改资料需要验证密码 integer questionid 安全提问索引 string answer 安全提问答案 返回值 值 含义 integer 1:更新成功 0:没有做任何修改 -1:旧密码不正确 -4:Email 格式有误 -5:Email 不允许注册 -6:该 Email 已经被注册 -7:没有做任何修改 -8:该用户受保护无权限更改 本接口函数用于更新用户资料。更新资料需验证用户的原密码是否正确,除非指定 ignoreoldpw 为 1。如果只修改 Email 不修改密码,可让 newpw 为空;同理如果只修改密码不修改 Email,可让 email 为空。 $ucresult = uc_user_edit($_POST['username'], $_POST['oldpassword'], $_POST['newpassword'], $_POST['emailnew']); if($ucresult == -1) { echo '旧密码不正确'; } elseif($ucresult == -4) { echo 'Email 格式有误'; } elseif($ucresult == -5) { echo 'Email 不允许注册'; } elseif($ucresult == -6) { echo '该 Email 已经被注册'; }这个是官方自带手册上的php版本。实现原理,应该跟注册登录的时候 把用户写入到uc类似。 |
|
返回顶楼 | |
发表时间:2011-04-14
同感,很不舒服。还是觉得纯java代码看起来爽。
|
|
返回顶楼 | |
发表时间:2011-05-19
实现的java工程与disucz的 用户整合,但是,在注册新用户后,在调用登录方法,并没有同步,但是,如果再一次,从论坛登录,激活用户。第二次再从Java端登录。就可以实现同步了。怎么让他不需要激活?》
|
|
返回顶楼 | |