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的配置
<bean name="loginService" class="org.springframework.remoting.httpinvoker.HttpInvokerProxyFactoryBean">
<property name="serviceUrl" value="http://127.0.0.1:8080/loginServiceInvoker"/>
<property name="serviceInterface" value="org.job.service.login.ILoginService"/>
</bean>
servlet-context.xml 的配置
<context:component-scan base-package="org.job.login" >
<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Service" />
</context:component-scan>
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/views/"/>
<property name="suffix" value=".jsp"/>
</bean>
-------------------------------------------------------------------------------------
server project
servlet-context.xml
<bean name="/loginServiceInvoker" class="org.springframework.remoting.httpinvoker.HttpInvokerServiceExporter">
<property name="service" ref="loginServiceImpl"/>
<property name="serviceInterface" value="org.job.service.login.ILoginService"/>
</bean>
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/views/"/>
<property name="suffix" value=".jsp"/>
</bean>
<context:component-scan base-package="org.login.web" >
<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Service" />
</context:component-scan>
applicationContext.xml
<bean name="loginServiceImpl" class="org.job.service.login.LoginServiceImpl"/>