作为 Java 领域最 Railsful 的框架, Play 有如一股清新之风,以不破不立之势,一扫以往 JavaEE 开发臃肿庞杂之惑,迅速建立起了独特的简单之美。 Play 框架架构于标准的 Java 体系之上,开发起来却与 Rails 框架非常神似;其框架本身的核心代码只有不到 2 万 7 千行(含注释),可谓小巧精致,非常极简主义,却包含了从 Web 框架到对象持久、从动态编译到单元测试、从缓存到异步作业框架、从插件到模块扩展体系等众多功能,是一个全栈框架——“ All you need to create a cool web application ” ;它吸收并重用了大量已有 Java 类库,却依然能够独树一帜、标新立异。
如果说当年的 Spring 框架,是以“ JavaEE without EJB ”打出了响亮的口号,将传说中的 EJB 组件技术和昂贵的 EJB 容器轰下神坛;那么现在的 Play 框架,则类似“ JavaWeb without EE ”,甚至不需要 Servlet ,它更彻底地宣称,自己是一个代替企业级 Java 框架栈的、清爽的平台。
Play 框架一开始就宣布,这是一个“无痛的 Java 框架”,关注于开发人员的生产力,针对 RESTful 架构,是敏捷软件开发的绝佳搭档:
1、 没有了“编译 - 打包 - 部署”,直接“修改 - 保存 - 刷新”;
2、 非常详细的编译错误提示
3、 简单的无状态 MVC 架构
4、 HTTP 直接映射到代码调用
5、 高效的模板引擎
6、 强化的 JPA
7、 测试驱动开发
8、 全栈式应用框架
我把以上几点称为其八大“美学”特征,但是,在试用了 Play 框架,并作初步的分析之后,我却又逐渐发现其如下的八大“暴力”特征:
1、 自带嵌入式的 Java 编译器,不再需要构建工具编译、打包代码;
2、 自带嵌入式的 HTTP 服务器,不再需要打包部署到 Servlet 容器;
3、 自带在嵌入式服务器中运行的测试框架,所有的测试类,必须以测试模式启动服务器方式执行
4、 严格按 MVC 组织应用代码,各层组件类必须继承基类,没有“优雅”的接口实现,也不用依赖注入;
5、 对渲染响应结果的跳转控制,居然使用“异常”抛出机制 ;
6、 控制器类的 Action 方法通通是静态的,直接调用静态方法即为 Action 链重定向;
7、 将模型类的字段声明为 public ,再通过框架编译成私有字段和公共属性访问方法,访问模型对象的属性时也不使用 get/set ;
8、 打破 Java 的封闭类定义,可以为 Java 类库中的类定义增强方法,并在响应模板中嵌入的增强对象上调用。
综合起来,统称为 Play 框架的“暴力美学”比较合适。这样一个矛盾的结合体,究竟会是怎样一个框架?它又是如何做到的呢?我很疑惑,也很期待,希望能够从框架的源码入手,通过抽丝剥茧,层层解读,找到答案。
Play 框架的命名,正是为了一反传统 JavaEE 开发的臃肿,代表着一种轻松、玩乐、写意的态度,因此为不失其初衷,我想也给接下来的几篇文章取一个轻松的名字,就叫 Playing Play !系列吧,应该很合适。