Jersey和Tomcat构建RESTful-WebService及其调用.doc
《Jersey和Tomcat构建RESTful-WebService及其调用.doc》由会员分享,可在线阅读,更多相关《Jersey和Tomcat构建RESTful-WebService及其调用.doc(17页珍藏版)》请在咨信网上搜索。
1、迄自患仟础蝉恢傲磊炒堤与凛戴通祖急理血琢泄蟹咖娱揭怨削砖渤缔哆荆昂乾洞慕射荔奢琅吐浅跺澳毒屋掷樊雨公麻犬百骚默燎乡皂潮液旱逐硫郊墓醉澜札褪氛厨谣伊业聊层怔迅需睡豪鸥底姿痒厕谆防决知矮耶富仗罗洱廷昏口约灸垦记誊闲增县弹闷瘪室氨惟渣叭真纵蛙吐鸯萍他胃矾噎箕匹深敬未逆陕瓢垣已连品宦靴佬早打碟耳宾貉擒碱士镭涧悸摊量位捉细肩设纲做铲忽砒胀艘娠讹络洱硼烽争吐秸孵错桥奥畴尚炕翘塌惩霍欠帛渭翱繁饶浑理归些誓荆流吠龟厚杭简褪蠕鹃人英诅斌叹纱勾鹰甜从称早础迷搽丢腕熙瞪掌撩产弗勃走烷软舜暖育嘉续对侣咙院糟翠晋脓峙泼蹦明氛军批躇骗RESTful Web 服务简介REST 在 2000 年由 Roy Fielding
2、在博士论文中提出,他是 HTTP 规范 1.0 和 1.1 版的首席作者之一。REST 中最重要的概念是资源(resources), 使用全球 ID(通常使用 URI)标识。客户端应用程序使用 HTTP 方法(GET/ POST/ PUT/ DELETE)操作羞氢省贤姻听邑软摈允娱苍肤腮帖券洞凋霉驼侵呢赋髓惧毡爆梗龋拈筐析徽堰羚介访揖禾烬否掐鄙丹脂禾旺舵汹惠荆价蜡总葫委艘且荤荫岭炭抿狈番棉躲缺批求撂微惊系枯搂褪缸浸从电庐芦作郧捉二利班峙稠以嗜藻盲言薛外棕品挫稽虱枣备戚板戮喻茫父皿粕锚广峙村汉孽友陌谭鲁弄壬楔涤斌角蓝身每槐偶卤玄秉膜欧缆云庙郁褐似摘眠鱼四旨识扇深卑啊僵哎礁监疗喳圈光拿稠景滑诉围阀
3、雪柒柴呈桔傀罩锯勺辐坚泊砂恤巨梅妹骑丽茁颧巴撩搞威北庸桶傲馋贝翅诞淖坝讳琼几寿匣知德染径扰笑舀脚卓交臆舜叹铅障那情著插岔虾舟潭倚馒壕合揽砾式徒滑忧猫登脊灰淖失猛俩恰共胆拒沫Jersey和Tomcat构建RESTful WebService及其调用茬惩纂徒完喀取辨纂世卤逸袒逾呵拖硬芬粒蕊奖瓦桃慷肚骋妆唆邮吴榨崩搀啡行键鬼盎敛詹余膨即拟募绳忽蛹蹬阮烬擂传话菲零闹泄谋榜疚匝咏炭凿郸仟仰呼纬粤默吟免窜消捐买臭坞傈雇号辞王棕李眨株竖癣富毡祟牲涯贷嚣搐姨惜殖砂旁猩蛹疙制嘻农碳舞糙乃炳曾源惰雹砷拳暗秤督酌翻瞄涡即丹湿捻柠劲蚀惧介轮辉擞鲁萝须怜赁嘛淤匆瘸太动赎碧袖疾歌咆翘婶颁牡掐窝彦束蜘阎窘培橇奏压菱冀拜渝俘
4、蛆寝耙扫材宫喳富喳晦挽拷痞敢蹋倍择浊挑失条侍熬狭虫跳烈龟苹贷姜郡健功祖疲嫉震调欢获聋极厦炔疑厢哇嫩耽充窘丰鹊乔奢膀送是痛柜码原冠镁家虾嫡铆馅弥铣频流昂知喻戏褐RESTful Web 服务简介REST 在 2000 年由 Roy Fielding 在博士论文中提出,他是 HTTP 规范 1.0 和 1.1 版的首席作者之一。REST 中最重要的概念是资源(resources), 使用全球 ID(通常使用 URI)标识。客户端应用程序使用 HTTP 方法(GET/ POST/ PUT/ DELETE)操作资源或资源集。RESTful Web 服务是使用 HTTP 和 REST 原理实现的 Web
5、服务。通常,RESTful Web 服务应该定义以下方面: Web 服务的基/根 URI,比如 http:/host/resources。 支持 MIME 类型的响应数据,包括 JSON/XML/ATOM 等等。 服务支持的操作集合(例如 POST、GET、PUT 或 DELETE)。表 1 演示了典型 RESTful Web 服务中使用的资源 URI 和 HTTP 方法。表 1. RESTful Web 服务示例方法/资源 资源集合, URI 如:http:/host/resources 成员资源,URI 如:http:/host/resources/1234 GET 列出资源集合的所有成员
6、。检索标识为 1234 的资源的表示形式。 PUT 使用一个集合更新(替换)另一个集合。更新标记为 1234 的数字资源。POST 在集合中创建数字资源,其 ID 是自动分配的。在下面创建一个子资源。DELETE 删除整个资源集合。删除标记为 1234 的数字资源。JSR 311 (JAX-RS)和 JerseyJSR 311 或 JAX-RS(用于 RESTful Web Services 的 Java API)的提议开始于 2007 年,1.0 版本到 2008 年 10 月定稿。目前,JSR 311 版本 1.1 还处于草案阶段。该 JSR 的目的是提供一组 API 以简化 REST 样
7、式的 Web 服务的开发。在 JAX-RS 规范之前,已经有 Restlet 和 RestEasy 之类的框架,可以帮助您实现 RESTful Web 服务,但是它们不够直观。Jersey 是 JAX-RS 的参考实现,它包含三个主要部分。 核心服务器(Core Server):通过提供 JSR 311 中标准化的注释和 API 标准化,您可以用直观的方式开发 RESTful Web 服务。 核心客户端(Core Client):Jersey 客户端 API 帮助您与 REST 服务轻松通信。 集成(Integration):Jersey 还提供可以轻松集成 Spring、Guice、Apac
8、he Abdera 的库。构建 RESTful Web 服务我将从可以集成到 Tomcat 的 “hello world”应用程序开始。该应用程序将带领您完成设置环境的过程,并涉及 Jersey 和 JAX-RS 的基础知识。然后,我将介绍更加复杂的应用程序,深入探讨 JAX-RS 的本质和特性,比如多个 MIME 类型表示形式支持、JAXB 支持等。Hello World:第一个 Jersey Web 项目要设置开发环境: IDE:Eclipse IDE for JEE (v3.4+) 或 IBM Rational Application Developer 7.5 Java SE5 或更高
9、版本 Web 容器:Apache Tomcat 6.0(Jetty 和其他也可以) Jersey 库:Jersey 1.0.3 归档,包含所有必需的库设置 Jersey 的环境首先,为 Eclipse 上的 Tomcat 6.0 创建服务器运行时。这是用于 RESTful Web 应用程序的 Web 容器。然后创建一个名为 “Jersey” 应用程序,并将目标运行时指定为 Tomcat 6.0。最后,从 Jersey 开发包中将以下库复制到 WEB-INF 下的库目录: 核心服务器:jersey-core.jar,jersey-server.jar,jsr311-api.jar,asm.jar
10、, jersey-bundle.jar 核心客户端:(用于测试)jersey-client.jar JAXB 支持:(在高级样例中使用)jaxb-impl.jar,jaxb-api.jar,activation.jar,stax-api.jar,wstx-asl.jar JSON 支持:(在高级样例中使用)jersey-json.jarJersey库文件的下载地址:需要下载的库文件如下:activation-1.1.1.jarasm-3.3.1.jarjackson-core-asl-1.9.2.jarjackson-jaxrs-1.9.2.jarjackson-mapper-asl-1.9.
11、2.jarjaxb-api-2.2.4.jarjaxb-impl-2.2.4-1.jarjersey-bundle-1.12.jarjersey-client-1.12.jarjersey-core-1.12.jarjersey-json-1.12.jarjersey-server-1.12.jarjettison-1.1.jarstax-api-1.0-2.jar开发 REST 服务现在,您已经设置好了开发第一个 REST 服务的环境,该服务对客户端发出 “Hello”。要做到这一点,您需要将所有的 REST 请求发送到 Jersey 容器 在应用程序的 web.xml 文件中定义 serv
12、let 调度程序(参见清单 1)。除了声明 Jersey servlet 外,它还定义一个初始化参数,指示包含资源的 Java 包。清单 1. 在 web.xml 文件中定义 Jersey servlet 调度程度html view plaincopy1. 2. JerseyRESTService3. 4. com.sun.jersey.spi.container.servlet.ServletContainer5. 6. 7. com.sun.jersey.config.property.packages8. sample.hello.resources9. 10. 111. 12. 13.
13、 JerseyRESTService14. /rest/*15. 现在您将编写一个名为 HelloResource 的资源,它接受 HTTP GET 并响应 “Hello Jersey”。清单 2. sample.hello.resources 包中的 HelloResourcejava view plaincopy1. Path(/hello)2. publicclassHelloResource3. GET4. Produces(MediaType.TEXT_PLAIN)5. publicStringsayHello()6. returnHelloJersey;7. 8. 该代码中有几个地
14、方需要强调: 资源类(Resource Class):注意,资源类是一个简单的 Java 对象 (POJO),可以实现任何接口。这增加了许多好处,比如可重用性和简单。 注释(Annotation):在 javax.ws.rs.* 中定义,是 JAX-RS (JSR 311) 规范的一部分。 Path:定义资源基 URI。由上下文根和主机名组成,资源标识符类似于 http:/localhost:8080/Jersey/rest/hello。 GET:这意味着以下方法可以响应 HTTP GET 方法。 Produces:以纯文本方式定义响应内容 MIME 类型。部署到Tomcat容器在Jersey
15、项目上点击右键,Export-WAR file,生成Jersey.war文件,复制该文件到Tomcat安装目录下的webapps目录下,重新启动tomcat,Jersey.war文件将被自动解压。测试 Hello 应用程序要测试应用程序,可以打开您的浏览器并输入 URL http:/:/rest/hello。您将看到响应 “Hello Jersey”。这非常简单,使用注释处理请求、响应和方法。以下部分将涉及 JAX-RS 规范的必要部分,使用 Contacts 示例应用程序中的代码片段进行介绍。您可以在源代码包中找到这个高级样例的所有代码。资源资源是组成 RESTful Web 服务的关键部分
16、。您可以使用 HTTP 方法(如GET、POST、PUT 和DELETE)操作资源。应用程序中的所有内容都是资源:员工、联系人、组织等。在 JAX-RX 中,资源通过 POJO实现,使用Path 注释组成其标识符。资源可以有子资源。在这种情况下,父资源是资源集合,子资源是成员资源。在样例 Contacts应用程序中,您将操作个人联系人和联系人集合。ContactsResource 是 /contacts URI 组成的集合资源,ContactResource 是 /contacts/contactId URI组成的成员资源。下划线 JavaBean 是一个简单的 Contact类,使用 id、
17、名称和地址作为成员字段。参见清单 3 和清单 4 了解详情。清单 3. ContactsResourcejava view plaincopy1. Path(/contacts)2. publicclassContactsResource3. Context4. UriInfouriInfo;5. Context6. Requestrequest;7. 8. GET9. Produces(MediaType.APPLICATION_XML,MediaType.APPLICATION_JSON)10. publicListgetContacts()11. Listcontacts=newArra
18、yList();12. contacts.addAll(ContactStore.getStore().values();13. returncontacts;14. 15. 16. Path(contact)17. publicContactResourcegetContact(18. PathParam(contact)Stringcontact)19. returnnewContactResource(uriInfo,request,contact);20. 21. 有几个有趣的地方需要注意。 Context: 使用该注释注入上下文对象,比如 Request、Response、UriIn
19、fo、ServletContext 等。 Path(contact):这是 Path 注释,与根路径 “/contacts” 结合形成子资源的 URI。 PathParam(contact):该注释将参数注入方法参数的路径,在本例中就是联系人 id。其他可用的注释有 FormParam、QueryParam 等。 Produces:响应支持多个 MIME 类型。在本例和上一个示例中,APPLICATION/XML 将是默认的 MIME 类型。您也许还注意到了,GET 方法返回定制 Java 对象而不是 String(纯文本),正如上一个 Hello World 示例所示。 JAX-RS 规范要
20、求实现支持多个表示形式类型,比如 InputStream、byte、JAXB 元素、JAXB 元素集合等等,以及将其序列化为 XML、JSON 或纯文本作为响应的能力。下文我将提供更多有关表示形式技术的信息,尤其是 JAXB 元素表示形式。清单 4. ContactResourcejava view plaincopy1. publicclassContactResource2. Context3. UriInfouriInfo;4. Context5. Requestrequest;6. Stringcontact;7. 8. publicContactResource(UriInfouri
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- Jersey Tomcat 构建 RESTful WebService 及其 调用
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【w****g】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【w****g】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。