GWT有两种与服务端进行交互的技术:GWT RPC和基于普通AJAX的远程交互技术。这里只介绍GWT RPC技术。

一个完整的RPC服务至少包含三个Java文件:

1、客户端远程接口类,需要继承RemoteService类

2、客户端远程接口类的异步类,异步类的名称格式是: 客户端远程接口类名 + Async 后缀

3、服务器端的远程接口类,需要继承RemoteServiceServlet类和实现客户端远程接口类

客户端相关的类必须位于client包及其子包下,服务器端相关的类必须位于server包及其子包下。

1、客户端远程接口类 源码

  1. /**
  2. * 客户端远程接口类需要继承RemoteService类
  3. */
  4. public interface PersonService extends RemoteService {
  5. public Person getPerson(String name, int age) throws RuntimeException;
  6. //使用内部类创建客户端远程接口类的异步类
  7. public static class Utils{
  8. private static PersonServiceAsync serviceAsync;
  9. public static PersonServiceAsync getInstance(){
  10. if(serviceAsync==null){
  11. serviceAsync = (PersonServiceAsync) GWT.create(PersonService.class);
  12. }
  13. return serviceAsync;
  14. }
  15. }
  16. }
/**
* 客户端远程接口类需要继承RemoteService类
*/
public interface PersonService extends RemoteService {
public Person getPerson(String name, int age) throws RuntimeException; //使用内部类创建客户端远程接口类的异步类
public static class Utils{
private static PersonServiceAsync serviceAsync; public static PersonServiceAsync getInstance(){
if(serviceAsync==null){
serviceAsync = (PersonServiceAsync) GWT.create(PersonService.class);
}
return serviceAsync;
}
}
}

2、客户端远程接口类的异步类 源码

  1. /**
  2. * 异步接口的方法返回值均为void,并且其对应的每个方法都比原接口多一个类型为AsyncCallback的参数
  3. */
  4. public interface PersonServiceAsync {
  5. public void getPerson(String name, int age, AsyncCallback callback) throws RuntimeException;
  6. }
/**
* 异步接口的方法返回值均为void,并且其对应的每个方法都比原接口多一个类型为AsyncCallback的参数
*/
public interface PersonServiceAsync {
public void getPerson(String name, int age, AsyncCallback callback) throws RuntimeException;
}

3、服务器端的远程接口类 源码

  1. /**
  2. * 实现类要继承RemoteServiceServlet类
  3. */
  4. public class PersonServiceImpl extends RemoteServiceServlet implements PersonService {
  5. public Person getPerson(String name, int age) throws RuntimeException {
  6. //与HTTP的交互
  7. HttpServletRequest request = this.getThreadLocalRequest();
  8. HttpServletResponse response = this.getThreadLocalResponse();
  9. HttpSession session = request.getSession();
  10. return new Person(name, age);
  11. }
  12. }
/**
* 实现类要继承RemoteServiceServlet类
*/
public class PersonServiceImpl extends RemoteServiceServlet implements PersonService {
public Person getPerson(String name, int age) throws RuntimeException {
//与HTTP的交互
HttpServletRequest request = this.getThreadLocalRequest();
HttpServletResponse response = this.getThreadLocalResponse();
HttpSession session = request.getSession(); return new Person(name, age);
}
}

4、交互过程中传递的对象

  1. /**
  2. * 在GWT RPC中,如果要交互的数据(方法的参数和返回值)是一个复杂类型的话,
  3. * 那么这个类要实现IsSerializable接口,来使该类能被正常序列化和反序列化。
  4. */
  5. public class Person implements IsSerializable {
  6. private String name;
  7. private int age;
  8. public Person(){
  9. }
  10. public Person(String name, int age){
  11. this.name = name;
  12. this.age = age;
  13. }
  14. //省略getter、setter方法
  15. }
/**
* 在GWT RPC中,如果要交互的数据(方法的参数和返回值)是一个复杂类型的话,
* 那么这个类要实现IsSerializable接口,来使该类能被正常序列化和反序列化。
*/
public class Person implements IsSerializable {
private String name;
private int age; public Person(){ } public Person(String name, int age){
this.name = name;
this.age = age;
} //省略getter、setter方法
}

5、GWT应用入口点类需要实现EntryPoint接口,其源码如下

  1. public class Index implements EntryPoint {
  2. public void onModuleLoad() {
  3. Button button = new Button("Click me");
  4. VerticalPanel vPanel = new VerticalPanel();
  5. vPanel.setWidth("100%");
  6. vPanel.setHorizontalAlignment(VerticalPanel.ALIGN_CENTER);
  7. vPanel.add(button);
  8. RootPanel.get().add(vPanel);
  9. //按钮的单击事件
  10. button.addClickListener(new ClickListener() {
  11. public void onClick(Widget sender) {
  12. //初始化Service接口
  13. PersonServiceAsync personService = PersonService.Utils.getInstance();
  14. //为Service代理描述Service接入点的URL
  15. ServiceDefTarget target = (ServiceDefTarget)personService;
  16. String path = GWT.getModuleBaseURL() + "PersonService";
  17. target.setServiceEntryPoint(path);
  18. //发出RPC请求
  19. personService.getPerson("cjm", 100, new AsyncCallback(){
  20. public void onSuccess(Object result) {
  21. Person person = (Person)result;
  22. Window.alert(person.getName());
  23. }
  24. public void onFailure(Throwable caught) {
  25. Window.alert(caught.getMessage());
  26. }
  27. });
  28. }
  29. });
  30. }
  31. }
public class Index implements EntryPoint {
public void onModuleLoad() {
Button button = new Button("Click me"); VerticalPanel vPanel = new VerticalPanel();
vPanel.setWidth("100%");
vPanel.setHorizontalAlignment(VerticalPanel.ALIGN_CENTER);
vPanel.add(button); RootPanel.get().add(vPanel); //按钮的单击事件
button.addClickListener(new ClickListener() {
public void onClick(Widget sender) {
//初始化Service接口
PersonServiceAsync personService = PersonService.Utils.getInstance(); //为Service代理描述Service接入点的URL
ServiceDefTarget target = (ServiceDefTarget)personService;
String path = GWT.getModuleBaseURL() + "PersonService";
target.setServiceEntryPoint(path); //发出RPC请求
personService.getPerson("cjm", 100, new AsyncCallback(){
public void onSuccess(Object result) {
Person person = (Person)result;
Window.alert(person.getName());
} public void onFailure(Throwable caught) {
Window.alert(caught.getMessage());
}
}); }
}); }
}

6、在Index.gwt.xml文件中增加以下配置信息

将RPC服务与GWT应用入口点类关联起来

  1. <servlet path="/PersonService" class="com.cjm.server.PersonServiceImpl"/>
<servlet path="/PersonService" class="com.cjm.server.PersonServiceImpl"/>

7、在web.xml文件增加以下配置信息

  1. <!-- 在宿主模式下启动应用时,此servlet是必须的 -->
  2. <servlet>
  3. <servlet-name>shell</servlet-name>
  4. <servlet-class>com.google.gwt.dev.shell.GWTShellServlet</servlet-class>
  5. </servlet>
  6. <servlet-mapping>
  7. <servlet-name>shell</servlet-name>
  8. <url-pattern>/*</url-pattern>
  9. </servlet-mapping>
  10. <!-- RPC服务配置 -->
  11. <servlet>
  12. <servlet-name>PersonService</servlet-name>
  13. <servlet-class>com.cjm.server.PersonServiceImpl</servlet-class>
  14. </servlet>
  15. <servlet-mapping>
  16. <servlet-name>PersonService</servlet-name>
  17. <url-pattern>/PersonService</url-pattern>
  18. </servlet-mapping>

通过GWT RPC实现客户端与服务器端的交互的更多相关文章

  1. Android客户端和服务器端数据交互

    网上有很多例子来演示Android客户端和服务器端数据如何实现交互不过这些例子大多比较繁杂,对于初学者来说这是不利的,现在介绍几种代码简单.逻辑清晰的交互例子,本篇博客介绍第四种: 一.服务器端: 代 ...

  2. ajax+客户端与服务器端的交互

    一. AJAX 原生JS var xhr=new XMLHttpRequest(); xhr.open("GET","[请求地址]",false); xhr.o ...

  3. 浅析Java web程序之客户端和服务器端交互原理(转)

    转载自http://www.cnblogs.com/lys_013/archive/2012/05/05/2484561.html 1. 协议 a. TCP/IP整体构架概述 TCP/IP协议并不完全 ...

  4. [转]HTTP报文接口及客户端和服务器端交互原理

    1. 协议 a. TCP/IP整体构架概述 TCP/IP协议并不完全符合OSI的七层参考模型.传统的开放式系统互连参考模型,是一种通信协议的7层抽象的参考模型,其中每一层执行某一特定任务.该模型的目的 ...

  5. 浅析Java web程序之客户端和服务器端交互原理

    原文链接: https://www.iteye.com/topic/470019 1. 协议 a. TCP/IP整体构架概述 TCP/IP协议并不完全符合OSI的七层参考模型.传统的开放式系统互连参考 ...

  6. GWT RPC

    GWT RPC GWT RPCRemote Procedure Calls GWT: Google Web Toolkit的缩写,有了 GWT可以使用 Java 编程语言编写 AJAX 前端,然后 G ...

  7. GWT RPC机制

    GWT RPC GWT RPCRemote Procedure Calls GWT: Google Web Toolkit的缩写,有了 GWT可以使用 Java 编程语言编写 AJAX 前端,然后 G ...

  8. zookeeper原理解析-客户端与服务器端交互

    Zookeeper集群中server数量总是确定的,所以集群中的server交互采用比较可靠的bio长连接模型:不同于集群中sever间交互zookeeper客户端其实数量是未知的,为了提高zooke ...

  9. ASP.NET获取客户端、服务器端的信息

    ASP.NET获取客户端.服务器端基础信息 1. 在ASP.NET中专用属性: 获取服务器电脑名:Page.Server.ManchineName 获取用户信息:Page.User 获取客户端电脑名: ...

随机推荐

  1. 【python】分片copy和等号的区别

    例一 >>> list1=[1,2,3,4]>>> list2=list1>>> list3=list1[:]>>> list1 ...

  2. VOIP概述

    简介 VoIP(Voice over Internet Protocol)就是将模拟声音讯号(Voice)数字化,以数据封包(Data Packet)的型式在 IP 数据网络 (IP Network) ...

  3. servlet 默认是线程安全的吗?

    由于Servlet默认是以多线程模式执行的,所以,在编写代码时需要非常细致地考虑多线程的安全问题.然而,很多人编写Servlet程序时并没 有注意到多线程安全的问题,这往往造成编写的程序在少量用户访问 ...

  4. IronPython脚本调用C#dll示例

    上篇Python脚本调用C#代码数据交互示例(hello world)介绍了与C#紧密结合的示例,这里还将提供一个与C#结合更紧密的示例,直接调用C#编写的DLL.      我们还是沿用了上篇文章的 ...

  5. MySQL 5.6 root密码丢失

     windows下mysql密码忘记了 第一步:netstat -nat(可以查看mysql是否启动了,如果启动了,可以用输入net stop mysql(或者通过任务管理器结束进程)) 第二步:my ...

  6. django 常用命令

    django 常用命令,备忘: django-admin.py startproject test 创建一个项目名叫test的项目 python manage.py startapp app 创建一个 ...

  7. HNOI2008 and ZJOI2006 排名系统

    1056: [HAOI2008]排名系统 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1311  Solved: 337[Submit][Statu ...

  8. 知乎上关于c和c++的一场讨论_看看高手们的想法

    为什么很多开源软件都用 C,而不是 C++ 写成? 余天升 开源社区一直都不怎么待见C++,自由软件基金会创始人Richard Stallman认为C++有语法歧义,这样子没有必要.非常琐碎还会和C不 ...

  9. C# partial 局部类型

    关键字partial是一个上下文关键字,只有和 class.struct.interface 放在一起时才有关键字的含义.因此partial的引入不会影响现有代码中名称为partial的变量.局部类型 ...

  10. 大型邮箱smtp服务器及端口 收集

    各大型邮箱smtp服务器及端口收集: 新浪邮箱smtp服务器 外发服务器:smtp.vip.sina.com 收件服务器:pop3.vip.sina.com 新浪免费邮件 外发服务器:smtp.sin ...