论坛首页 Java企业应用论坛

关于网站用户接入,单点登录,discuz,ucenter

浏览 19445 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2011-01-25   最后修改:2011-01-25
   经过多番尝试,终于将现有网站与discuz接入成功。具体思路和做法下面会给出详细的描述。希望对别人也有所帮助。进入正题。
   之前网站结合的是一个基于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


   发表时间:2011-01-25  
整合不錯。不過Java代碼中混合php的命名方式,感覺很不舒服。
0 请登录后投票
   发表时间:2011-01-25  
uc思想值得借鉴,是整合和统一的关键一步
0 请登录后投票
   发表时间:2011-01-26  
xnnyygn 写道
整合不錯。不過Java代碼中混合php的命名方式,感覺很不舒服。

呵呵,是的,不过 偶尔有点这样的变量 代码更醒目,也不错
0 请登录后投票
   发表时间:2011-01-26  
人月神话 写道
uc思想值得借鉴,是整合和统一的关键一步

确实,什么东西都是在发展,不过uc还是很对问题,有待完善
0 请登录后投票
   发表时间:2011-01-26  
xnnyygn 写道
整合不錯。不過Java代碼中混合php的命名方式,感覺很不舒服。

确实 同感 不舒服
0 请登录后投票
   发表时间:2011-02-10  
前一段时间研究过uc整合的问题,其中关于用户密码修改的问题,在传递密码时,参数带过去的值是空值,这一点我过康盛的人,他们说不推荐修改密码,所以他们这里功能还没做。那请问你是如何处理这里的呢?
0 请登录后投票
   发表时间: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类似。
0 请登录后投票
   发表时间:2011-04-14  
同感,很不舒服。还是觉得纯java代码看起来爽。
0 请登录后投票
   发表时间:2011-05-19  
实现的java工程与disucz的 用户整合,但是,在注册新用户后,在调用登录方法,并没有同步,但是,如果再一次,从论坛登录,激活用户。第二次再从Java端登录。就可以实现同步了。怎么让他不需要激活?》
0 请登录后投票
论坛首页 Java企业应用版

跳转论坛:
Global site tag (gtag.js) - Google Analytics