RESTful API Design and Development

10 Ratings

Course Number: PROG-102
Duration: 2 days (13 hours)
Format: Live, hands-on

RESTful API Design and Development Overview

This RESTful API Design and Development course teaches attendees the core concepts and practices for RESTful API design and development. 
The course focuses on the principles for designing a RESTful JSON API. Core concepts and best practices are covered for both development and consumption of a RESTful API. 

View our 5-Minute API Design tutorials.

Location and Pricing

Accelebrate offers instructor-led enterprise training for groups of 3 or more online or at your site. Most Accelebrate classes can be flexibly scheduled for your group, including delivery in half-day segments across a week or set of weeks. To receive a customized proposal and price quote for private corporate training on-site or online, please contact us.

In addition, some courses are available as live, instructor-led training from one of our partners.

Objectives

  • Consider web architecture as the basis of API strategies
  • Understand the REST architectural style and its motivations
  • Utilize the Richardson Maturity Model as a way to discuss design choices and induced properties
  • Implement security measures
  • Work with client technologies
  • Incorporate API management approaches
  • Implement testing strategies
  • Think about REST APIs vs. linked data, RPC models and GraphQL

Prerequisites

Other than object-oriented development or architecture experience, no prior expertise is presumed.

Outline

Expand All | Collapse All

Introduction
  • API Breakdown of Players
  • How did we get here?
    • Past
    • REST and JSON
Current state of API
  • API Strategies
    • REST
    • GraphQL & GRPC
  • OpenAPI
    • Tools
    • Definitions and Standards
    • Demos and Labs
API Design
  • General design concepts (separation of concern, error handling, API vs. RPC, etc.)
REST API Key Concepts
  • State
  • Nouns
  • Verbs Overview
Paths
  • GET
  • Design in OpenAPI
  • Verbs Details
  • Query String Parameters
Separation of Concerns
  • Gathering
  • Formatting
  • Delivery
  • Security and Scalability
  • Operation Responses
  • OpenAPI Schema
Error Definitions
  • Demo Server
    • Typicode
    • GitHub
Richardson Maturity Model
  • Levels 0-3
  • Hypermedia/HATEOAS
Components Section
  • Reuse
  • Response
Example APIs
API Development Standards
  • OpenAPI
  • Benefits
  • Maturity
  • Parameters
  • POST, PUT and PATCH
  • HEAD, OPTIONS and TRACE
OpenAPI Tools
  • Overview
  • Insomnia
  • Local Typicode Server
CRUD: Create
  • POST Create
  • Request Body Schema
  • Combining Schemas
  • Responses in Components
  • Array Schema Type
Server Variables
Path Parameters
  • Path
Parameters
  • Path, header and cookie
  • Required, default, min/max, enum
  • Path Level Reuse
  • Serialization
  • Styles and Explode
CRUD: Delete
Design First vs. Develop First
Automated Testing
  • Tools, Insomnia
  • Chai JS Assertion Library
Legacy API Considerations
  • Database
  • Endpoints
  • Functionality
API Versioning
  • URL vs. Header
Security
  • Documentation Options
  • Authentication vs. Authorization
  • JWT
  • Security Definitions in OpenAPI
    • Types
    • Flow
    • Fields
Pet Store API Review
Automated Testing Principles
  • Best Practices
  • Integration Testing
  • Insomnia CLI
  • GitHub Actions
Tutorials
  • Jetty Web API Servlet
  • C# .NET Server
  • Java Server using Spark
  • Python Server using Flask
Conclusion

Training Materials

All RESTful API Design and Development students will receive comprehensive courseware including slides, design exercises, and sample solutions.

Software Requirements

  • Google Chrome
  • Other modern browsers as desired
  • Other free software and lab files that Accelebrate would specify, including Node.js


Learn faster

Our live, instructor-led lectures are far more effective than pre-recorded classes

Satisfaction guarantee

If your team is not 100% satisfied with your training, we do what's necessary to make it right

Learn online from anywhere

Whether you are at home or in the office, we make learning interactive and engaging

Multiple Payment Options

We accept check, ACH/EFT, major credit cards, and most purchase orders



Recent Training Locations

Alabama

Birmingham

Huntsville

Montgomery

Alaska

Anchorage

Arizona

Phoenix

Tucson

Arkansas

Fayetteville

Little Rock

California

Los Angeles

Oakland

Orange County

Sacramento

San Diego

San Francisco

San Jose

Colorado

Boulder

Colorado Springs

Denver

Connecticut

Hartford

DC

Washington

Florida

Fort Lauderdale

Jacksonville

Miami

Orlando

Tampa

Georgia

Atlanta

Augusta

Savannah

Hawaii

Honolulu

Idaho

Boise

Illinois

Chicago

Indiana

Indianapolis

Iowa

Cedar Rapids

Des Moines

Kansas

Wichita

Kentucky

Lexington

Louisville

Louisiana

New Orleans

Maine

Portland

Maryland

Annapolis

Baltimore

Frederick

Hagerstown

Massachusetts

Boston

Cambridge

Springfield

Michigan

Ann Arbor

Detroit

Grand Rapids

Minnesota

Minneapolis

Saint Paul

Mississippi

Jackson

Missouri

Kansas City

St. Louis

Nebraska

Lincoln

Omaha

Nevada

Las Vegas

Reno

New Jersey

Princeton

New Mexico

Albuquerque

New York

Albany

Buffalo

New York City

White Plains

North Carolina

Charlotte

Durham

Raleigh

Ohio

Akron

Canton

Cincinnati

Cleveland

Columbus

Dayton

Oklahoma

Oklahoma City

Tulsa

Oregon

Portland

Pennsylvania

Philadelphia

Pittsburgh

Rhode Island

Providence

South Carolina

Charleston

Columbia

Greenville

Tennessee

Knoxville

Memphis

Nashville

Texas

Austin

Dallas

El Paso

Houston

San Antonio

Utah

Salt Lake City

Virginia

Alexandria

Arlington

Norfolk

Richmond

Washington

Seattle

Tacoma

West Virginia

Charleston

Wisconsin

Madison

Milwaukee

Alberta

Calgary

Edmonton

British Columbia

Vancouver

Manitoba

Winnipeg

Nova Scotia

Halifax

Ontario

Ottawa

Toronto

Quebec

Montreal

Puerto Rico

San Juan