Grails 入门

2024-01-08 17:58
文章标签 入门 grails

本文主要是介绍Grails 入门,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

1 下载和安装

让Grails运行起来的第一步是安装发行包。请按照如下步骤:

  • 下载 Grails的二进制发行包并解压到你指定的目录下
  • 新增 GRAILS_HOME 环境变量并指向你解压发行包时选择的目录
    • Unix/Linux系统上通常在你的profile文件中添加 export GRAILS_HOME=/path/to/grails 来设置环境变量
    • Windows系统上则是在 我的电脑/属性/高级/环境变量 中添加相同的环境变量
  • 现在需要添加 bin 目录到 PATH 环境变量中:
    • Unix/Linux系统上在profile中继续添加 export PATH="$PATH:$GRAILS_HOME/bin"
    • Windows系统上修改 我的电脑/属性/高级/环境变量 中的 Path 环境变量

如果Grails正常工作了那么你可以在终端窗口中键入 grails 命令并看到如下简单的输出:

 


Welcome to Grails 1.0 - http://grails.org/
Licensed under Apache Standard License 2.0
Grails home is set to: /Developer/grails-1.0
No script name specified. Use 'grails help' for more info

 

2从Grails 1.0.x升级

尽管Grails开发团队试图将从Grails 1.0.x升级到Grails 1.1时带来的影响降到最低限度,但仍然有一些事项需要你认真考虑。重大变化描述如下。

 

Groovy 1.6

Grails 1.1现在和Groovy 1.6协同工作并且不再支持针对Groovy 1.5的代码编译。如果你有一个使用Groovy 1.5编写的组件库,在将它用于Grails 1.1之前,你需要针对Groovy 1.6来重新编译它。

 

Java 5.0

Grails 1.1现在不再支持JDK 1.4,如果你希望正常使用Grails,那么建议你继续使用Grails 1.0.x系列直到你能够升级你的JDK。

 

配置的变化

1) 为了系统的一致性,设置项 grails.testing.reports.destDir 已经被重命名为 grails.project.test.reports.dir

2) 下列设置已经从 grails-app/conf/Config.groovy 文件中移到了 grails-app/conf/BuildConfig.groovy 文件:

  •  
    • grails.config.base.webXml
    • grails.war.destFile
    • grails.war.dependencies
    • grails.war.copyToWebApp
    • grails.war.resources

3) 自从Java 5.0成为基线起, grails.war.java5.dependencies 选项已不再被支持(见上文)。

4) jsessionid的使用(现在被认为是有害的)默认是禁用的。如果你的应用程序需要用到jsessionid,你可以重新启用它,在 grails-app/conf/Config.groovy 文件中添加如下设置:

 

grails.views.enable.jsessionid=true

5) 用来配置Log4j的语法已经改变了。看看用户指南的 登录 一章可以获得更多信息。

 

插件的变化

Grails 1.1默认将不在你的 PROJECT_HOME/plugins 目录下储存插件。这可能导致你的应用程序出现编辑错误,解决办法是重新安装所有的插件或者在 grails-app/conf/BuildConfig.groovy 文件中设置下列属性:

 

grails.project.plugins.dir="./plugins"

 

脚本的变化

1) 如果你先前使用的是Grails 1.0.3或以下的版本,那么下边用于从GRAILS_HOME导入脚本的语法将不再被支持:

 

Ant.property(environment:"env")
grailsHome = Ant.antProject.properties."env.GRAILS_HOME"

includeTargets << new File ( "${grailsHome}/scripts/Bootstrap.groovy" )

取而代之的是 grailsScript 方法,它能导入一个命名的脚本:

 

includeTargets << grailsScript( "Bootstrap.groovy" )

2) 由于升级到了Gant,所有对变量 Ant 的引用应该改为 ant

3) 项目的根目录不再存于classpath中,像如下的资源加载方式将无法使用:

 

def stream = getClass().classLoader.getResourceAsStream("grails-app/conf/my-config.xml")

但是你可以使用Java文件API以及 basedir 属性来完成如上操作:

 

new File("${basedir}/grails-app/conf/my-config.xml").withInputStream { stream -> // read the file  
}

 

命令行的变化

run-app-httpsrun-war-https 这两个命令已经被取消了,取而代之的是 run-app 命令带上特定的参数:

 

grails run-app -https

 

数据映射的变化

1) 枚举类型现在可以使用它们的String值来映射,而不再是ordinal值。当然你也可以通过如下方式改变你的映射来还原为旧的习惯:

 

static mapping = {someEnum enumType:"ordinal"
}

2) 双向的一对一关联现在可以使用在所有者端的一个单列和一个外键引用来映射。你不需要做任何修改,除非你想删除在相反端包含了重复数据的那一列。

 

REST支持

接收到的XML请求现在不能被自动解析了。要启用对REST请求的解析,你需要在URL映射中使用 parseRequest 变量:

 

"/book"(controller:"book",parseRequest:true)

其次,你也可以使用新的 resource 变量来开启默认解析:

 

"/book"(resource:"book")

3 创建一个应用程序

要创建一个Grails应用程序你首先需要熟悉 grails 命令的使用,使用方式如下:

 

grails [命令名称]

假如你需要执行的命令是 create-app:

 


grails create-app helloworld

这将创建一个新的目录,其中包含了helloworld这个项目。你现在可以在终端里导航到这个目录:

 


cd helloworld

 

4 一个Hello World例子

要实现经典的"hello world!"例子你可以运行 create-controller 命令:

 


grails create-controller hello  

这将在 grails-app/controllers 目录中创建一个名为 HelloController.groovy 的控制器(参见控制器一章获得更多内容)。

控制器能用来处理web请求并用来实现“hello world!”的例子,我们的实现代码如下:

 

class HelloController {def world = {render "Hello World!"}
}

完工。现在使用另一个称为run-app的新命令来启动容器:

 


grails run-app

这将在8080端口开启一个服务器,现在可以通过http://localhost:8080/helloworld这个URL来访问你的应用程序了。

你将看到如下截图所示的内容:

这是由 web-app/index.gsp 文件所呈现的Grails介绍页面。你会注意到它已经发现了你的控制器的存在,点击链接来访问控制器,我们可以看到浏览器窗口中打印除了“Hello World!”的文本。

 

5 设置IDE

IntelliJ IDEA

目前用于Groovy和Grails开发的IDE中,最成熟、最全面的是IntelliJ IDEA 7.0和它的JetGroovy插件。在大型项目中,Grails团队优先推荐使用IDEA。

 

TextMate

由于Grails关注的是简洁性,所以我们可以使用一些更简单的编辑器,例如在Mac环境下的TextMate,它对Groovy/Grails有着优秀的支持,可以从Texmate bundles SVN获得它。

 

Eclipse

对于Eclipse,Groovy Eclipse 插件提供了语法高亮和代码自动完成等功能。

 

在Grails的Wiki上有更多关于Groovy Eclipse插件的 详细讨论。

Grails为你自动创建了用于Eclipse的.project 以及 classpath 文件,所以要在Eclipse中导入一个Grails项目,只需在“Package Explorer”中点右键并选择“Import”,随后选择“Existing project into Workspace”并“Browse”你的项目位置。

接着顺序点击“Ok”和“Finish”即可完成项目的导入和安装。

Grails也将自动安装一个项目对应的“Run Configuration”配置,随后可以在Eclipse的“Run”菜单中来使用它运行Grails。

 

6 约定优于配置

Grails使用“约定优于配置”原则来配置自己。这通常意味着文件的名称和位置被用来替代明确的配置,因此你需要熟悉Grails提供的目录结构。

以下是大致目录结构并链接到相关的章节:

  • grails-app - Groovy源码的顶级目录
    • conf - 源配置。
    • controllers - Web控制器 - MVC模式中的C层。
    • domain - 应用域。
    • i18n - 国际化(i18n)支持。
    • services - 服务层。
    • taglib - 标记库。
    • views - 视图,包含了Groovy服务器页面(GSP)。
  • scripts - Gant脚本。
  • src - 源文件目录
    • groovy - 其他的Groovy源文件
    • java -其他的Java源文件
  • test - 单元测试和集成测试。

 

7 运行应用程序

Grails应用程序可以使用 run-app 命令来运行在内置的Jetty服务器上,这个命令将默认在8080端口上启动一个服务器:

 

grails run-app

当然你也可以使用 server.port 变量来指定其他端口:

 

grails -Dserver.port=8090 run-app

更多关于 run-app 命令的信息可以在参考指南中找到。

8 测试应用程序

Grails 中的 create-* 系列命令可以为你在 test/integration 目录内创建集成测试代码框架。当然你还得自己来填写有效的逻辑测试代码,更多的信息可以参考 测试 一章。如果你要执行测试代码,那么可以运行 test-app 命令:

 

grails test-app

Grails也自动生成了用于Ant的 build.xml 文件,它可以委托Grails的 test-app 命令来运行测试代码:

 

ant test

当你使用如CruiseControl这样的持续集成平台来自动构建Grails应用程序时,使用Ant的方式将非常有用。

9 部署应用程序

Grails应用程序是通过Web应用程序档(WAR文件)的格式来部署的,它使用 war 命令来执行这个部署任务:

 

grails war

这将在你的项目根目录中产生一个WAR文件,你可以参照你的容器指南来部署它。

 

绝对不要使用 run-app 命令来作为部署的命令,因为它使Grails能够在运行期间自动重载,但这将带来许多性能和扩展性问题。

部署好Grails之后,你应该为你的容器JVM设置 -server 选项来分配足够的内容。一个较好的VM设置应该像这样:

 

-server -Xmx512M

10 创建工件

Grails提供了许多像 create-controller 和 create-domain-class 这样方便的命令,可以使用它们来为你创建 控制器 等各种类型的工件。

这只是为了方便你进行开发,你也可以随意使用喜欢的IDE或文本编辑器来完成同样的工作。

例如,一个应用程序的基础部分是 域模型 ,我们可以像这样创建它:

 

grails create-domain-class book

这将在 grails-app/domain/Book.groovy 文件中创建一个域类,内容如下:

 

class Book {  
}

还有许多类似 create-* 这样的命令,你可以在命令行参考指南中了解它们

10 支持的 Java EE 容器

Grails支持相当广泛的容器,如下:

  • Tomcat 5.5
  • Tomcat 6.0
  • GlassFish v1 (Sun AS 9.0)
  • GlassFish v2 (Sun AS 9.1)
  • Sun App Server 8.2
  • Websphere 6.1
  • Websphere 5.1
  • Resin 3.2
  • Oracle AS
  • JBoss 4.2
  • Jetty 6.1
  • Jetty 5
  • Weblogic 7/8/9/10

一些容器还有不少Bug,但在多数情况下它们都能工作的很好。在Grails的wiki站点你能找到一份 开发中已知问题列表 。

11 生成一个应用

要使用Grails快速开始,经常用到的一个特性叫做 脚手架 ,它可以用来生成一个应用的骨架。要开始这样做,你可以使用 generate-* 这样的命令,如 generate-all 可以用来生成一个 控制器 以及相关的 视图 :

 

grails generate-all Book

 

这篇关于Grails 入门的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/584329

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

数论入门整理(updating)

一、gcd lcm 基础中的基础,一般用来处理计算第一步什么的,分数化简之类。 LL gcd(LL a, LL b) { return b ? gcd(b, a % b) : a; } <pre name="code" class="cpp">LL lcm(LL a, LL b){LL c = gcd(a, b);return a / c * b;} 例题:

Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

概述 基本概念 Java Swing 的架构 Java Swing 是一个为 Java 设计的 GUI 工具包,是 JAVA 基础类的一部分,基于 Java AWT 构建,提供了一系列轻量级、可定制的图形用户界面(GUI)组件。 与 AWT 相比,Swing 提供了许多比 AWT 更好的屏幕显示元素,更加灵活和可定制,具有更好的跨平台性能。 组件和容器 Java Swing 提供了许多

【IPV6从入门到起飞】5-1 IPV6+Home Assistant(搭建基本环境)

【IPV6从入门到起飞】5-1 IPV6+Home Assistant #搭建基本环境 1 背景2 docker下载 hass3 创建容器4 浏览器访问 hass5 手机APP远程访问hass6 更多玩法 1 背景 既然电脑可以IPV6入站,手机流量可以访问IPV6网络的服务,为什么不在电脑搭建Home Assistant(hass),来控制你的设备呢?@智能家居 @万物互联

poj 2104 and hdu 2665 划分树模板入门题

题意: 给一个数组n(1e5)个数,给一个范围(fr, to, k),求这个范围中第k大的数。 解析: 划分树入门。 bing神的模板。 坑爹的地方是把-l 看成了-1........ 一直re。 代码: poj 2104: #include <iostream>#include <cstdio>#include <cstdlib>#include <al

MySQL-CRUD入门1

文章目录 认识配置文件client节点mysql节点mysqld节点 数据的添加(Create)添加一行数据添加多行数据两种添加数据的效率对比 数据的查询(Retrieve)全列查询指定列查询查询中带有表达式关于字面量关于as重命名 临时表引入distinct去重order by 排序关于NULL 认识配置文件 在我们的MySQL服务安装好了之后, 会有一个配置文件, 也就

音视频入门基础:WAV专题(10)——FFmpeg源码中计算WAV音频文件每个packet的pts、dts的实现

一、引言 从文章《音视频入门基础:WAV专题(6)——通过FFprobe显示WAV音频文件每个数据包的信息》中我们可以知道,通过FFprobe命令可以打印WAV音频文件每个packet(也称为数据包或多媒体包)的信息,这些信息包含该packet的pts、dts: 打印出来的“pts”实际是AVPacket结构体中的成员变量pts,是以AVStream->time_base为单位的显

C语言指针入门 《C语言非常道》

C语言指针入门 《C语言非常道》 作为一个程序员,我接触 C 语言有十年了。有的朋友让我推荐 C 语言的参考书,我不敢乱推荐,尤其是国内作者写的书,往往七拼八凑,漏洞百出。 但是,李忠老师的《C语言非常道》值得一读。对了,李老师有个官网,网址是: 李忠老师官网 最棒的是,有配套的教学视频,可以试看。 试看点这里 接下来言归正传,讲解指针。以下内容很多都参考了李忠老师的《C语言非

MySQL入门到精通

一、创建数据库 CREATE DATABASE 数据库名称; 如果数据库存在,则会提示报错。 二、选择数据库 USE 数据库名称; 三、创建数据表 CREATE TABLE 数据表名称; 四、MySQL数据类型 MySQL支持多种类型,大致可以分为三类:数值、日期/时间和字符串类型 4.1 数值类型 数值类型 类型大小用途INT4Bytes整数值FLOAT4By

【QT】基础入门学习

文章目录 浅析Qt应用程序的主函数使用qDebug()函数常用快捷键Qt 编码风格信号槽连接模型实现方案 信号和槽的工作机制Qt对象树机制 浅析Qt应用程序的主函数 #include "mywindow.h"#include <QApplication>// 程序的入口int main(int argc, char *argv[]){// argc是命令行参数个数,argv是