spring-rpc-case

阅读更多
spring 提供了基本的基于http协议的rpc,同时提供了对rmi 、httpclient3、httpclient4、hession/burlap等相关现有的rpc支持。

rpc :远程方法调用。
效果:在客户端可以通过编程语言调用 服务端的对象。
实现基本思想:在客户端调用方法的时候,把调用的方法名,参数,参数类型通过相关协议传递到服务端,服务端解析到客户端调用的方法、参数等信息,在server端的对象上同样调用此方法,并把调用的结果通过协议返回。
依赖底层技术:java序列化(对象流),http或者tcp 协议。

基于http协议rpc的实现设想:
1、server端启动http协议接口。接受methodname,parameter,parameterTypes
2、clientApp调用远程的方法m1,参数:p1,通过http协议调用接口,传递m1,p1
3、servr端接收到请求,解析到m1,p1,在server端调用m1方法,然后回调客户端的接口,提交server端执行后的数据结果。
4、client收到server端的回调,解析server端执行的结果的数据。(可以同步,也可以异步)

下面是spring rpc 实现的case:

client project
@Controller
@RequestMapping("/login")
public class LoginController {
	private final static Logger logger = LoggerFactory.getLogger(LoginController.class);
	@Autowired
	private ILoginService loginService;
	@RequestMapping("/guest")
	public String login(HttpServletRequest request,HttpServletResponse response){
		logger.info("begin login ");
		User user = loginService.login(request.getParameter("username"), request.getParameter("password"));
		request.setAttribute("username", user.getUsername());
		request.setAttribute("password", user.getPassword());
		logger.info("end login ");
		return "login";
	}
	public ILoginService getLoginService() {
		return loginService;
	}
	public void setLoginService(ILoginService loginService) {
		this.loginService = loginService;
	}
}



applicationContext.xml的配置

      
      
   


servlet-context.xml 的配置

		
		
	

		
		
	

-------------------------------------------------------------------------------------
server project
servlet-context.xml

      
      
   

		
		
	


		
		
	


applicationContext.xml



  • spring-rpc.zip (835.7 KB)
  • 下载次数: 5

你可能感兴趣的:(spring-rpc)