OpenSocial规范、实现现状与展望
OpenSocial为构建跨多个网站的社交应用程序提供了一组通用 API。开发人员可以使用标准 JavaScript 和 HTML 创建应用程序,用以访问社交网络里的朋友并更新对应的Feeds。本文是对本次QClub活动内容的一个简短总结,希望对没有到现场参会的读者了解OpenSocial有所帮助,也希望能引起大家更多的讨论。
作者 Charles Humble译者 曹晶 发布于 2008年4月14日 上午7时7分
在大多数企业级应用中,数据约束会存在于下面两个地方:在Hibernate Validator高级开发人员Emmanuel Bernard的带领下,JSR-303旨在标准化Java EE 6的约束元数据模型。规范的初稿已经发布,专家组也在积极征求反馈。做为这项工作的一部分,已经创建了一个论坛,Bernard也开始在Hibernate的博客中发表一系列描述API工作原理的文章(第一部分,第二部分)。
知道了JSR-303规范的起源,JSR-303很大程度上受JBoss Hibernate Validations的影响也就不足为怪了,尽管很多其它验证框架(比如Xwork和Apache Commons Validator)也影响了该规范。JSR-303在大多数情况下使用Annotation,并为运行时验证提供标准的APIs来查询元数据。每个约束Annotation都必须定义一个String类型的信息来创建错误信息。错误信息支持国际化。可以对对象的属性、Get方法、类、父类、接口声明约束,验证对象会验证该对象所有的约束。比如说,下面的代码创建了一个叫street1的字符串,它的最大长度是50个字符,而且不允许为空:
@NotEmpty @Max(50)
private String street1;
该框架设计为可扩展的,所以应用能很容易地定义自己特有的补充约束。第一篇博客文章中写道:
“约束由下面部分构成:
• Annotation
• 约束验证实现
Annotation表示对域模型的约束,而验证实现则判断给定的值能否通过约束。”
规范不仅支持实例验证,也支持对象图的验证,那么举例来说,如果ClientDetails Bean包含一个带有一或多个@Valid Annotation的Address Bean,验证器在验证ClientDetails Bean的时候也会验证Address Bean的内容。
规范和Hibernate Validator之间的一个重要不同是组的概念,组提供了创建验证子集的方法。组有一个关联序列(通过@GroupSequence Annotation设置),所以开发人员可以在下一组约束执行之前强制通过一组约束而不产生错误。组也允许JavaBean的部分验证。规范初稿提出了可能有用的两种场景:
“• 第二种组完全运行需要依赖于稳定状态Java EE 6平台中多种技术都应该能利用JSR-303。比如说,用ORM工具生成(DDL)时的DLL更新、由Java持久化API进行的插入/更新的实体验证、新的WebBeans API、JavaServerFaces组件,看似都很有希望。
• 第二种组会严重消耗时间、CPU或内存,应该尽可能避免使用”
OpenSocial为构建跨多个网站的社交应用程序提供了一组通用 API。开发人员可以使用标准 JavaScript 和 HTML 创建应用程序,用以访问社交网络里的朋友并更新对应的Feeds。本文是对本次QClub活动内容的一个简短总结,希望对没有到现场参会的读者了解OpenSocial有所帮助,也希望能引起大家更多的讨论。
Ruby 1.9的纤程(Fibers)和非阻塞I/O越来越收到关注了。我们对来自NeverBlock项目的Mohammad A. Ali和来自Revactor项目的Tone Arcieri进行了访谈。
InfoQ中文站有幸与Google中国的产品经理杨巍先生在一起探讨了OpenSocial的相关话题,包括OpenSocial的初衷、构成要素、实现方式、以及要实现它的技术储备等等。
Ryan Cooper对Amr Elssamadisy的新书发表了评价,并认为书中提供了一种为实施敏捷量身定做的框架。本书并没有给出一种人人可用的敏捷方法,而是为读者提供一些模式和工具,用以找出哪些敏捷实践可以最有效地达到该组织机构的特定目标。
这个由业界主要专家们参加的座谈会探究了在使应用程序具备尽可能好的伸缩性及性能的过程中所面临的挑战和思考过程。
本视频主要对OpenSocial进行了分析,并对实现的方式进行了介绍。其中包括:OpenSocial的开发经验、Container Provider的技术准备、平台的构成要素、具体的规范、以及对未来的展望。
Memcached在大型网站被应用得越来越广泛,但是Java客户端并不多,本文作者基于现有的开源客户端进行了封装优化,并翔实记录了这一过程。
在他们文章的第二部分,作者探讨了动态业务应用的架构并介绍了资源容器的概念。他们示范了如何在JEE之上构建这个架构,以及它如何影响实现生产力。
没有回复
回复