LearningPatterns: Your Global Source for Java Training, Mentoring, and Consulting
Home | About LearningPatterns | Our Services | Contact Us | Printer Friendly Link

Course Description:

Developing RESTful Services with REST/JAX-RS Courseware for License

This course provides in-depth coverage of REST principles and building RESTful services using the JAX-RS 2.0 API. It includes a brief overview of SOAP-based services and WSDL, to provide a contrast to RESTful services.

To really understand REST, we need to remind (teach) students about the full capabilities of HTTP, since RESTful service design is centered on the innate principles and capabilities of the HTTP protocol. Stated differently, RESTful services should use HTTP the way it was originally intended, not just as GET/POST plumbing for request/response data. You will emerge from the course with a full understanding of the HTTP protocol and its vision of the "original web," and how these ideas are implemented in RESTful applications.

We'll show you how to handle the most common types of request input, culminating in the transmission of HTTP entities in both XML and JSON format, in line with the original intention of HTTP. You'll also learn how to create appropriate responses given a variety of inputs and conditions, according to the guidelines and principles in the HTTP standard.

On the client side, we look at Ajax-JavaScript clients, as well as standalone Java clients using the JAX-RS 2.0 Client API.

Your daily personal use of the web is increasingly RESTful, and this course will show you how to expose your backend business systems using REST and the innate API and capabilities of HTTP. We also take cues from the masters such as Google, examining some of their public services and using them as a backdrop in building our own.

The course is very hands-on with frequent labs, in which the student can see these ideas implemented in software.

Attendees must be experienced in Java and preferably familiar with XML, Java web applications, and other Java EE standards. Familiarity with Ajax, JavaScript, and JSON is also beneficial, but not required.

All labs are done with the Eclipse IDE Java EE version and the WildFly Application Server, and the lab instructions include detailed directions for using them. Other IDEs and servers available on request.

Course Information

Duration: 3 days

Hands-on: Minimum 50% hands-on labs

Supported Platforms: Eclipse IDE and WildFly Application Server, other IDEs and servers available on request.

Skills Gained:

Course Details:

Session 1: Web Services Overview
  • Definition
    • Legacy Systems
    • Benefits of Web Services
    • Architecture
  • Standards and Portability
    • XML and Related Standards
    • JSON
    • HTTP
  • SOAP-Based Services
    • Overview
    • SOAP Messages, Requests, and Responses
    • WSDL
    • Java APIs and Programming Models
Session 2: Introduction to REST
  • Overview and Principles
    • REST Characteristics
    • Resources and Operations
    • REST Principles
  • Requests and Responses
    • REST APIs
    • URI Templates
    • GET, POST, PUT, DELETE
    • Safe and Idempotent Methods
  • Comparison of REST and SOAP
Session 3: Introduction to JAX-RS
  • APIs and Implementations
    • JAX-RS Overview, Annotations
    • JAX-RS Implementations
  • Runtime Environment
    • Application Server, Servlet-Only Container
    • Architectural and Implementation Perspectives
    • Configuring the Application
  • Applications, Resources, and Providers
    • JAX-RS Applications
    • Resource Classes and @Path
    • Provider Classes and @Provider
    • Default Lifecycles
    • The Application Class and rest-path
  • Ajax-JavaScript Clients
    • Overview
    • Classic vs. Ajax Interactions
    • Working with Ajax-JavaScript
Session 4: Resources and Requests
  • Resources and Subresources
    • Root Resource Classes, Resource Methods, Subresource Methods
    • @GET, @POST, @PUT, @DELETE
    • Subresource Locators
    • Naming Conventions and Rules
    • Dispatching Requests to Methods
  • Binding Request Data
    • Request Data Injection and Conversion
    • Default Values
    • Fields vs. Method Parameters
  • Context-Based Injection
    • Injection via @Context
    • Context-Injectable Types
    • Context Injection from the Web Container
    • Fields vs. Method Parameters
Session 5: HTTP Entities
  • Complex Content and Entities
    • Working with Complex Content
    • @Consumes and @Produces
    • Content Negotiation
    • Standard Entity Providers
  • Working with JSON
    • Returning Data as JSON
    • Working with JSON in JavaScript
    • Processing JSON Responses
  • Working with XML
    • JAXB and Mapping to XML
    • Returning Data as XML
    • Working with XML on the Client
    • Customizing Content, Custom Media Types
    • Working with Collections
  • XML vs. JSON
Session 6: Responses
  • Response Class
    • Return Types and HTTP Response Codes
    • Appropriate Responses for HTTP Methods
    • Choosing the Right Response
  • Error Handling
    • Exception Mappers
    • WebApplicationException
    • Response vs. Thrown Exception
    • Error Responses
  • Subresource Locators
    • Motivation and Uses
    • Locating the Locator
    • Initializing the Subresource
  • Binary Content
    • File, InputStream, StreamingOutput
    • Using StreamingOutput
Session 7: Java Client API
  • Java Client - Options and Ingredients
  • Building and Sending the Request
  • Consuming the Response
  • Options for the Response Data
  • Asynchronous Requests
Session 8: Integration with Java EE
  • Integration with EJB
  • CDI - Contexts and Dependency Injection
    • Activation, Scopes, and JAX-RS Lifecycles
    • Injection in CDI-Enabled JAX-RS Applications
    • Enhanced Java EE Lifecycle
Session 9: Security
  • Java EE Security Overview
    • Security Requirements in JAX-RS
    • Declarative, Role-Based Security
    • Security Constraints
    • Annotation-Based Security
  • Authentication
    • Configuration
    • Authentication Models: Basic, Digest, Client-Cert
  • Programmatic Security
    • SecurityContext
    • Client Security
  • HTTPS
LearningPatterns Inc. | http://www.LearningPatterns.com | tel:212.487.9064 | e-mail:
Copyright © 2009 LearningPatterns Inc. All rights reserved. LearningPatterns is a trademark of LearningPatterns Inc. Java, and all Java-based trademarks are registered trademarks of Sun Microsystems in the U.S. and other countries. JBoss is a registered trademark of Red Hat, Inc. in the U.S. and other countries. IBM and Rational are registered trademarks of IBM Corp. in the U.S. and other countries. All other products and company names mentioned here may be trademarks of their respective owners.