GXT之旅:第三章:表单和窗口(4)——表单的提交和RPC
表单使用HTTP提交
表单有两种提交方式,第一种就是传统的HTTP提交。
最直接的步骤就是:
- 使用FormPanel的setAction()方法,去定义submit的URL
- 使用FormPanel的isValid()方法,去验证所有的fields是否有正确
- 如果正确,使用FormPanel的submit()方法提交表单。
- setAction("http://www.example.com/submit.php");
- final Button btnSave = new Button("Save");
- btnSave.setIconStyle("save");
- btnSave.addSelectionListener(new SelectionListener<ButtonEvent>()
- {
- public void componentSelected(ButtonEvent ce) {
- if (isValid())
- {
- submit();
- } }
- });
- addButton(btnSave);
setAction("http://www.example.com/submit.php"); final Button btnSave = new Button("Save"); btnSave.setIconStyle("save"); btnSave.addSelectionListener(new SelectionListener<ButtonEvent>() { public void componentSelected(ButtonEvent ce) { if (isValid()) { submit(); } } }); addButton(btnSave);
GWT RPC
表单就拥有了另外一种提交方式——RPC。对于GWT和GXT来说,他不像传统的web应用,在client端我们可以选择存储和操作java类型的数据——不管这些数据是在web前端还是通过GWT RPC或者JSON别的什么方法提交到后端,我们都可以操作他们。
在RSSReader项目里,我们就会使用GWT RPC。
创建一个Feed service
为了能够检索到Feed对象,就必须有唯一的ID。java里有专门用来生成的主键的类——UUID。接下来我们要实现一个功能,就是当在client端所使用Feed的实例对象,是通过RPC从server端返回的,并且已经赋值ID的。因为先前,我们所创建的Feed类,就是为了在client和server两端都可以使用。那么接下来就要创建一个GWT RPC的service去处理Feed实例对象。
- 创建新包:com.danielvaughan.rssreader.client.services,在此包下,新建一个接口FeedService,继承GWT RemoteService。定义一个方法createNewFeed():
- package com.danielvaughan.rssreader.client.services;
- import com.danielvaughan.rssreader.shared.model.Feed;
- import com.google.gwt.user.client.rpc.RemoteService;
- import com.google.gwt.user.client.rpc.RemoteServiceRelativePath;
- @RemoteServiceRelativePath("feed-service")
- public interface FeedService extends RemoteService {
- Feed createNewFeed();
- }
package com.danielvaughan.rssreader.client.services; import com.danielvaughan.rssreader.shared.model.Feed; import com.google.gwt.user.client.rpc.RemoteService; import com.google.gwt.user.client.rpc.RemoteServiceRelativePath; @RemoteServiceRelativePath("feed-service") public interface FeedService extends RemoteService { Feed createNewFeed(); }
- 注意1:@RemoteServiceRelativePath("feed-service") 注解了当前这个service,在web.xml应该配置的url映射地址。也就是说不管哪个类实现了FeedService接口,那么他在web.xml的servlet url映射就应该设置成"feed-service"。
- 注意2:FeedService接口创建完毕之后,GWT就会自动的提示你去创建与之对应的另外一个接口FeedServiceAsync
- package com.danielvaughan.rssreader.client.services;
- import com.danielvaughan.rssreader.shared.model.Feed;
- import com.google.gwt.user.client.rpc.AsyncCallback;
- public interface FeedServiceAsync {
- void createNewFeed(AsyncCallback<Feed> callback);
- }
package com.danielvaughan.rssreader.client.services; import com.danielvaughan.rssreader.shared.model.Feed; import com.google.gwt.user.client.rpc.AsyncCallback; public interface FeedServiceAsync { void createNewFeed(AsyncCallback<Feed> callback); }
- FeedServiceAsync接口中生成了FeedService接口中的,异步回调的抽象方法。其目的是在createNewFeed()方法执行之后的返回期间会调用FeedServiceAsync接口中的与之对应的createNewFeed(AsyncCallback<Feed> callback)方法,来作为createNewFeed()方法执行情况的反馈。
- 之前的两个接口都是属于client端的services,具体的实现类就应该属于的server端的services。所以新建包:com.danielvaughan.rssreader.server.services,在此包下创建FeedServiceImpl类实现FeedService,继承RemoteServiceServlet。具体的实现如下代码:
- package com.danielvaughan.rssreader.server.services;
- import java.io.IOException;
- import java.util.UUID;
- import com.danielvaughan.rssreader.client.services.FeedService;
- import com.danielvaughan.rssreader.shared.model.Feed;
- import com.google.gwt.user.server.rpc.RemoteServiceServlet;
- @SuppressWarnings("serial")
- public class FeedServiceImpl extends RemoteServiceServlet implements
- FeedService {
- @Override
- public Feed createNewFeed() {
- UUID uuid = UUID.randomUUID();
- return new Feed(uuid.toString());
- }
- }
package com.danielvaughan.rssreader.server.services; import java.io.IOException; import java.util.UUID; import com.danielvaughan.rssreader.client.services.FeedService; import com.danielvaughan.rssreader.shared.model.Feed; import com.google.gwt.user.server.rpc.RemoteServiceServlet; @SuppressWarnings("serial") public class FeedServiceImpl extends RemoteServiceServlet implements FeedService { @Override public Feed createNewFeed() { UUID uuid = UUID.randomUUID(); return new Feed(uuid.toString()); } }
- 配置FeedServiceImpl的servlet映射。编辑web.xml
- <servlet>
- <servlet-name>feedServlet</servlet-name>
- <servlet-class>
- com.danielvaughan.rssreader.server.services.FeedServiceImpl
- </servlet-class>
- </servlet>
- <servlet-mapping>
- <servlet-name>feedServlet</servlet-name>
- <url-pattern>/rssreader/feed-service</url-pattern>
- </servlet-mapping>
<servlet> <servlet-name>feedServlet</servlet-name> <servlet-class> com.danielvaughan.rssreader.server.services.FeedServiceImpl </servlet-class> </servlet> <servlet-mapping> <servlet-name>feedServlet</servlet-name> <url-pattern>/rssreader/feed-service</url-pattern> </servlet-mapping>
- 注意:<url-pattern>/rssreader/feed-service</url-pattern>其中的rssreader是小写,这与<script type="text/javascript" language="javascript"
src="rssreader/rssreader.nocache.js"></script>是一直的。
- RPC的services已经创建完毕了。只要记住他包括client端和server端代码。client端是接口的定义,server端是具体的实现。web.xml里配置的server端的servlet。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】
2013-03-14 Linux压缩与解压缩文件
2012-03-14 c#在WinForm下使用HttpWebRequest上传文件并显示进度
2012-03-14 使用WebClient或HttpWebRequest模拟上传文件和数据(我用的这个)
2012-03-14 C#中使用HttpWebRequest用Post提交MultiPart数据
2012-03-14 使用C#的HttpWebRequest模拟登陆访问人人网
2012-03-14 在C#用HttpWebRequest中发送GET/HTTP/HTTPS请求
2012-03-14 winform下通过webclient使用非流方式上传(post)数据和文件