Jhipster初识

Jhipster初识
本文基于自己根据jhipster的初次接触,write down下一些笔记心得,以及一些操作步骤。
一、Jhipster介绍
1.大神语录
一个代码生成器而已
核心是Spring Boot
、spring
对j2ee企业解决方案的提供、AnjularJs
。(掌握这些是必不可少的)。
未来spring和spring提供的所有解决方案就是j2ee的趋势和核心。
Yeoman
要懂跟Spring Boot
集成的东西比如elasticsearch
cassadry
mongondb
redis
websockets
等等等等。jhipster
集成的只是它非常非常有限的一部分。
看看Spring Boot
的refrencebook 所有的jhipster的改进都是跟着springboot走的。
springdatajpa
是对hibernate
的封装 屏蔽的关系和非关系的差异 比如你用mysql oracle
就用springdatajpa
如果有一天你要换gemfire
或者mongodb了
怎么办?——换个repository
的接口就得了 就是这么简单。

二、创建第一个jhipster应用
1.准备工作
安装JDK,注意版本(我初次使用的是1.8,并且需要配置环境变量)。
安装java创建工具(Maven
或gradle
),推荐安装Maven
(并且需要配置环境变量),如果选择gradle
则无需安装,因为Jhipster
已经支持了。我选择了Maven
(版本:apache-maven-3.3.9)。
官网安装git
(配置环境变量)。我的版本是:version2.6.3。
官网安装Node.js
,安装nodejs时,同时也会一并安装npm。(注意配置环境变量,安装过程中可能已经配置好了)。我的版本是:v5.2.0。
安装Yeoman
,在dos窗口通过命令:npm install -g yo
.
安装bower
:npm install -g bower
.
安装Grunt
(推荐):npm install -g grunt-cli
或者Gulp.js
:npm install -g gulp
.
最后,安装jhipster
:npm install -g generator-jhipster

安装并配置好数据库,因为这个应用,我们打算使用mysql,因此安装配置好mysql数据库。

大功告成!
需要注意的是
准备工作中安装的软件注意需要都是操作系统对应的位数(32位或64位)。
注意版本。
注意配置环境变量。

2.开始创建jhipster应用
打开dos窗口,进入要创建的项目所对应的空文件夹(testjhipster)。输入命令:yo jhipster
.
接着出现交互问答,以便按照开发者要求去生成代码,实现应用的功能:What is the base name of your application?(testjhipster)项目的基本名称(我的理解就是项目名),输入默认的testjhipster。回车。

What is your default Java package name?(com.mycompany.myapp)项目中默认的java包的包名。我输入:com.mytest.testjhipster。回车

<font color="#f50">Which type of authentication would you like to use?(Use arrow keys)使用哪种类型的验证。这个暂时不明白,没关系,通过上下箭头选择,我们选择默认的。回车。

Which type of database would you like to use?(Use arrow keys)使用什么类型的数据库?有三个选项:SQL、MongoDB、Cassandra。MongoDB是分布式文档存储数据库,Cassandra是开源分布式NoSQL数据库类型。我们选择常用的关系数据库类型SQL。回车。

Which production database would you like to use?(use arrow keys)使用什么具体的数据库产品?我们选择默认的MySQL。回车。这个选择与项目生成后的src/main/resources/config/application-prod.yml
文件密切相关。

which development database would you like to use?开发时使用什么数据库?这里有三个选项,'H2 with disk-based persistence'、'H2 with in-memory persistence'和'MySQL',第一个是将数据保存在运行内存中,重启服务器时,数据就会丢失。第二个是将数据保存在磁盘中,目前正在测试阶段,而且不能再window下正常使用。我们选择默认的MySQL。这个选择对应项目生成后的src/main/resources/config/application-dev.yml
文件。回车。

Do you want to use Hibernate 2nd level cache?是否需要使用Hibernate二级缓存?根据自己需要,项目只是用来测试,因此我们选择NO。回车。

Do you want to use a search engine in your application?是否需要使用一个搜索引擎。这个搜索引擎可以搜到关于jhipster的相关指南。我们选择默认的No。回车。

Do you want to use clustered HTTP sessions?是否使用集群HTTP回话,不懂,没关系,选择默认的NO。回车。

Do you want to use WebSocket?是否使用websocket?不明白websocket的作用和用法。因此选择默认的No。回车。

Would you like to use Maven or Gradle for building the backend?使用Maven或者Gradle。我们选择默认的Maven。回车

Would you like to use Grunt or Gulp.js for building the frontend?使用默认的Grunt。回车。

Would you like to use the LibSass stylesheet preprocessor for your css?是否使用LibSass作为css样式表处理器。我们输入NO。回车

Would you like to enable translation support with Angular Translate?是否使用Anjular提供的翻译支持?我们选择No。回车。

Which testing frameworks would you like to use?测试框架的选择。我们选择默认,直接回车。

问题回答完毕,然后等待。直到结束,基本的jhipster项目testjhipster创建完毕。

3.IDE导入jhipster项目并运行
Spring Tool Suite(sts)
在官网下载sts。
按照如下步骤导入导入之前创建的testjhipster项目: import->Maven->Existing Maven Projects
,然后 ->next
,->browse
,选中项目导入,finish

在安装好的mysql中新建一个数据库。数据库名为:testjhipster(只要和项目中的src/main/resources/config/application-dev.yml
文件中配置的一致即可)
运行。选中项目,右击鼠标,Run As
->Spring Boot App

即可运行,控制台出现“JHIPSTER”的图样,并给出链接:http:localhost:8080
,表明成功运行。到浏览器中访问这个链接即可。
Ecplise
下载eclipse。
按照如下步骤导入导入之前创建的testjhipster项目: import->Maven->Existing Maven Projects
,然后 ->next
,->browse
,选中项目导入,finish

配置tomcat服务器,需要8.0以上。
同样,在安装好的mysql中新建一个数据库。数据库名为:testjhipster(只要和项目中的src/main/resources/config/application-dev.yml
文件中配置的一致即可)。
运行。选中项目,右击鼠标,Run As
->Run on Server
,选中配置好的tomcat,->next
,->finish
启动后,在浏览器中访问http://localhost:8080/testjhipster/
,注意:不要少了最后面的斜杠。

注意:默认的登录名和密码都是admin。
此时发现,Entities导航没有任何实体。接下来通过了解如何插入实体,从而更深入的了解testjhipster项目的内部目录结构。
后面的操作以Spring Tool Suite(sts)为例。
4.创建实体
实体是应用中的基本对象。创建实体的步骤如下:
在dos窗口进入testjhipster所在目录testjhipster,然后运行命令:yo jhipster:entity author
,回车。
接着是一系列的交互问题,目的是生成自己想要的author对象,包括域、域对应的类型,是否验证、author是否与别的实体建立关系等等。经过一些列问题,创建了一个实体:author,有属性:name(String),nation(Nation)。//nation是一个创建的枚举类,给这个域设定类型为java enum type即可。

另外还有两个问题:<font color="f50">Do you want to use a Data Transfer Object(DTO)?是否需要使用数据传输对象。默认不使用。

Do you want to use separate service class for your business logic?是否要为你的业务逻辑使用一个分离出来的服务类?默认No,使用自己的默认的CRUD实现方法,也可以选择另外两个,自己可以在生成的service类中实现自己的逻辑代码。我们选择no。

Do you want pagination on your entity?是否要为实体使用一个分页。选择第二个,生成一个简单的分页。

回车等待完成。在sts中将项目刷新,再次运行。在浏览器中访问(注意sts和eclipse在浏览器中访问时的不同)。发现Entitis项目下多了一个author实体,可以对其实现CRUD操作。数据库中也有了这个表。

5.testjhipster项目的目录结构
前端的主要代码都在src/main/webapp
下,未建实体时,其下的目录结构如下:
webapp├── index.html - Application starting page that loads everything├── bower_components - Dependencies retrieved by bower├── assets│ ├── fonts - Fonts│ ├── images - Images│ ├── styles - CSS stylesheets├── scripts│ ├── app - App specific components go in here│ │ ├── app.js - Main script│ │ ├── app.constants.js - Constants generated by build│ │ ├── main│ │ │ ├── main.js - Component's definition like a state/route│ │ │ ├── main.controller.js - Component's controller│ │ │ ├── main.html - Component's view│ │ ││ ├── components - Our reusable components, non-specific to our app│ │ ├── navbar│ │ │ ├── navbar.js│ │ │ ├── navbar.controller.js │ │ │ ├── navbar.directive.js│ │ │ ├── navbar.html│ │ ├── util - Generic components like filters to format data├── i18n - Translation files //如果选择加入翻译的话,就有这个目录。

当创建实体author后,在script下多了一个entities:
scripts├── app│ ├── entities│ │ ├── author - Main location of the CRUD front-end for author│ │ │ ├── authors.html - View to display the list of author entities│ │ │ ├── author-detail.html - View to display details of one author entity│ │ │ ├── author.js - States for list and details│ │ │ ├── author.controller.js - Controller of the list view│ │ │ ├── author-detail.controller.js - Controller of the detailed view├── components│ ├── entities│ │ ├── author│ │ │ ├── author.service.js - Service to access the Foo REST resourcei18n - 如果选择加入翻译的话,就有这个目录。├── en - 英语│ ├── author.json - English translation of author name, fields, ...| |—— global.json├── fr - 法语│ ├── foo.json - French translation of Foo name, fields, ...| |—— global.json

后台主要的CRUD操作代码在com.mytest.testjhipster.web.rest
包下,当然其中有许多库文件在背后支持。
补充:
src/main/resources/config/liquibase/changelog
这个目录下拥有生成实体表结构的xml文件。他们在src/main/resources/config/liquibase/master.xml
文件中被引用。
src/main/resources/config/
下的两个配置文件application-dev.yml
和application-prod.yml
与数据库的链接紧密相关。
src/main/webapp/scripts/components/navbar
下的navbar.html文件就是页面中顶端的导航栏。在其中更改导航栏的代码,就可以实现一些操作:添加一个导航项目。只需复制entities对应的li。
编辑一个导航项目。
更改导航项目中的每一个子菜单项的顺序。
...

6.添加一个实体后,框架为应用生成了那些代码
前端
首先,在src/main/webapp/scripts/components/navbar/navbar.html
文件中会在entities对应的菜单项中添加一个author菜单子项。1
其次,在src/main/webapp/scripts/app/entities
文件夹下会生成一个文件夹author
,这里面存放author实体CRUD操作对应的页面以及js页面。2
如果支持translate功能,那么在src/main/webapp/i18n
文件夹下的所有不同语种的文件夹(cn
和ZH
)下,会生成一个author.json文件,里面对应了翻译的译文。只需更改即可。在同样这两个文件夹下,global.json文件也会被插入一条语句:"author":"author"(label以及对应的译文)。1

ps1:如果不存在entitis菜单项,这个添加的这行内容,就可能会被添加到此文件代码的第一行,从而导致页面错乱,此时就需要自己去更改!。 2:如果不存在entities菜单项,这个实体文件夹中的所有js文件中可能会出现一个问题,所有的$uiModelInstace应该手动改为$modelInstance。这个是实战中发现的,原理有待学习AnjularJS再去总结。

后台
在com.mytest.testjhipster.repository
包中,会生成一个类文件AuthorRepository.java
,该借口继承JpaRepository
,封装CRUD的底层操作。
在com.mytest.testjhipster.web.rest
包中,会添加一个类AuthorResource.java
文件。其中是对该实体CRUD操作的后台代码,它调用了前面的AuthorRepository.java中的接口。
如果创建实体时,自己选择生成了service class的话,那么在com.mytest.testjhipster.service
包下,会生成对应这个实体的类文件,其中自己实现一些逻辑代码。逻辑代码的作用,有待进一步了解。

配置文件
src/main/resources/config/liquibase/changelog
目录下,将会生成该实体author对应建表的xml文件。
此外,在src/main/resources/config/liquibase/master.xml
文件中,会增加一条代码,对上面的xml文件进行引用,实现配置。1****ps:
1: 如果不存在entities,那么可能master.xml中生成的该条引用代码就会被添加到第一行,导致结构错误,程序报错

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352

推荐阅读更多精彩内容

  • jHipster - 微服务搭建 CC_简书[https://www.jianshu.com/u/be0d56c4...
    quanjj阅读 804评论 0 2
  • 原创性声明:本文完全为笔者原创,请尊重笔者劳动力。转载务必注明原文地址。 Jhipster初识# 本文基于自己根据...
    东方一号蓝阅读 16,599评论 8 35
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,649评论 18 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,039评论 25 707
  • 血对女人尤其珍贵。女人因周期性生理失血,而与血结下了不解之缘。伴随女人一生的经、孕、产、乳不同生理过程,都在失血耗...
    水瓶细语阅读 362评论 0 1