几周前,我迁移了Play! 框架 1.x版本的Deadbolt应用于Play 2平台,并且对缺少有关创建模块的信息感到惊讶。 Play 1.x文档中详细介绍了该主题,这使得创建模块非常简单。 显然,需要做些事情-这是关于为Play 2创建模块和插件的三部分系列文章的第一篇。

重要的是要注意,这不是权威指南,而是我在处理自己的模块时所使用的信息和技术的集合。

我将假设您已经安装了Play 2,如果没有,请直接访问http://www.playframework.org/documentation/2.0/Installing ,以获取有关如何进行设置的详细信息。

在第一部分中,我们将介绍创建和发布模块以及添加示例应用程序的基础知识。 接下来的两部分将更深入地介绍插件,拦截器,标签和其他有用的工具。

首先,简要介绍一下模块和库之间的区别。 在Play 1.x中,使用“ play new-module”创建了一个模块,并通过模块存储库进行分发。 在Play 1.1之前,模块都是通过application.conf条目控制的,并且库是在本地添加的。 从Play 1.2开始,模块和库都通过基于Ivy的依赖关系管理机制进行控制。 不过,在这两种情况下,都有一个明确的模块概念(与Play紧密集成,遵循Play的封装结构等约定)和一个库(一个通用的第三方库)。

在播放2中,线条模糊到一定程度。 现在,通过Ivy或Maven,模块以与库相同的方式分发,并且包结构可以是任意的,因此您可以拥有传统的com.example.whatever结构。 从这个角度来看,模块和库之间的唯一真正区别是模块直接使用Play API。

其次,关于语言的说明。 由于Play 2本身支持Java和Scala,因此您可以使用任何一种语言来实现模块。 如果模块具有自己的应用程序可以使用的API,则Java和Scala之间的出色互操作性意味着-在大多数情况下,您所选择的语言与使用API​​的应用程序无关。

1.入门

作为简单的介绍,我们将创建一个基本的日志记录模块,该模块遵循行业最佳实践,将输出写入控制台窗口。 这个模块称为mylogger,因为它是星期一,而我现在并不觉得很有创意。 该模块(主要)将用Java编写。

您可以将Play 2模块视为是Play 2应用程序,其中缺少一些文件。 因此,您可以按照与应用程序相同的方式来创建模块。 转到或创建用于保存项目的目录,然后使用“播放新的Mylogger”创建应用。 出现提示时选择选项2,以创建一个简单的Java应用程序。

steve@hex:/tmp$ play new mylogger_            __ __ | | __ _ _  _| |
| '_ \| |/ _' | || |_|
|  __/|_|\____|\__ (_)
|_|            |__/play! 2.0, http://www.playframework.orgThe new application will be created in /tmp/myloggerWhat is the application name?
> myloggerWhich template do you want to use for this new application?1 - Create a simple Scala application2 - Create a simple Java application3 - Create an empty project> 2OK, application mylogger is created.Have fun!

因为我们将在模块旁边有一个示例应用程序,所以我们将稍微更改目录结构。 目前,它看起来像这样:

mylogger
– app
– conf
– project
– public
– target
– .gitignore
– README

在mylogger目录中,创建两个新目录,项目代码和示例。 将上面列出的所有文件复制到项目代码目录中。 您现在应该拥有

mylogger
– samples
– project-code– app– conf– project– public– target– .gitignore– README

conf目录包含两个文件-路由和application.conf。

– Play必须存在application.conf才能将mylogger /项目代码识别为Play应用程序,因此我们无法删除它,但可以删除其中包含的所有内容。 模块需要的任何配置都应添加到“实际”应用程序的application.conf中。
–必须删除路由*。 如果您不这样做,它可能/将取代使用该应用程序的任何应用程序的路由文件,这是一件不好的事情(主要是因为什么都不起作用)。

清空application.conf并删除路由后,在项目代码中键入“ play”以启动Play控制台。

steve@hex:/tmp/mylogger/project-code$ play
[info] Loading project definition from /tmp/mylogger/project-code/project
[info] Set current project to mylogger (in build file://tmp/mylogger/project-code/)_            __ __ | | __ _ _  _| |
| '_ \| |/ _' | || |_|
|  __/|_|\____|\__ (_)
|_|            |__/play! 2.0, http://www.playframework.org> Type "help play" or "license" for more information.
> Type "exit" or use Ctrl+D to leave this console.[mylogger] $

现在,我们有了一个有效的Play 2模块(请注意,它什么也不做)。

如果您使用的是IDE,那么现在是创建项目的好时机-本教程与IDE无关,因此,如果需要,您可以使用位于http://www.playframework.org/documentation/2.0/IDE的指南。去做这个。

2.添加一些功能

如上所述,Play 2模块可以具有更传统的com.example.package包结构,但是默认的Play应用程序具有传统的app / controllers,app / models等结构。 我们现在将其保留,并在本教程的后面部分进行更改。

2.1刀耕火种

在app文件夹中,我们具有“ play new”命令为我们创建的以下结构:

app
– controllers– Application.java
– views– index.scala.html– main.scala.html

对于此模块的初始迭代,我们不需要任何视图,因此您可以删除视图包。

您也可以删除Application.java,因为我们是从头开始编写的。

2.2添加一些模块代码

在controllers包中,创建一个名为MyLogger.java的新类。 它不需要扩展或实现任何东西,它包含一个方法:

package controllers;/*** @author Steve Chaloner*/
public class MyLogger
{public static void log(String message){System.out.println("MyLogger: " + message);}
}

2.3喝啤酒

您刚刚编写了一个模块。 去喝啤酒。

2.4啤酒后实现

当您凝视着现在空荡荡的杯子,充满创造力的喜悦和即将来临的行业声誉时,您可能会意识到,实际上没有人能够进入您的模块,因为它位于您的计算机上。 您需要发布它。

3.发布并受到谴责

对于此示例,我们将要发布到您的本地存储库。 在Play安装的根目录中,有一个存储库目录,这是您首先推送模块的位置。

发布之前,请始终确保已运行“干净”,否则,从源树中删除的某些类/文件可能仍以编译形式存在,并最终出现在模块jar文件中。 如果该类与您实际应用程序中的类匹配,则可以在您的实际类中代替它。 真烂

在Play控制台中,使用“ clean”,然后使用“ publish-local”打包您的模块,并将其发布到本地仓库:

[mylogger] $ publish-local
[info] Updating {file:/tmp/mylogger/project-code/}mylogger...
[info] Packaging /tmp/mylogger/project-code/target/scala-2.9.1/mylogger_2.9.1-1.0-SNAPSHOT-sources.jar ...
[info] Done packaging.
[info] Wrote /tmp/mylogger/project-code/target/scala-2.9.1/mylogger_2.9.1-1.0-SNAPSHOT.pom
[info] Done updating.
[info] :: delivering :: mylogger#mylogger_2.9.1;1.0-SNAPSHOT :: 1.0-SNAPSHOT :: release :: Mon Mar 19 20:57:26 CET 2012
[info]  delivering ivy file to /tmp/mylogger/project-code/target/scala-2.9.1/ivy-1.0-SNAPSHOT.xml
[info] Compiling 1 Java source to /tmp/mylogger/project-code/target/scala-2.9.1/classes...
[info] Generating API documentation for main sources...
model contains 4 documentable templates
[info] Packaging /tmp/mylogger/project-code/target/scala-2.9.1/mylogger_2.9.1-1.0-SNAPSHOT.jar ...
[info] Done packaging.
[info] API documentation generation successful.
[info] Packaging /tmp/mylogger/project-code/target/scala-2.9.1/mylogger_2.9.1-1.0-SNAPSHOT-javadoc.jar ...
[info] Done packaging.
[info]  published mylogger_2.9.1 to /home/steve/development/play/play-2.0/framework/../repository/local/mylogger/mylogger_2.9.1/1.0-SNAPSHOT/poms/mylogger_2.9.1.pom
[info]  published mylogger_2.9.1 to /home/steve/development/play/play-2.0/framework/../repository/local/mylogger/mylogger_2.9.1/1.0-SNAPSHOT/jars/mylogger_2.9.1.jar
[info]  published mylogger_2.9.1 to /home/steve/development/play/play-2.0/framework/../repository/local/mylogger/mylogger_2.9.1/1.0-SNAPSHOT/srcs/mylogger_2.9.1-sources.jar
[info]  published mylogger_2.9.1 to /home/steve/development/play/play-2.0/framework/../repository/local/mylogger/mylogger_2.9.1/1.0-SNAPSHOT/docs/mylogger_2.9.1-javadoc.jar
[info]  published ivy to /home/steve/development/play/play-2.0/framework/../repository/local/mylogger/mylogger_2.9.1/1.0-SNAPSHOT/ivys/ivy.xml
[success] Total time: 4 s, completed Mar 19, 2012 8:57:28 PM

如果您查看$ PLAY_HOME / repository / local,现在将看到一个名为mylogger的目录。 由于我们没有提供组织名称,因此该组织与模块本身具有相同的名称。 进入mylogger,您将看到工件– mylogger_2.9.1。 文件名的2.9.1部分来自Play本身,并且(似乎是)版本控制。 如果有人对此有更多了解,请发表评论并告诉我。

在mylogger_2.9.1中,我们具有模块版本,在本例中为1.0-SNAPSHOT,而该版本又包含jar文件,源jar,Maven和Iyy信息等。

所有这些信息从何而来? 它基于project / Build.scala文件。 在这里,您可以提供模块的名称,组织,版本和其他各种信息。 目前,我们将保持原样,但是随着我们对某些问题的深入了解,此极其重要的文件将得到更新。

4.提供样品

您可以编写世界上最好,最令人难以置信的有用模块,但是如果没有示例应用程序来a)展示它的工作原理,b)展示它的工作原理,那么您将难以令人信服。 这就是为什么我们在最初创建模块时将目录结构改回原来的原因。 打开另一个终端,然后转到mylogger / samples目录-现在该展示mylogger可以做什么。

4.1一个示例应用程序是一个Play应用程序

由于我们正在编写一个Play模块,因此提供一个Play应用程序作为示例很有意义。 现在我们在mylogger /示例中,使用“播放新的mylogger-示例”来创建示例应用程序。 同样,选择选项2来制作一个简单的Java应用程序。

4.2声明依赖

为了使用mylogger,我们必须在mylogger-sample / project / Build.scala中为其声明一个依赖项。 打开此文件,然后更改

val appDependencies = Seq(// Add your project dependencies here,)

val appDependencies = Seq("mylogger" % "mylogger_2.9.1" % "1.0-SNAPSHOT")

您可以看到这与mylogger / mylogger_2.9.1 / 1.0-SNAPSHOT的存储库路径匹配。

懒洋洋地,我们还将声明本地存储库为查找模块的地方。 更改

val main = PlayProject(appName, appVersion, appDependencies, mainLang = JAVA).settings(// Add your own project settings here)

val main = PlayProject(appName, appVersion, appDependencies, mainLang = JAVA).settings(resolvers += "Local Play Repository" at "file://path/to/play-2.0/repository/local")

(但更改路径以适合您的本地安装)

在mylogger / samples / mylogger-sample目录中,使用“ play”启动Play控制台。 如果使用“ dependencies”命令,您将看到mylogger现在是应用程序的依赖项。

重要的提示! 自从我们在更改Build.scala后启动了Play控制台以来,所做的更改将自动被提取。 如果在控制台打开时更改此文件,请使用“重新加载”以确保使用了更改。

4.2使用模块

在您新的默认Play应用程序中,我们将向控制器/Application.java添加一行以调用MyLogger:

package controllers;import play.mvc.Controller;
import play.mvc.Result;
import views.html.index;public class Application extends Controller
{public static Result index(){MyLogger.log("Here's my log message");return ok(index.render("Your new application is ready."));}
}

请注意,我们不需要导入MyLogger,因为它也在controllers软件包中。

“运行”该应用程序,然后转到http:// localhost:9000。 片刻之后,页面将呈现出来,您将在控制台中看到

[info] play - Application started (Dev)
MyLogger: Here's my log message

重新加载页面几次,您会看到每次都出现日志消息。

5.再喝一杯啤酒

恭喜,您现在有了一个模块和一个工作示例。 它实际上并没有为您的示例应用程序增加多少价值,但这将在第2部分中得到解决。同时,将头放在冰箱上,为自己准备另一杯啤酒。

您可以在此处下载此示例的完整源代码

参考: Play 2的编写模块,第1部分:在Objectify博客上从我们的JCG合作伙伴 Steve Chaloner获得帮助。

翻译自: https://www.javacodegeeks.com/2012/04/writing-modules-for-play-2-part-1-get.html

编写Play 2的模块,第1部分:使工作正常相关推荐

  1. play 拦截器_编写Play 2的模块,第2部分:拦截器

    play 拦截器 在本教程的第一部分中,我们介绍了创建,发布和调用模块的基本知识. 我们创建的模块并没有真正做很多事情,因此现在是时候使用Play的某些功能来扩展功能了. 1.拦截器 拦截器使您可以拦 ...

  2. 编写Play 2的模块,第2部分:拦截器

    在本教程的第一部分中,我们介绍了创建,发布和调用模块的基本知识. 我们创建的模块并没有真正做很多事情,因此现在是时候使用Play的某些功能来扩展功能了. 1.拦截器 拦截器使您可以拦截对控制器的调用, ...

  3. (Xposed)编写第一个Xposed模块

    编写第一个Xposed模块 1.创建项目 在创建项目时,选择一个有MainActivity的项目,要是注册空项目还要自己去注册入口activity 2.添加Xposed提供的jar到lib目录 3.修 ...

  4. python反编译luac_Lua程序逆向之为Luac编写IDA Pro处理器模块

    上一篇讲解了如何加载一个Luac文件到IDA Pro当中,加载进入idb数据库的内容犹如切好洗净的食材,并不能粗暴的直接展示给用户,还需要IDA Pro中的处理器模块对内容进行下一步的反汇编渲染与指令 ...

  5. iOS应用模块化的思考及落地方案(一)模块的划分及模块化工作流程

    1.0 什么是模块化 很多关于重构及设计模式的介绍中,经常提到的几个词语是复用及解耦. 模块化之所以被提出,也更多是为了解决这几个问题. 复用可以减少重复造轮子的情况,很容易理解的是,我们经常使用的g ...

  6. boost::filesystem模块演示错误报告的工作原理的测试程序

    boost::filesystem模块演示错误报告的工作原理的测试程序 实现功能 C++实现代码 实现功能 boost::filesystem模块演示错误报告的工作原理的测试程序 C++实现代码 #i ...

  7. C语言试题二十四之编写一个函数unsigned function(unsigned w),w使一个大于10的无符号整数,若w是n(n≥2)位的整数,则函数求出w后n-1位的数作为函数值返回。

    1. 题目 请编写一个函数unsigned function(unsigned w),w使一个大于10的无符号整数,若w是n(n≥2)位的整数,则函数求出w后n-1位的数作为函数值返回. 比如:w是1 ...

  8. 如何在Go中编写防弹代码:不会失败的服务器工作流程

    by Tal Kol 通过塔尔科尔 如何在Go中编写防弹代码:不会失败的服务器工作流程 (How to write bulletproof code in Go: a workflow for ser ...

  9. 2、采用结构体数组编写程序,定义一个含职工姓名、工作年限、工资总额的结构体类型,从键盘输入5名职工的信息,最后再对工作年限超30年的职工加1000元工资,并输出工资变化后的所有职工的信息

    2.采用结构体数组编写程序,定义一个含职工姓名.工作年限.工资总额的结构体类型,从键盘输入5名职工的信息,最后再对工作年限超过30年的职工加1000元工资,并输出工资变化后的所有职工的信息(要求用下标 ...

  10. 了解串口协议和RS-232标准,以及RS232电平与TTL电平的区别,了解“USB/TTL转232“模块(以CH340芯片模块为例)的工作原理。

    目录 一.何为串口通信协议 二.RS-232 三.TTL电平与RS232电平的区别 四.了解"USB/TTL转232"模块(以CH340芯片模块为例)的工作原理. ​​​​​​​ ...

最新文章

  1. 前线解释多线程《二》
  2. vs2005's addin folder
  3. spark sql and hive 3g数据测试
  4. IT是产品、IT是服务、IT是能力
  5. 分布式机器学习_229页,CMU博士张昊毕业论文公布,探索机器学习并行化的奥秘...
  6. 从0开始做Windows Phone 7开发
  7. HTTP1.1/2.0与QUIC协议
  8. 智能移动项目打包发布经验交流
  9. 高级文本编辑器——Kate
  10. 混淆的艺术-(苍井空变凤姐)Proguard源码分析(二)Proguard参数解析
  11. 交通灯控制逻辑电路设计
  12. uk码对照表_36码(uk码和中国码对照表)
  13. Harbor 核心服务不可用---故障排除
  14. 安装和使用IBM PowerVP和IBM AIX
  15. 超实分析手机版,国际研究生数学教材
  16. MATLAB 矩阵处理及多项式计算
  17. 为什么我从Flutter转投Electron的怀抱?
  18. 几种快速传输大文件的方式
  19. 捕鱼达人的算法猜测—较色碰撞算法
  20. pyqt5 登录界面界面的设计(多窗口的设计)

热门文章

  1. git连接到github(SSH无密码登陆)
  2. 索引---B+Tree
  3. oracle密码不能重复用_重复码
  4. java 正则表达式 开头_如何在Java中修复表达式的非法开头
  5. 公证服务信息_使用多个公证员提高网络吞吐量
  6. 手游建筑美术资源_建筑商和机械手
  7. 构建器设计模式_创新设计模式:构建器模式
  8. hotspot 垃圾收集器_HotSpot增量Java垃圾收集器
  9. java jooq_将Java EE与jOOQ结合使用的初学者指南
  10. mockito入门_Mockito入门