Project Name | Stars | Downloads | Repos Using This | Packages Using This | Most Recent Commit | Total Releases | Latest Release | Open Issues | License | Language |
---|---|---|---|---|---|---|---|---|---|---|
Spring Boot Api Project Seed | 9,214 | 6 months ago | 112 | Java | ||||||
:seedling::rocket:一个基于Spring Boot & MyBatis的种子项目,用于快速构建中小型API、RESTful API项目~ | ||||||||||
Spring Boot Projects | 4,551 | 3 months ago | 2 | apache-2.0 | Java | |||||
:fire: 该仓库中主要是 Spring Boot 的入门学习教程以及一些常用的 Spring Boot 实战项目教程,包括 Spring Boot 使用的各种示例代码,同时也包括一些实战项目的项目源码和效果展示,实战项目包括基本的 web 开发以及目前大家普遍使用的线上博客项目/企业大型商城系统/前后端分离实践项目等,摆脱各种 hello world 入门案例的束缚,真正的掌握 Spring Boot 开发。 | ||||||||||
Spring Cloud Rest Tcc | 2,474 | 3 years ago | Java | |||||||
以Spring Cloud Netflix作为服务治理基础, 展示基于tcc思想所实现的分布式事务解决方案 | ||||||||||
White Jotter | 2,144 | 6 months ago | 20 | mit | Java | |||||
白卷是一款使用 Vue+Spring Boot 开发的前后端分离项目,附带全套开发教程。(A simple CMS developed by Spring Boot and Vue.js with development tutorials) | ||||||||||
Xbin Store | 2,116 | 2 years ago | 20 | gpl-3.0 | Java | |||||
模仿国内知名B2C网站,实现的一个分布式B2C商城 使用Spring Boot 自动配置 Dubbox / MVC / MyBatis / Druid / Solr / Redis 等。使用Spring Cloud版本请查看 | ||||||||||
Spring Boot Leaning | 2,068 | 8 months ago | 1 | Java | ||||||
Spring Boot 2.X 最全课程代码 | ||||||||||
X Springboot | 1,731 | a month ago | 1 | Java | ||||||
X-SpringBoot是一个轻量级的Java快速开发平台,能快速开发项目并交付【接私活利器】 | ||||||||||
Quarkus Quickstarts | 1,719 | 3 days ago | 155 | apache-2.0 | Java | |||||
Quarkus quickstart code | ||||||||||
Spring Boot Shiro | 1,496 | 2 years ago | 3 | Java | ||||||
Shiro基于SpringBoot +JWT搭建简单的restful服务 | ||||||||||
Spring Microservices | 1,369 | a year ago | 7 | mit | Java | |||||
Microservices using Spring Boot, Spring Cloud, Docker and Kubernetes |
This backend version of the Spring Petclinic application only provides a REST API. There is no UI. The spring-petclinic-angular project is a Angular front-end application which consumes the REST API.
See the presentation of the Spring Petclinic Framework version
git clone https://github.com/spring-petclinic/spring-petclinic-rest.git
cd spring-petclinic-rest
./mvnw spring-boot:run
docker run -p 9966:9966 springcommunity/spring-petclinic-rest
You can then access petclinic here: http://localhost:9966/petclinic/
There are actuator health check and info routes as well:
You can reach the swagger UI with this URL http://localhost:9966/petclinic/.
You then can get the Open API description reaching this URL localhost:9966/petclinic/v3/api-docs.
Our issue tracker is available here: https://github.com/spring-petclinic/spring-petclinic-rest/issues
In its default configuration, Petclinic uses an in-memory database (HSQLDB) which gets populated at startup with data. A similar setups is provided for MySql and PostgreSQL in case a persistent database configuration is needed. To run petclinic locally using persistent database, it is needed to change profile defined in application.properties file.
For MySQL database, it is needed to change param "hsqldb" to "mysql" in string
spring.profiles.active=hsqldb,spring-data-jpa
defined in application.properties file.
Before do this, would be good to check properties defined in application-mysql.properties file.
spring.datasource.url = jdbc:mysql://localhost:3306/petclinic?useUnicode=true
spring.datasource.username=pc
spring.datasource.password=petclinic
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.jpa.database=MYSQL
spring.jpa.database-platform=org.hibernate.dialect.MySQLDialect
spring.jpa.hibernate.ddl-auto=none
You may also start a MySql database with docker:
docker run --name mysql-petclinic -e MYSQL_ROOT_PASSWORD=petclinic -e MYSQL_DATABASE=petclinic -p 3306:3306 mysql:5.7.8
For PostgeSQL database, it is needed to change param "hsqldb" to "postgresql" in string
spring.profiles.active=hsqldb,spring-data-jpa
defined in application.properties file.
Before do this, would be good to check properties defined in application-postgresql.properties file.
spring.datasource.url=jdbc:postgresql://localhost:5432/petclinic
spring.datasource.username=postgres
spring.datasource.password=petclinic
spring.datasource.driver-class-name=org.postgresql.Driver
spring.jpa.database=POSTGRESQL
spring.jpa.database-platform=org.hibernate.dialect.PostgreSQLDialect
spring.jpa.hibernate.ddl-auto=none
You may also start a Postgres database with docker:
docker run --name postgres-petclinic -e POSTGRES_PASSWORD=petclinic -e POSTGRES_DB=petclinic -p 5432:5432 -d postgres:9.6.0
This API is built following some API First approach principles.
It is specified through the OpenAPI. It is specified in this file.
Some of the required classes are generated during the build time. Here are the generated file types:
To see how to get them generated you can read the next chapter.
Some of the required classes are generated during the build time using maven or any IDE (e.g., IntelliJ Idea or Eclipse).
All of these classes are generated into the target/generated-sources
folder.
Here is a list of the generated packages and the corresponding tooling:
Package name | Tool |
---|---|
org.springframework.samples.petclinic.mapper | MapStruct |
org.springframework.samples.petclinic.rest.dto | OpenAPI Generator maven plugin |
To get both, you have to run the following command:
mvn clean install
In its default configuration, Petclinic doesn't have authentication and authorization enabled.
In order to use the basic authentication functionality, turn in on from the application.properties file
petclinic.security.enable=true
This will secure all APIs and in order to access them, basic authentication is required. Apart from authentication, APIs also require authorization. This is done via roles that a user can have. The existing roles are listed below with the corresponding permissions
There is an existing user with the username admin
and password admin
that has access to all APIs.
In order to add a new user, please use the following API:
POST /api/users
{
"username": "secondAdmin",
"password": "password",
"enabled": true,
"roles": [
{ "name" : "OWNER_ADMIN" }
]
}
The following items should be installed in your system:
Note: when m2e is available, there is an m2 icon in Help -> About dialog. If m2e is not there, just follow the install process here: http://eclipse.org/m2e/download/
git clone https://github.com/spring-petclinic/spring-petclinic-rest.git
File -> Import -> Maven -> Existing Maven project
Layer | Source |
---|---|
REST API controllers | REST folder |
Service | ClinicServiceImpl.java |
JDBC | jdbc folder |
JPA | jpa folder |
Spring Data JPA | springdatajpa folder |
Tests | AbstractClinicServiceTests.java |
This application uses Google Jib to build an optimized Docker image
into the Docker Hub
repository.
The pom.xml has been configured to publish the image with a the springcommunity/spring-petclinic-rest
image name.
Command line to run:
mvn compile jib:build -X -DjibSerialize=true -Djib.to.auth.username=xxx -Djib.to.auth.password=xxxxx
The Spring Petclinic master branch in the main spring-projects GitHub org is the "canonical" implementation, currently based on Spring Boot and Thymeleaf.
This spring-petclinic-rest project is one of the several forks hosted in a special GitHub org: spring-petclinic. If you have a special interest in a different technology stack that could be used to implement the Pet Clinic then please join the community there.
The issue tracker is the preferred channel for bug reports, features requests and submitting pull requests.
For pull requests, editor preferences are available in the editor config for easy use in common text editors. Read more and download plugins at http://editorconfig.org.