In this document, the authors have a number of goals:
Re-introduce the idea of a web service, and cover the relevant terminology
Explain the roles of the requestor (the client) and the responder (the server
Discuss how a client uses an HTTP client object (e.g. XmlHttpRequest, or the fetch API) to contact a server, and handle (typically) JSON data responses
Promote the idea that we are building and working with a distributed computing system, that has two or more autonomous programs that pass messages (requests, responses) among the programs
At this point in time, please review and study the week 9 notes from the previous BTI325 course, so that you are in a position to build upon that knowledge and experience.
A web service is an application that runs on a web server, and is accessed programmatically.
When we parse this short sentence, and consider the meanings behind the simple words, we reveal some very important concepts:
Web services can be developed on any web-connected technology platform, in any language, and can be used on any kind of device.
Study this diagram to understand the differences, and then be prepared to explain them to someone else:
With the rise of the web’s use and popularity in the 1990s, efforts were made to define and specify web services.
This led to the de facto standardization of SOAP XML web services. Often described as “big web services”, or “legacy web services”, SOAP XML web services are the implementation of remote procedure calls on the web. This kind of web service typically has one specific endpoint address, and requestors must create and send a data package (which conforms to a data format named SOAP), and then process the response (which also conforms to SOAP).
However, other efforts took advantage of the web and its existing features and benefits. In other words, they simply followed the HTTP specification and its ex post facto architecture definition, to create true and pure web services. These kinds of web services, often termed “Web API”, “RESTful web services”, or “HTTP services”, exploded in use and popularity from about 2005 onwards, and are now the preferred design approach.
Web services are vital for modern software architectures.
For all device platforms.
The course notes and your professor will guide you. However, you must learn (more) about HTTP.
In class, we will discuss some HTTP topics, recall your BTI325 experience, refer to the overview on Wikipedia, and the official specification series, RFC 7230 to RFC 7235, which replaced RFC 2616 in June 2014.
In the previous web programming course, you got started with this task in the Week 9 coverage (Ajax Review / Practical Ajax Programming).
In addition, you used an easily-accessed public web service, reqres.in.
Let’s step back for a moment, and identify the topics that a web service programmer needs to cover and acquire:
Returning to the knowledge and skills that you gained in the previous web programming course, you can map to the list above:
Web services development and deployment environment
You will continue to use the frameworks and tools from the previous web programming course:
Each web service that you create will be treated as a separate and distinct program, and not bundled in with the front end client (browser) app that you may be working on. It will be concerned only with listening then responding to requests that come in.
During development, you will use an HTTP inspector app, like Postman, to create and send requests to a web service.
Then, you will be creating separate web app clients, which send requests to your web service.
Each program can be individually and separately deployed to any device platform that meets your needs.
As your web programming competency grows, it is important to know and be able to correctly use some common web programming terms.
Web app, and web service
If you create a server-based program, and it is intended to be used mostly by web browsers, we typically call that a web app.
A resource is a digital asset.
Familiar examples include a document, or an image.
What is the format, or representation, of the resource? Well, it depends on the design of the web service, and sometimes the needs of the requestor.
As defined above, a resource is a digital asset.
A representation is a digital asset that is formatted as a specific internet media type.
The concrete or real form of a representation “is a sequence of bytes, plus … metadata to describe those bytes”.
From Roy Fielding, “Architectural Styles and the Design of Network-based Software Architectures”, section 184.108.40.206
Think about a scenario where a web service was used to manage students in a course. Each student is a resource - a digital asset - that can be identified by a URI.
If a user requested a specific resource through a web browser, you would expect that the resource would be represented by some HTML that included the student’s name, student ID, and so on.
Alternatively, it’s also possible to request the same specific resource - using the same URI - but also specify that it be returned in a data format (like JSON or XML, discussed later). The server will return a data representation of the resource.
Or, maybe the request specified that the student’s photo be returned as the resource’s representation. Again, the same URI is used.
So, in summary, a resource’s representation can vary to meet the needs of the web service programmer or the web service user. The requestor and responder use a feature called content negotiation to make this happen.
Every representation is defined by an internet media type.
Internet media type
An internet media type is defined as a data format for a representation of a resource on the internet.
The data formats are standardized, published, and well-known, by the IANA (the Internet Assigned Numbers Authority).
This Wikipedia article is an acceptable introduction to internet media types.
Both are plain-text data formats. They are somewhat human-readable.
Later, you will probably learn how to work with non-text media types. From now on, we will typically work with plain-text JSON.
Get started with JSON
Here’s an overview of JSON from Wikipedia.
Here’s the official web site for JSON, by Douglas Crockford.
While we’re on the topic of data types, the property values will be any of about five types:
String values must be surrounded by quotes.
The web services that you create in this course will rely on the JSON internet media type.
Let’s discuss state in this section of the notes, and in the next section.
In this section, we are interested in the state of the data elements in a distributed system. (In the next section, we will be interested in the state of the interaction among programs in a distributed system.)
In a web app or web service context, the meaning of the word state is the current value of a resource.
At the server, a resource could be in the form of an item in a persistent store (i.e. a database system), or it could be in the form of an item that is generated upon request. That difference doesn’t matter; what matters is that when a resource is requested, its current state is sent, or transferred, as the response.
A resource’s state can be changed (or modified), of course. The stimulus for the change can originate from anywhere in the distributed system, ranging from server-based batch or automatic processes that modify the persistent store (apart from or separately from the web app or web service), through to client-sent requests that are received by a web app or web service.
Does this work the other way, when a client app changes the state of an resource?
A client can send a request that includes a representation of a resource. (For example, an HTTP POST or PUT request.)
The new or updated state of the resource is transferred, from the client app to the server (web app or web service).
Upon acceptance (and validation etc.), the server appends to or updates the resource in the persistent store.
In this section, we are interested in the state of the interaction among programs in a distributed system. (In the previous section, we were interested in the state of the data elements in a distributed system.)
One of the characteristics of a web app or web service is that it can be used by a single client app, or by theoretically unlimited numbers of client apps.
Does the server keep track of the interaction state with each client? No. This responsibility is borne by the client app. This design feature is one of most important parts of the web.
“Each request from client to server must contain all of the information necessary to understand the request, and cannot take advantage of any stored context on the server. Session state is kept entirely on the client.” (Roy Fielding, PhD thesis, section 3.4.3)
The main point is that the server effectively treats every request as separate/discrete/atomic, and does not actively maintain any notion of a logical session over time. In other words, no interaction state maintenance or management is done at the server.
Therefore, if the interaction state of a (message exchange) session is important to maintain, it’s done by the client.
Now we can circle back to REST. It is an acronym for REpresentational State Transfer.
In the week 9 notes of the previous course, you were introduced to the term “REST API”, where it was explained “as a way to use the HTTP protocol with a standard message format to perform operations on data”.
While that explanation is clear and understandable for a web programming student, it embeds a much deeper understanding that can come only through more learning and experience. If a student is serious about a career that includes web programming, then it is essential to study Roy Fielding’s PhD dissertation from the year 2000, Architectural Styles and the Design of Network-based Software Architectures.
More information about Roy Fielding is here.
Will we be creating “REST APIs”? Yes, if we follow all the guidance and practices. However, that will come only with more knowledge and experience. (The School of ICT offers a web services pro option course that equips the student with most of what’s needed to create a true REST API.)
As a result, it may be more accurate and safer to use the term “web API” when naming or describing our web service work.
The term “web API” captures the essence of “REST API” above, but it uses a more generic and easier to understand or explain word. Arguably, every computer user has a reasonably accurate knowledge of the word “web”, so that word doesn’t have to be explained. The expansion of the “API” initialism is also easy to understand or explain. It’s just a bit better (and safer) than using “REST”, and avoids the immediate need to cover large chunks of a 180-page PhD dissertation.
So, let’s define “web API” as an API to a web app or web service.
In this document, we have defined and explained a web service.
We have been reminded of our brief introduction to web service programming in the previous BTI325 course.
Terminology was introduced, argued, and explained.
Now, you’re ready to take the next step, and create web services that support the main focus of this BTI425 course, which is front end client-side browser apps.