Chapter 2. Building RESTful Web Services with Maven and Gradle

As mentioned in the previous chapter, we will build a sample property management system as a RESTful web service. Before we dig into the implementation, let's first take a look at how the service will be put together. In this chapter, we will discuss the following topics:

  • Building a RESTful web service with Apache Maven
  • Building a RESTful web service with Gradle
  • Structuring our property management web service
  • Running and debugging a Spring-based web service

Apache Maven

Maven is an open-source software project management tool. It was born out of the need to simplify Ant-based builds and it favors convention over configuration. In more concrete terms, it offers out of the box support for typical workflows, such as building Java web applications, provided one follows its conventions. However, customizing the build process can prove challenging, and many of its detractors point this design choice out as the main motivation for not using Maven.

Note

More information on Maven can be found at https://maven.apache.org.

While Maven offers many features, they are beyond the scope of this chapter. We will focus on its support for building Java web applications.

The following POM (Project Object Model) file illustrates how a project can be declared with Maven (in a file called pom.xml):

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.packtpub.rest-with-spring</groupId>
    <artifactId>rest-with-spring</artifactId>
    <version>1.0.0-SNAPSHOT</version>
    <packaging>war</packaging>

</project>

This pom.xml file defines a project with a group identifier, artifact identifier, and version. It also describes how the resulting application will be packaged (as a WAR file in this case).

Tip

Maven artifacts belong to a group (typically com.company.application), and must have a unique identifier (typically the application's name).

Developers are free to choose their versioning schemes. However, Maven works best with a version of the form x.y, where x is the major version number and y the minor version number.

Note

The SNAPSHOT version suffix tells Maven that this project is currently in development. It has implications for the way artifacts are handled by the dependency resolution, as explained in the following section.

Dependency management in Apache Maven

One build feature that makes development much easier is dependency management. It alleviates the need to manually download third-party libraries and package them with the application. Maven has robust dependency management based on artifact repositories.

Tip

The main repository for Maven is called the Central Repository and can be searched on at http://maven.org.

To declare dependencies, the sample POM file that was presented in the previous section can be amended in the following fashion:

// content omitted for readability purposes
    <version>1.0.0-SNAPSHOT</version>
    <packaging>war</packaging>
    <dependencies>
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-core</artifactId>
            <version>4.1.9.Final</version>
        </dependency>
        <!-- Test Dependencies -->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.11</version>
            <scope>test</scope>
        </dependency>
    </dependencies>
</project>

The <dependencies> element in the amended POM file declares two dependencies:

  • Hibernate: This is a standard dependency that Maven will automatically fetch before compiling the project
  • JUnit: With this dependency, Maven will alter the classpath used to compile and execute the unit tests

Another build tool that has gathered a lot of popularity is Gradle and it is discussed in the next section

..................Content has been hidden....................

You can't read the all page of ebook, please click here login for view all page.
Reset
18.227.111.208