JHipster 基础使用

认识JHipster

在这里插入图片描述

JHipster又称Java Hipster,是一个Java代码脚手架,hipster 的意思是时髦的 意思是最时髦的Java解决方案
他的主要核心是Spring Boot,还有Anaglar React 热门的前端框架,是Spring Boot开发的最佳实践,同时也支持Spring Cloud

JHipster 技术栈

前端

单页面程序

  • Angular 5 or React
  • Bootstrap响应式布局
  • HTML5 模板
  • 兼容ie11和现代游览器
  • 国际化支持
  • scss
  • 支持 Spring WebSocket

开发工具

  • 支持yarn 安装依赖
  • 支持webpack 开发
  • 支持JestProtractor 测试框架

同时也支持后端Thymeleaf渲染

后端

  • Spring Boot 简化配置
  • Maven or Gradle 构建工具, 测试并运行应用
  • spring profiles 开发环境和生产环境 (Maven and Gradle)
  • Spring Security 安全管理框架
  • Spring MVC REST + Jackson
  • 可选的 WebSocket 支持 with Spring Websocket
  • Spring Data JPA + Bean Validation
  • Liquibase 数据库版本管理
  • Elasticsearch 搜索引擎
  • MongoDB and Couchbase no-sql 数据库支持
  • Kafka 支持
  • 可选的微服务组件
  • ELK应用监测
  • ehcache hazelcast or Infinispan 缓存
  • logback 日志管理
  • HikariCP 连接池(号称最快的连接池)
  • docker 打包支持
  • 标准 war jar 打包支持
  • 主要的微服务提供AWS, Cloud Foundry, Heroku, Kubernetes, OpenShift, Docker…

安装JHipster

JHipster 依赖node 的Yeoman框架,所以安装之前必须安装nodejs
为什么Java的代码生成器要用nodejs写呢,我觉的可能是歪果仁嫌Java要写写的太多了,没有js脚本写的简洁

step 1: 安装yeoman

npm install -g yo

step 2:安装JHipster

npm install -g generator-jhipster

第一个JHipster 项目

step1:打开dos窗口

mkdir myapplication
cd myapplication/
yo jhipster

step2:根据你的需要选择你要的选项
输入完命令后悔出现一大堆的交互问答,如下

What is the base name of your application?(jhipster)
这个是问你项目是啥 输入项目名回车进行下一步

What is your default Java package name?(com.mycompany.myapp)
项目的包名

Which type of authentication would you like to use?(Use arrow keys)
上下箭头选择 根据你的业务详情选择合适的授权方案

Which type of database would you like to use?(Use arrow keys)
选择需要的数据库类型

Which production database would you like to use?(use arrow keys)
具体的数据库产品

which development database would you like to use?
开发是用什么数据库 h2保存在磁盘中不windows下有的问题

Do you want to use Hibernate 2nd level cache?
是否开启二级缓存

Do you want to use a search engine in your application?
是否需要搜索引擎

Do you want to use clustered HTTP sessions?
是否需要使用集群session

Do you want to use WebSocket?
是否需要使用websocket

Would you like to use Maven or Gradle for building the backend?
使用maven还是gradle构建项目

Would you like to use Grunt or Gulp.js for building the frontend?
是否使用glup来构建前端应用

Would you like to use the LibSass stylesheet preprocessor for your css?
是否使用LibSass作为css样式表处理器

Would you like to enable translation support with Angular Translate?
是否使用Anaglar的翻译支持

Which testing frameworks would you like to use?
选择测试框架

所有的问题都回答完就会自动生成项目,然后使用ide导入即可

命令行参数

  • –help - 答应生成器的options
  • –blueprint - 指定使用一种语言. For example jhipster --blueprint kotlin
  • –skip-cache - 不提示缓存在对话中会跳过 (Default: false)
  • –skip-git -不添加只git仓库 (Default: false)
  • –skip-install - 不自动下载依赖(Default: false)
  • –skip-client - 跳过前端代码生成, 只会有后端代码生成 (Default: false)
  • –skip-server - 通过后端代码生成(Default: false)
  • –skip-user-management - 前后台通过用户管理生成 (Default: false)
  • –i18n - 指定i18n的状态 (Default: true)
  • –auth - 当取消服务端时选择授权方式,当跳过服务端时不是必须的
  • –db - 指定数据库,当跳过服务端时不是必须的
  • –with-entities - 覆盖已经生成的实体 (使用 .jhipster 文件夹中的配置) (Default: false)
  • –skip-checks - 通过检查需要的工具 (Default: false)
  • –jhi-prefix - 在服务、组件和状态/路由名称之前添加前缀(Default: jhi)
  • –npm - Use NPM instead of Yarn (Default: false)
  • –experimental - 启用实验功能,这些功能是不稳定的可能随时崩溃

使用JHipster创建实体

当你创建了你的应用,你就会想去创建实体,比如你想创建一个Author 和 Book实体,对于每个实体,你需要以下步骤

  • 在数据库建立表
  • Liquibase 添加一条修改记录
  • 创建 JPA 实体
  • 创建 JPA Repository
  • 创建Spring MVC REST Controller 提供基础的CURD 操作
  • 创建Angular路由,一个组件和一个service
  • 创建一个HTMl页面
  • 集成测试取保各个方面都正常

上面的步骤很多,大部分也都是我们日常做的东西,现在使用JHipster可以自动帮我们生成这些代码

使用子生成器 entity 生成代码

entity 子生成器可以为每一个实体生成前后台的CRUD操作

使用姿势

jhipster entity <entityName> --[options]

options

  • –table-name <table_name> - JHipster默认会根据你的实体名去创建表, 如果你的表名和你的实体名不一样可以使用这个参数
  • –angular-suffix - 设置anaglar路由前缀
  • –regenerate - 无提示覆盖已经生成的实体
  • –skip-server - 跳过服务端代码生成
  • –skip-client - 跳过前端代码生成
  • –db - 指定数据库

JHipster UML and JDL Studio

上面的介绍了如何使用命令行创建实体,如果你需要重建大量实体,并且这些实体之间的关系错综复杂,这是你就需要一个图形化工具来操作

  • JHipster UML 使用uml编辑器生成
  • JDL Studio 在线生成工具 使用JHipster定义的domain-specific language JDL.

使用JDL Studio 生成实体

网站打不开的可以戳这里下载传送门 如果不想下载eclipse 和 vs code 的插件库中也有jhipster的插件,idea暂时没有

使用JDL Studio 导出会下载一个 xxx.jh 后缀的文件
然后就可以使用 import-jdl 子生成器生成代码

正确的打开方式

jhipster import-jdl your-jdl-file.jh --[options]

options

  • –json-only 不覆盖已经生成的实体,只在.jhipster 文件夹中生成json文件
  • –force 覆盖已经生成的实体

如果你想用JHipster UML代替 iimport-jdl 生成器 你需要 npm install -g jhipster-uml 然后运行 jhipster-uml yourFileName.jh

JDL介绍

JHipster Domain Language (JDL) 是一种特殊的领域模型语言,这种语言让你可以在一个或多个文件中用简单友好的语法去描述你的实体和实体之间的关系

当你有一个生成的项目或者已经存在的项目(跳过jhipster生成),你可以使用 import-jdl子生成器,通过运行在项目目录下运行 jhipster import-jdl your-jdl-file.jh生成实体,你也能通过 JHipster UML 生成实体并导出为JDL文件

定义实体

entity <entity name> {
  <field name> <type> [<validation>*]
}
  • 实体名
  • 字段名
  • 字段类型
  • 字段的检验

举个例子

entity A
entity B
entity C 空实体不用带{}

entity D {
  name String required,
  address String required maxlength(100),
  age Integer required min(18)
}

//使用正则表达式校验
entity A {
  myString String required minlength(1) maxlength(42) pattern(/[A-Z]+/)
}

JHipster 会默认加上id字段

实体关系定义

relationship (OneToMany | ManyToOne | OneToOne | ManyToMany) {
  <from entity>[{<relationship name>[(<display field>)]}] to <to entity>[{<relationship name>[(<display field>)]}]
}
  • (OneToMany | ManyToOne| OneToOne | ManyToMany)
  • 关系的出发点 source
  • 关系的目的地 target
  • 外键字段
  • 显示字段(default: id),
  • required 是否需要注入的字段

举个例子

entity Book
entity Author {
  name String required
}

relationship OneToMany {
  Author{book} to Book{writer(name) required}
}

entity A
entity B
entity C
entity D

relationship OneToOne {
  A{b} to B{a},
  B{c} to C
}
relationship ManyToMany {
  A{d} to D{a},
  C{d} to D{c}
}

entity A {
  name String required
}
entity B


relationship OneToOne {
  A{b} to B{a(name)}
}

枚举

在JDL中创建枚举

 enum Language {
    FRENCH, ENGLISH, SPANISH
  }

在实体中使用枚举作为字段类型

entity Book {
    title String required,
    description String,
    language Language
  }

二进制类型定义

JHipster 给出了三种二进制数据类型

  • AnyBlob or Blob 适用任何二进制类型
  • ImageBlob 图片类型
  • TextBlob 文本类型

定义操作

JDL可以定义实体的分页或DTO等操作
格式
<option> <ENTITIES | * | all> with <option>

可用的操作

  • dto (mapstruct)
  • service (serviceClass, serviceImpl)
  • paginate (pager, pagination, infinite-scroll)
  • search (elasticsearch)
  • microservice (custom value)
  • angularSuffix (custom value)

其他操作
<OPTION> <ENTITIES | * | all> except? <ENTITIES>

可用的操作

  • skipClient
  • skipServer
  • noFluentMethod
  • filter
entity A {
  name String required
}
entity B
entity C

dto A, B with mapstruct //生成dto

paginate A with infinite-scroll //无限滚动
paginate B with pagination 
paginate C with pager  // pager is only available in AngularJS

service A with serviceClass
service C with serviceImpl

service option

entity A
entity B
entity C

service B with serviceClass //不带service接口的
service C with serviceImpl  //带service接口的

使用 *all匹配所有, *all是等价的

entity A
entity B
...
entity Z

dto * with mapstruct except A
service all with serviceImpl except A, B, C
paginate C with pagination

skip option

entity A
entity B
entity C

skipClient for A
skipServer for B
angularSuffix * with mySuperEntities 路由前缀

entity option

entity A // A 默认是表名
entity B (table_name) // table_name指定表名

注释 & Javadoc

/**
 * Class comments.
 * @author The JHipster team.
 */
entity MyEntity { // another form of comment
  /** A required attribute */
  myField String required,
  mySecondField String // another form of comment
}

/**
 * Second entity.
 */
entity MySecondEntity {}

relationship OneToMany {
  /** This is possible too! */
  MyEntity{mySecondEntity}
  to
  /**
   * And this too!
   */
  MySecondEntity{myEntity}
}

Constants 常量

DEFAULT_MIN_LENGTH = 1
DEFAULT_MAX_LENGTH = 42
DEFAULT_MIN_BYTES = 20
DEFAULT_MAX_BYTES = 40
DEFAULT_MIN = 0
DEFAULT_MAX = 41

entity A {
  name String minlength(DEFAULT_MIN_LENGTH) maxlength(DEFAULT_MAX_LENGTH)
  content TextBlob minbytes(DEFAULT_MIN_BYTES) maxbytes(DEFAULT_MAX_BYTES)
  count Integer min(DEFAULT_MIN) max(DEFAULT_MAX)
}

各个数据库可用的数据类型

SQLMongoDBCassandraValidations
StringStringStringrequired, minlength, maxlength, pattern
IntegerIntegerIntegerrequired, min, max
LongLongLongrequired, min, max
BigDecimalBigDecimalBigDecimalrequired, min, max
FloatFloatFloatrequired, min, max
DoubleDoubleDoublerequired, min, max
EnumEnumrequired
BooleanBooleanBooleanrequired
LocalDateLocalDaterequired
Daterequired
ZonedDateTimeZonedDateTimerequired
UUIDrequired
BlobBlobrequired, minbytes, maxbytes
AnyBlobAnyBlobrequired, minbytes, maxbytes
ImageBlobImageBlobrequired, minbytes, maxbytes
TextBlobTextBlobrequired, minbytes, maxbytes
InstantInstantInstantrequired

创建Spring 控制器

语法

jhipster spring-controller Foo

回答命令行的问题选择需要的方法

创建Spring service

语法

jhipster spring-service Foo

查询懒加载需要加@Transactional注解

升级应用

当一个新的JHipster 版本出来是,你可以使用子生成器 upgrade 来升级你的应用
这样就可以使用JHipster的最新功能并且能修复一些bug

语法

cd myapp/
jhipster upgrade

options

  • –verbose 日志中打印升级详情
  • –target-version=4.2.0 升级至指定版本
  • –force 强制更新

最后推荐下我的个人博客 www.youngboy.vip

  • 6
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值