文档章节

play1.x 第一弹 :与play的初次邂逅(搭建,目录结构,生命周期)

星闪
 星闪
发布于 2017/08/07 11:57
字数 1565
阅读 5
收藏 0

谨以此系列文章进行学习、记录、分享。

注:参考了play官方文档    https://www.playframework.com/documentation/1.2.x/home

前言

    与play的第一次邂逅,还是在来到这个公司的时候,这个项目应用的就是play项目,对于之前一直使用传统框架(例如:spring  springMVC mybaits  struts hibernate)的我,对这个框架还是满新奇的!

    play framework说他是一个框架 但是我认为他是一个基于JVM的可玩性很高的,开发平台,在这里你可以省去繁琐的关系抽象,省去繁杂的配置文件,更神奇的是,他解决了java的往常平台的一大问题重复和繁琐的编译包部署周期,可以直接线上改编代码,他更侧重于生产的速度,让你有更多的时间去想你要干什么,而不用为以后准备各种关系的抽象,和去重复重启项目。

    Play框架是由Web开发人员为Web开发人员编写的,这是一个非常规的定位,将Web的原则和约定放在第一位,Java是第二个。具体来说,这意味着Play框架更符合W3C的万维网体系结构,而不是Java Enterprise Edition(Java EE)约定。

    都说兴趣才是最后的学习方式,下边我们一起paly一下。

搭建及简单应用(配合eclipse)

    

    既然要play,首先我们要简单的搭建一下play,并简单运行它,其实play的搭建和运行非常的简单,只需要下载压缩包(这里是1.2.7版本),解压,并把路径配置到环境变量中即可,配置之后,我们可以在黑窗口(cmd)中 输入play命令,看看有没有效果,有的话 就是配置成功。

    既然配置成功了,那么我们就先建一个项目玩一下,首先我们进入黑窗口,进入到你想建项目的目录,输入命令play new <项目名>,Play会在当前路径下创建项目。

    那么既然要配合eclipse使用,我们就要把这个项目转换一下,输入play eclipsify <项目名>命令进行转换,之后再eclipse中进行导入项目即可。

    导入之后会在项目中产生一个eclipse文件夹,并在里边生成三个文件,我们可以在这三个文件上run as 和debug as ,

    直接运行Debug As 执行helloworld会报错,需要:打开helloworld.launch,找到

<stringAttribute key="org.eclipse.jdt.launching.VM_ARGUMENTS" value="-Xdebug -Xrunjdwp:transport=dt_socket,address=8000,server=y,suspend=n -Dplay.debug=yes -Dplay.id= -Dapplication.path  …/>

    将-Xrunjdwp:transport=dt_socket,address=8000,server=y,suspend=n 去掉。然后Debug As,即可成功启动调试。

    还有一个比较好的方法直接配置一下debug或run直接运行就好,这样很方便。

                                            

    之后访问http://localhost:9000/ 就可以到项目,到此项目搭建完成。

目录结构

项目搭建而完成了,那么我们应该了解一下他的目录结构了。

web_app                         根目录               

|   sbt                         SBT Unix 批处理脚本用于启动sbt-launch.jar

|   sbt.bat                     SBT Windows 批处理脚本用于启动sbt-launch.jar

|   sbt-launch.jar              SBT 启动的Java可执行类库

|

+---app                         Play Web 应用全部代码所在目录

|   |

|   +---models                  模型代码所在目录

|   |       Message.scala       留言板例程模型代码

|   |

|   +---controllers             控制器代码所在目录

|   |       Application.scala   默认控制器代码

|   |

|   \---views                   视图(Play Scala HTML模板) 代码所在目录

|           main.scala.html     主模板文件

|           index.scala.html    首页模板文件

|           msgboard.scala.html 留言板例程模板文件

|

+---conf                        Play 配置文件所在目录

|       application.conf        应用配置文件

|       routes                  应用入口路由文件,所有的HTTP请求将通过该文件转发到指定的Scala对象处理

|

+---logs                        日志目录

|       application.log         应用运行日志

|

+---project                     SBT工程文件

|       build.properties        保存所需的SBT版本信息,通常无需更改

|       Build.scala             主要的工程配置文件

|       plugins.sbt             告知SBT本工程所需要的插件以及下载位置

|

+---public                      存储一切直接发送给浏览器的资源文件

|   |

|   +---images                  图像文件,如JPEG、PNG、GIF等

|   |

|   +---javascripts             JavaScript脚本文件

|   |

|   \---stylesheets             CSS样式表文件

|

\---target                      存放编译后的可执行代码和编译时的中间代码

请求的生命周期

         其实了解一个框架,首先就应该了解他的请求是怎么传递的,他的传递过程是怎么样的,这样你才会对这个框架的走向有一个大体的概念,在了解请求的生命周期前我们先来看一下mvc模型,play是遵循MVC模型的。

    Play的MVC模型

  •    模型层:他对数据进行定义和处理,来返回我们所需要的数据。大多数应用程序使用持久存储机制(如数据库)来存储数据。MVC没有特别提及数据访问层,因为它被理解为在模型下面或由模型封装。
  •  视图层:其实他就是通常的用户界面的形式。为了不同的目的,单个模型可以存在多个视图。在Web应用程序中,视图通常以HTML,XML或JSON等“Web格式”呈现。然而,在某些情况下,视图可以以二进制形式表示,例如动态渲染的图表。
  •  控制器:它的作用是响应事件(通常为用户操作),并对其进行处理,并且还可以调用模型上的数据。在Web应用程序中,事件通常是HTTP请求:控制器侦听HTTP请求,从“事件”中提取相关数据,例如查询字符串参数,请求标头...并对底层模型对象应用操作。                                                                                  
  • 在Play应用程序中,这三个层在app目录中定义,每个层都在一个单独的Java包中。
  • 请求生命周期

    ·  框架接收到HTTP请求。

    ·  路由器组件尝试找到能够接受此请求的最具体路由。然后调用相应的动作方法。

    ·  执行应用程序代码。

    ·  如果需要生成复杂视图,则会呈现模板文件。

    ·  操作方法的结果(HTTP响应代码,内容)然后被写为HTTP响应。

    •                                     

 

© 著作权归作者所有

共有 人打赏支持
星闪
粉丝 0
博文 5
码字总数 5173
作品 0
高级程序员
让netbeans7.3 支持play 2.1.X

netbeans是一个很好的免费的 java IDE,也是所有IDE中,中文最好的。 当用netbeans开发play1.x的时候,只要用play netbeansify就可以了,然后用netbeans直接打开项目就可以开发了。 如果用n...

ln_bo
2013/04/19
0
0
Play Framework 安装

记得有一次OSC高手问答是关于Play Framework的,那是我第一次听说Play Framework这个所谓的全堆栈式的java应用框架,当时也没有非常吸引我,但是它也算在我的脑海里留下了一定的印象,由于公...

beidao-ai
2012/06/05
0
3
Play源码深入之六:数据库与事务管理

由前面的文章大致知道,Play的事务由过滤器中处理,这里理一下Play框架与数据库相关的部分。 主要是play.db包中的DBPlugin/DB类,与play.db.jpa包中的JPAPlugin/JPA类有关,前者管理数据源,...

刀狂剑痴
2015/08/27
686
0
play1.2.5公用model层问题

@javadeveloper 你好,想跟你请教个问题:您好,请问下你们是使用的play1.x。我想问下你们多个play项目怎么公用model呢。连接的库是一个库。

八十四亩地
2015/06/23
149
2
Play源码深入之七:Play的MVC实现

整体来说,Play1.x是一个较完善的框架,各种功能都一应俱全,有点像句老话“麻雀虽小五脏俱全”哈。虽没有Struts、SpringMVC的大名气,但是使用起来,相当顺手。本文将深入Play1.x的MVC,也整...

刀狂剑痴
2015/08/27
700
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

八大包装类型的equals方法

先看其中一个源码 结论:八大包装类型的equals方法都是先判断类型是否相同,不相同则是false,相同则判断值是否相等 注意:包装类型不能直接用==来等值比较,否则编译报错,但是数值的基本类型...

xuklc
33分钟前
1
0
NoSQL , Memcached介绍

什么是NoSQL 非关系型数据库就是NoSQL,关系型数据库代表MySQL 对于关系型数据库来说,是需要把数据存储到库、表、行、字段里,查询的时候根据条件一行一行地去匹配,当量非常大的时候就很耗...

TaoXu
昨天
0
0
890. Find and Replace Pattern - LeetCode

Question 890. Find and Replace Pattern Solution 题目大意:从字符串数组中找到类型匹配的如xyy,xxx 思路: 举例:words = ["abc","deq","mee","aqq","dkd","ccc"], pattern = "abb"abc ......

yysue
昨天
0
0
Linux | Redis

写在前面的话 常言道,不作笔记不读书。在下是深有体会啊,所以,跟我一起做下本节的笔记吧,或许多年以后,你一定会感谢今天的你。 安装 在官网的下载页 Redis Download 直接写了在Linux的安...

冯文议
昨天
1
0
NoSQL-memcached

NoSQL介绍 NoSQL叫非关系型数据库。而关系型数据库代表有MySQL。对于关系型数据库来说,是需要把数据存储到库、表、行、字段里,查询的时候根据条件一行一行地去匹配,当量非常大的时候就很...

ln97
昨天
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部