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

几周前,我迁移了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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/373071.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Dotnet Core

Global Exceptionhttp://www.talkingdotnet.com/global-exception-handling-in-aspnet-core-webapi/转载于:https://www.cnblogs.com/zwheui/p/6339692.html

交友系统设计:哪种地理空间邻近算法更快?

小熊学Java:https://javaxiaobear.cn 交友与婚恋是人们最基本的需求之一。随着互联网时代的不断发展,移动社交软件已经成为了人们生活中必不可少的一部分。然而,熟人社交并不能完全满足年轻人的社交与情感需求,于是陌生人交友平台…

linux ntp 'ntp_request.c'远程拒绝服务漏洞,NTP 'ntp_request.c'远程拒绝服务漏洞

NTP ntp_request.c远程拒绝服务漏洞发布日期:2013-12-30更新日期:2014-01-09受影响系统:NTP NTP 描述:--------------------------------------------------------------------------------BUGTRAQ ID: 64692CVE(CAN) ID: CVE-20…

指针的内容 ; 指针的地址 指针所指向的内容 指针的类型 指针所指向的类型...

这几个个东东很具有迷惑性。 int a10; //假设a的地址是 0x0000004C int *p; //假设p的地址是 0x0035FA94 p&a; 指针的内容:指针里面存放的是地址。 指针p里面存放的是a的地址(&a)。即指针p里面存放的内容是0x0000004C。 指针的地址&#xff…

Apache Camel教程– EIP,路由,组件,测试和其他概念的简介

公司之间的数据交换增加了很多。 必须集成的应用程序数量也增加了。 这些接口使用不同的技术,协议和数据格式。 但是,这些应用程序的集成应以标准化的方式建模,有效实现并由自动测试支持。 企业集成模式(EIP)[1]中存在…

iOS开发UI篇—UITableview控件简单介绍

一、基本介绍 在众多移动应⽤用中,能看到各式各样的表格数据 。 在iOS中,要实现表格数据展示,最常用的做法就是使用UITableView,UITableView继承自UIScrollView,因此支持垂直滚动,⽽且性能极佳 。 UITableview有分组和不分组两种样式,可以在storyboard或…

PL/SQL 08 异常 exception

--PL/SQL错误 编译时 运行时--运行时的出错处理 EXCEPTION --异常处理块DECLARE …BEGIN …EXCEPTION WHEN OTHERS THEN handler_error(…);END; --用户自定义的异常DECLARE e_TooManyStudents EXCEPTION; …BEGIN … RAISE e_TooManyStudents; …EXCEPTION WHEN e_TooMany…

html鼠标事件没反应,鼠标有时候点击没反应怎么解决

关于鼠标有时候点击没反应的问题,一些网友显得一头雾水,那这该怎么解决呢?下面就由小编来给你们说说鼠标有时候点击没反应的原因及解决方法吧,希望可以帮到你们哦!鼠标有时候点击没反应的解决方法一:一,系统繁忙&…

动态ADF火车:以编程方式添加火车停靠站

我将展示如何以编程方式“即时”将火车停靠站添加到ADF火车中。 在我的用例中,我有一些票务预订应用程序。 它具有训练模型的有限任务流。 在火车的第一站,用户输入乘客的数量,在随后的站点,他们输入一些乘客的信息。 带有乘客信息…

修改sqlserver的数据库排序规则语句

alter database SOETMS collate Chinese_PRC_CI_AS 转载于:https://www.cnblogs.com/lxboy2009/p/5481977.html

关于存储过程权限

关于ORACLE账号的权限问题,一般分为两种权限: 系统权限: 允许用户执行特定的数据库动作,如创建表、创建索引、创建存储过程等 对象权限: 允许用户操纵一些特定的对象,如读取视图,可更新某些列、执行存储过程等 像这种查…

宁波镇海2021年高考成绩查询,最新!2021年,宁波镇海区的这14所中小学“爆了...

宁波镇海区教育局发布了2021年公办学校小学一年级、初中一年级招生第一次预警,这也是宁波首个发布2021年公办学校招生预警的县、市、区。根据最新数据摸排,宁波镇海区有8所小学红色预警、2所初中红色预警,1所小学黄色预警、3所初中黄色预警。…

用Java解决生产者-消费者问题

当我们尝试多线程编程时,生产者-消费者问题是最常见的问题之一。 尽管不像多线程编程中的其他一些问题那样具有挑战性,但是错误地实现此问题可能会造成应用程序混乱。 生产的物品将不使用,开始的物品将被跳过,消耗量取决于生产是在…

哪位科学家奠定了计算机结构理论,计算机等级考试一级理论知识选择题题库(1-50)...

领域中的问题为主的数值计算称为科学计算B)计算机应用可分为数值应用和非数值应用两类C)计算机各部件之间有两股信息流,即数据流和控制流D)对信息(即各种形式的数据)进行收集、储存、加工与传输等一系列活动的总称为实时控制答案:D32. 金卡工程是我国正在…

axios 参数为payload的解决方法

1. 添加头部headers headers: {Content-Type: application/x-www-form-urlencoded,}, axios.post(url, {a: 1, b:2}, {headers: {Content-Type: application/x-www-form-urlencoded,}, }).then(response > response.data).then(err > {console.log(err);}); 2. 在Browser…

超出了GC开销限制– Java堆分析

这篇文章是我们原来的GC超出限制的问题模式帖子的延续。 正确的Java堆分析对于消除O​​utOfMemoryError:GC开销问题至关重要。 如果您不熟悉此Java HotSpot 1.6错误,建议您首先阅读有关此主题的第一篇文章 。 本文将为您提供一个示例程序和一个教程&…

开灯问题

开灯问题 时间限制:3000 ms | 内存限制:65535 KB难度:1描述有n盏灯,编号为1~n,第1个人把所有灯打开,第2个人按下所有编号为2 的倍数的开关(这些灯将被关掉),第3 个人按…

计算机科学基本理论,计算机科学的基础知识.ppt

计算机科学的基础知识第二章 计算机科学的基础知识 本章学习目标: 数据的理解、分类与表示 计算机的基本结构与工作原理 程序设计基础 算法基础 2.1 数据类型 2.2 计算机内部的数据 2.3 表示数据 2.4 十进制表示法 2.5 二进制表示法 2.6 十六进制表示法 2.7 八进制表…

损坏注册表的原因

软件: (1)应用程序错误 (2)驱动程序不兼容或使用了错误的应用程序 (3)应用程序在注册表中添加了错误的内容 (4)应用程序添加了错误的数据文件和应用程序之间的联系 硬件: &#xff0…

cdockpane限制调整大小_影视后期制作小伙伴必看:使用AU对声音质量进行调整的三大技巧...

一、增幅一般人进入AU的音频调整界面,会使用图中的旋钮进行音量调整,这种操作是错误的,因为通过拖拽并不能确定调整音量的大小幅度,精准度极低,反复操作才能试出最佳音量,效率极低。最优方案是使用左侧效果…