play 打包 模块
重要的是要注意,这不是权威指南,而是我在处理自己的模块时所使用的信息和技术的集合。
我假设您已经安装了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 打包 模块