Rop开发手册(4):最简单的服务开放平台框架

会话管理概述  

一个客户端应用开发出来后,可以有很多具体的使用者。Rop使用应用键/密钥可以定位到一个具体的客户端应用,但却无法定位到客户端应用当前的使用者。服务开放平台必须开放一个用户登录的服务,在登录成功后分配一个sessionId。这样,应用用户后续对服务平台的服务调用都附上这个sessionId,服务端就可根据这个sessionId判断请求用户的身份了。 

Rop作为一个独立的框架,本身不提供具体的用户登录服务,但是它提供了一种管理用户会话的机制,以便管理用户会话并进行用户会话的评论。Rop在com.rop.session包中定义了两个用于会话管理的接口: 

  • Session:会话对象,该接口没有定义任何的方法,是一个标签接口;
  • SessionManager:会话管理器,该接口拥有3个方法,分别是addSession(String sessionId, Session session)、Session getSession(String sessionId)及void removeSession(String sessionId)。
在实际应用中,Session一般会拥有用户相关的数据,如用户信息、用户权限等。由于服务平台一般都是工作于分布式环境中,所以一般不适合直接使用Web服务器的会话管理机制(如HttpSession)来管理Rop的会话,应当使用数据库或集中式缓存服务器等设施来管理会话。 

创建会话、删除会话一般对应用户登录、用户退出两个服务,这两个具体的服务由服务开放平台开发,在服务方法中利用SessionManagerRop提供的会话管理功能注册和删除会话,以便让Rop获知会话的状态。 
Rop在RopRequestContext中提供了3个管理会话的方法,介绍如下: 

  • void addSession(String sessionId, Session session):将会话添加到会话管理器中;
  • Session getSession(String sessionId):根据sessionId获取会话对象;
  • void removeSession(String sessionId):根据sessionId从会话管理器中移除会话。
注册会话管理器  
rop-sample提供了一个基于一个Map管理的SampleSessionManager会话管理器,这里我们通过SampleSessionManager演示会话管理器的过程。在实际应用中,您应该使用基于集中式缓存(如memcached)或数据库(redis)等来管理会话。 

SampleSessionManager:基于Map的会话管理器 
Java代码   收藏代码
  1. package com.rop.sample;  
  2.   
  3. import com.rop.session.Session;  
  4. import com.rop.session.SessionManager;  
  5.   
  6. import java.util.Map;  
  7. import java.util.concurrent.ConcurrentHashMap;  
  8.   
  9. public class SampleSessionManager implements SessionManager{  
  10.   
  11.     private final Map<String, Session> sessionCache =         ①    
  12.  new ConcurrentHashMap<String, Session>(1280.75f, 32);  
  13.   
  14.     @Override  
  15.     public void addSession(String sessionId, Session session) {  
  16.         sessionCache.put(sessionId, session);  
  17.     }  
  18.   
  19.     @Override  
  20.     public Session getSession(String sessionId) {  
  21.         return sessionCache.get(sessionId);  
  22.     }  
  23.   
  24.     @Override  
  25.     public void removeSession(String sessionId) {  
  26.         sessionCache.remove(sessionId);  
  27.     }  
  28. }  
开发出会话管理器后,如何将其装配到Rop中呢?答案还是通过<rop:annotation-driven/>的属性: 
Xml代码   收藏代码
  1. <rop:annotation-driven session-manager="sampleSessionManager"/>  
  2. <bean id="sampleSessionManager"   
  3.       class="com.rop.sample.SampleSessionManager" />  
开发登录和退出服务  

基于Rop的服务开放平台应当至少包括两个服务,即登录和退出平台的服务。这两个服务方法也应该最先开发出来。下面是rop-sample的登录和退出的服务方法: 

UserService.java:登录及退出服务方法 
Java代码   收藏代码
  1. @ServiceMethod(method = "user.logon",version = "1.0",  
  2. needInSession = NeedInSessionType.NO) //①  
  3. public RopResponse logon(LogonRequest request) {  
  4.           
  5.         //②创建会话  
  6.     SimpleSession session = new SimpleSession();                            
  7.     session.setAttribute("userName",request.getUserName());  
  8.     request.getRopRequestContext().addSession("mockSessionId1", session);  
  9.   
  10.     LogonResponse logonResponse = new LogonResponse();  
  11.     logonResponse.setSessionId("mockSessionId1");  
  12.     return logonResponse;  
  13. }  
  14.   
  15. @ServiceMethod(method = "user.logout",version = "1.0")  
  16. public RopResponse logout(RopRequest request) {  
  17.     request.getRopRequestContext().removeSession();//③删除会话  
  18.     LogoutResponse response = new LogoutResponse();  
  19.     response.setSuccessful(true);  
  20.     return response;  
  21. }  
简单来说,登录服务是用于创建会话生成sessionId给客户端的,因此登录服务的方法是工作在非会话环境中的。在默认情况下,所有的服务方法都必须工作于会话环境中,也即每次对服务的请求都必须提供sessionId,否则,Rop就会驳回请求,返回错误的报文。如果希望Rop不对服务方法进行会话校验,需要像①一样,显式将@ServiceMethod的needInSession属性设为NeedInSessionType.NO。 

客户端在调用登录服务的方法后,可从响应报文中获取sessionId,这样就可以在后续的服务调带上这个sessionId,Rop会根据sessionId将对应的Session绑定到服务请求上下文RopRequestContext中。 


转自:http://stamen.iteye.com/blog/1628515

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值