WMS - Operations¶
Background¶
- History
- WMS version 1.0.0 in April 2000, followed by version 1.1.0 in June 2001,and version 1.1.1 in January 2002. The OGC released WMS version 1.3.0 in January 2004. 
- Versions
- 1.3 is the current latest version 
- Test Suite
- Implementations
- Implementations can be found at the OGC database. here 
Usage¶
Through a highly configurable interface the WMS standard makes map images (but not source data) available in standard image formats. Government agencies publish all kinds of official map cartography using this standard. Other large organizations use this standard to enable independent departments to interact more easily internally. Anybody using this standard can use it to overlay map images from many different sources regardless of the underlying software.
WMS provides a standard interface for requesting a geospatial map image. The benefit of this is that WMS clients can request images from multiple WMS servers, and then combine them into a single view for the user. The standard guarantees that these images can all be overlaid on one another using a common geospatial coordinate reference system. Numerous servers and clients support WMS.
Relation to other OGC Standards¶
- OGC Web Map Tile Service Interface Standard (WMTS): The WMTS standard is a better fit For highly scalable systems (many simultaneous requests) that only need static maps. It complements the WMS standard with cachable static map tiles. WMS servers can be used as data sources or rendering engines for WMTS services. 
- OGC Web Feature Service (WFS): The WFS standard is a better fit for extended query functionality of spatial data. It provides programmatic access to the geographic feature data. WMS and WFS often go together. An organization publishing both WMS and WFS often use the same data source. 
- OGC Styled Layer Descriptor Interface Standard (SLD): The SLD standard allows the user to modify the cartographic appearance of a map image. It is an optional feature of the OGC WMS standard. 
- OGC Symbology Encoding (SE): The SE standard describes how to define map symbology. It is used to modify the cartographic appearance of map images. It is an optional feature of the OGC WMS and SLD standards. 
This section provides detailed information about the types of WMS requests a client is able to perform to a WMS server.
| Operation | Description | 
|---|---|
| 
 | Retrieves metadata about the service, including supported operations and parameters, and a list of the available layers. | 
| 
 | Retrieves a map image for a specified area and content. | 
| 
 | Retrieves the underlying data, including geometry and attribute values, for a pixel location on a map. | 
| 
 | Indicates the WFS or WCS to retrieve additional information about the layer. | 
| 
 | Retrieves a legend for a map. | 
GetCapabilities¶
Request¶
A WMS server responding to a GetCapabilities request returns metadata about the service, including supported operations and parameters, and a list of the available layers.
An example of a GetCapabilities request is:
https://ows.terrestris.de/osm/service?
REQUEST=GetCapabilities&
SERVICE=WMS&VERSION=1.3.0
This is a link to a GetCapabilities request.
There are three parameters (and values) being passed to the WMS server, SERVICE=WMS, VERSION=1.3, and REQUEST=GetCapabilities.
- The - SERVICEparameter tells the server that a WMS request is forthcoming.
- The - VERSIONparameter tells the server what version of the WMS is being requested.
- The - REQUESTparameter tells the server that the operation requested is the GetCapabilities operation.
The WMS standard requires that requests always includes these three parameters. The table bellow summarizes the parameters and values required to perform the request.
| Parameter | Required | Description | 
|---|---|---|
| 
 | Yes | Service name. Value is  | 
| 
 | Yes | Service version. Value is one of  | 
| 
 | Yes | Operation name. Value is  | 
Response¶
The response is a Capabilities XML document with a detailed description of the WMS service. It contains three main sections:
| Service | Contains service metadata such as the service name, keywords, and contact information for the organization operating the server. | 
|---|---|
| Request | Describes the operations the WMS service provides and the parameters and output formats for each operation. | 
| Layer | Lists the available coordinate systems and layers. In some servers (e.g. Geoserver) layers are named in the form “namespace:layer”. Each layer provides service metadata such as title, abstract and keywords. | 
GetCapabilities Layer Style Section¶
The GetCapabilites response contains a Layer section, which details about the style available to that layer. In the example bellow the available style is default.
<Layer queryable="0" opaque="0" cascaded="0">
  <Name>nationalparks</Name>
  <Title>National Parks</Title>
  <EX_GeographicBoundingBox>
    <westBoundLongitude>-4.43064</westBoundLongitude>
    <eastBoundLongitude>1.99728</eastBoundLongitude>
    <southBoundLatitude>50.3532</southBoundLatitude>
    <northBoundLatitude>55.5917</northBoundLatitude>
  </EX_GeographicBoundingBox>
  <BoundingBox CRS="EPSG:27700"
         minx="246828" miny="56378.4" maxx="652374" maxy="633117"/>
  <Style>
    <Name>default</Name>
    <Title>default</Title>
    <LegendURL width="110" height="22">
      <Format>image/png</Format>
      <OnlineResource xmlns:xlink="http://www.w3.org/1999/xlink"
         xlink:type="simple"
         xlink:href="..."/>
    </LegendURL>
  </Style>
</Layer>
GetMap¶
Request¶
A WMS server responding to a GetMap request returns a map image for a specified area and content.
The core parameters specify one or more layers and styles to appear on the map, a bounding box for the map extent, a target spatial reference system, and a width, height, and format for the output.
The information needed to specify values for parameters such as layers, styles and Spatial Reference Systems (SRS) can be obtained from the Capabilities document.
The response is a map image, or other map output artifact, depending on the format requested.
An example of a GetMap request is:
https://ows.terrestris.de/osm/service?
REQUEST=GetMap&
SERVICE=WMS&
VERSION=1.3.0&
LAYERS=OSM-WMS&
STYLES=&
CRS=EPSG:4326&
BBOX=51.49451,-0.11377,51.53267,-0.06971&
WIDTH=400&
HEIGHT=300&
FORMAT=image/png&
TRANSPARENT=TRUE
This is a link to a GetMap request.
The getMap request accesses a server offered by Terrestris. The request retrieves a map created from OpenStreetMap data
The coordinate reference system (CRS) is EPSG:4326, which is the World Geodetic System 1984 (WGS84) coordinate reference system. The image is returned in a PNG transparent format with width 400 and height 300 pixels.
The table bellow summarizes the available parameters and values.
| Parameter | Required? | Description | 
|---|---|---|
| 
 | Yes | Service name. Value is  | 
| 
 | Yes | Service version. Value is one of  | 
| 
 | Yes | Operation name. Value is  | 
| 
 | Yes | Layers to display on map. Value is a comma-separated list of layer names. | 
| 
 | Yes | Styles in which layers are to be rendered. Value is a comma-separated list of style names, or empty if default styling is required. Style names may be empty in the list, to use default layer styling. | 
| 
 | Yes | Spatial Reference System for map output.
Value is in form  | 
| 
 | Yes | Bounding box for map extent.
Value is  | 
| 
 | Yes | Width of map output, in pixels. | 
| 
 | Yes | Height of map output, in pixels. | 
| 
 | Yes | Format for the map output. | 
| 
 | No | Whether the map background should be transparent.
Values are  | 
| 
 | No | Background color for the map image.
Value is in the form  | 
| 
 | No | Format in which to report exceptions.
Default value is  | 
| 
 | No | Time value or range for map data. | 
| 
 | No | A URL referencing a StyledLayerDescriptor XML file which controls or enhances map layers and styling | 
| 
 | No | A URL-encoded StyledLayerDescriptor XML document which controls or enhances map layers and styling | 
Another WMS request examples is as follows:
http://localhost:8080/geoserver/wms?
request=GetMap
&service=WMS
&version=1.1.1
&layers=topp%3Astates
&styles=population
&srs=EPSG%3A4326
&bbox=-145.15104058007,21.731919794922,-57.154894212888,58.961058642578&
&width=780
&height=330
&format=image%2Fpng
The request specifies the topp:states layer to be output as a PNG map image in SRS EPGS:4326 and using default styling population.
A WMS request can also be sent via HTTP POST as an XML document, as follows:
<?xml version="1.0" encoding="UTF-8"?>
<ogc:GetMap xmlns:ogc="http://www.opengis.net/ows"
            xmlns:gml="http://www.opengis.net/gml"
   version="1.1.1" service="WMS">
   <StyledLayerDescriptor version="1.0.0">
      <NamedLayer>
        <Name>topp:states</Name>
        <NamedStyle><Name>population</Name></NamedStyle>
      </NamedLayer>
   </StyledLayerDescriptor>
   <BoundingBox srsName="http://www.opengis.net/gml/srs/epsg.xml#4326">
      <gml:coord><gml:X>-130</gml:X><gml:Y>24</gml:Y></gml:coord>
      <gml:coord><gml:X>-55</gml:X><gml:Y>50</gml:Y></gml:coord>
   </BoundingBox>
   <Output>
      <Format>image/png</Format>
      <Size><Width>550</Width><Height>250</Height></Size>
   </Output>
</ogc:GetMap>
Response¶
The response of a GetMap request is an image.
 
If the request is wrong the server will return an error message.
Time¶
The TIME parameter allows filtering a dataset by temporal slices as well as spatial tiles for rendering.
The TIME attribute for WMS GetMap requests is described in version 1.3 of the WMS specification.
Specifying a time¶
The format used for specifying a time in the WMS TIME parameter is based on ISO-8601. The precision might varied depending on the server.
The parameter is:
TIME=<timestring>
Times follow the general format:
yyyy-MM-ddThh:mm:ss.SSSZ
where:
- yyyy: 4-digit year
- MM: 2-digit month
- dd: 2-digit day
- hh: 2-digit hour
- mm: 2-digit minute
- ss: 2-digit second
- SSS: 3-digit millisecond
The day and intraday values are separated with a capital T, and the entire string is suffixed with a Z, indicating UTC for the time zone. (The WMS specification does not provide for other time zones.)
WMS Servers will apply the TIME value to all temporally enabled layers in the LAYERS parameter of the GetMap request.
Layers without a temporal component will be served normally, allowing clients to include reference information like political boundaries along with temporal data.
| Description | Time specification | 
|---|---|
| December 12, 2001 at 6:00 PM | 
 | 
| May 5, 1993 at 11:34 PM | 
 | 
Specifying an absolute interval¶
A client may request information over a continuous interval instead of a single instant by specifying a start and end time, separated by a / character.
In this scenario the start and end are inclusive; that is, samples from exactly the endpoints of the specified range will be included in the rendered tile.
| Description | Time specification | 
|---|---|
| The month of September 2002 | 
 | 
| The entire day of December 25, 2010 | 
 | 
Specifying a relative interval¶
A client may request information over a relative time interval instead of a set time range by specifying a start or end time with an associated duration, separated by a / character.
One end of the interval must be a time value, but the other may be a duration value as defined by the ISO 8601 standard.  The special keyword PRESENT may be used to specify a time relative to the present server time.
| Description | Time specification | 
|---|---|
| The month of September 2002 | 
 | 
| The entire day of December 25, 2010 | 
 | 
| The entire day preceding December 25, 2010 | 
 | 
| 36 hours preceding the current time | 
 | 
Reduced accuracy times¶
The WMS specification also allows time specifications to be truncated by omitting some of the time string. Usually servers will treat the time as a range whose length is equal to the most precise unit specified in the time string. For example, if the time specification omits all fields except year, it identifies a range one year long starting at the beginning of that year.
| Description | Reduced Accuracy Time | Equivalent Range | 
|---|---|---|
| The month of September 2002 | 
 | 
 | 
| The day of December 25, 2010 | 
 | 
 | 
Reduced accuracy times with ranges¶
Reduced accuracy times are also allowed when specifying ranges. The ranges are inclusive. Some servers (e.g GeoServer) effectively expands the start and end times as described above, and then includes any samples from after the beginning of the start interval and before the end of the end interval.
| Description | Reduced Accuracy Time | Equivalent Range | 
|---|---|---|
| The months of September through December 2002 | 2002-09/2002-12 | 2002-09-01T00:00:00.0Z/ 2002-12-31T23:59:59.999Z | 
| 12PM through 6PM, December 25, 2010 | 2010-12-25T12/ 2010-12-25T18 | 2010-12-25T12:00:00.0Z/ 2010-12-25T18:59:59.999Z | 
Specifying a list of times¶
Some Servers, such a GeoServer can also accept a list of discrete time values. This is useful for some applications such as animations, where one time is equal to one frame.
The elements of a list are separated by commas.
If the list is evenly spaced (for example, daily or hourly samples) then the list may be specified as a range, using a start time, end time, and period separated by slashes.
| Description | List notation | Equivalent range notation | 
|---|---|---|
| Noon every day for August 12-14, 2012 | TIME=2012-08-12T12:00:00.0Z, 2012-08-13T12:00:00.0Z, 2012-08-14T12:00:00.0Z | TIME=2012-08-12T12:00:00.0Z/ 2012-08-18:T12:00:00.0Z/ P1D | 
| Midnight on the first of September, October, and November 1999 | TIME=1999-09-01T00:00:00.0Z, 1999-10-01T00:00:00.0Z, 1999-11-01T00:00:00.0Z | TIME=1999-09-01T00:00:00.0Z/ 1999-11-01T00:00:00.0Z/ P1M | 
Specifying a periodicity¶
The periodicity is also specified in ISO-8601 format: a capital P followed by one or more interval lengths, each consisting of a number and a letter identifying a time unit:
| Unit | Abbreviation | 
|---|---|
| Years | 
 | 
| Months | 
 | 
| Days | 
 | 
| Hours | 
 | 
| Minutes | 
 | 
| Seconds | 
 | 
The Year/Month/Day group of values must be separated from the Hours/Minutes/Seconds group by a T character. The T itself may be omitted if hours, minutes, and seconds are all omitted. Additionally, fields which contain a 0 may be omitted entirely.
Fractional values are permitted, but only for the most specific value that is included.
The period must divide evenly into the interval defined by the start/end times. So if the start/end times denote 12 hours, a period of 1 hour would be allowed, but a period of 5 hours would not.
For example, the multiple representations listed below are all equivalent.
- One hour: P0Y0M0DT1H0M0S, PT1H0M0S or PT1H 
- 90 minutes: P0Y0M0DT1H30M0S, PT1H30M or P90M 
- 18 months: P1Y6M0DT0H0M0S, P1Y6M0D, P0Y18M0DT0H0M0S or P18M 
GetFeatureInfo¶
Request¶
A WMS server responding to a GetFeatureInfo request returns the underlying data, including geometry and attribute values, for a pixel location on a map.
It is similar to the WFS GetFeature operation, but less flexible in both input and output.
The one advantage of GetFeatureInfo is that the request uses an (x,y) pixel value from a returned WMS image.
This is easier to use for a naive client that is not able to perform true geographic referencing.
The standard parameters for the GetFeatureInfo operation are:
| Parameter | Required | Description | 
|---|---|---|
| 
 | Yes | Service name. Value is  | 
| 
 | Yes | Service version. Value is one of  | 
| 
 | Yes | Operation name. Value is  | 
| 
 | Yes | Comma separated list of layers to be queried` | 
| 
 | No | Format for the feature information response (MIME type). | 
| 
 | No | Maximum number of features to return. Default is 1. | 
| 
 | Yes | Pixel column point on the map. 0 is left side.
 | 
| 
 | Yes | Pixel row on the map. 0 is the top.
 | 
| 
 | No | Format in which to report exceptions.
The default value is  | 
Example formats are as follows:
| Format | Syntax | Notes | 
|---|---|---|
| TEXT | 
 | Simple text output. (The default format) | 
| GML 2 | 
 | Works only for Simple Features | 
| GML 3 | 
 | Works for both Simple and Complex Features | 
| HTML | 
 | Uses HTML templates that are defined on the server. | 
| JSON | 
 | Simple JSON representation. | 
An example request for feature information from the topp:states layer in HTML format is:
http://localhost:8080/geoserver/wms?
request=GetFeatureInfo
&service=WMS
&version=1.1.1
&layers=topp%3Astates
&styles=
&srs=EPSG%3A4326
&format=image%2Fpng
&bbox=-145.151041%2C21.73192%2C-57.154894%2C58.961059
&width=780
&height=330
&query_layers=topp%3Astates
&info_format=text%2Fhtml
&feature_count=50
&x=353
&y=145
&exceptions=application%2Fvnd.ogc.se_xml
An example request for feature information in GeoJSON format is:
http://localhost:8080/geoserver/wms?
&INFO_FORMAT=application/json
&REQUEST=GetFeatureInfo
&EXCEPTIONS=application/vnd.ogc.se_xml
&SERVICE=WMS
&VERSION=1.1.1
&WIDTH=970&HEIGHT=485&X=486&Y=165&BBOX=-180,-90,180,90
&LAYERS=COUNTRYPROFILES:grp_administrative_map
&QUERY_LAYERS=COUNTRYPROFILES:grp_administrative_map
&TYPENAME=COUNTRYPROFILES:grp_administrative_map
The result will be:
{
"type":"FeatureCollection",
"features":[
   {
      "type":"Feature",
      "id":"dt_gaul_geom.fid-138e3070879",
      "geometry":{
         "type":"MultiPolygon",
         "coordinates":[
            [
               [
                  [
                     XXXXXXXXXX,
                     XXXXXXXXXX
                  ],
                  ...
                  [
                     XXXXXXXXXX,
                     XXXXXXXXXX
                  ]
               ]
            ]
         ]
      },
      "geometry_name":"at_geom",
      "properties":{
         "bk_gaul":X,
         "at_admlevel":0,
         "at_iso3":"XXX",
         "ia_name":"XXXX",
         "at_gaul_l0":X,
         "bbox":[
            XXXX,
            XXXX,
            XXXX,
            XXXX
         ]
      }
   }
],
"crs":{
   "type":"EPSG",
   "properties":{
      "code":"4326"
   }
},
"bbox":[
   XXXX,
   XXXX,
   XXXX,
   XXXX
]
}
Exceptions¶
When a request from a client to a WMS Server is not performed properly, a Server needs to report an exception. Formats in which a WMS Server can report exceptions are shown in the table bellow.
| Format | Syntax | Notes | 
|---|---|---|
| XML | 
 | The error is described in XML. | 
| PNG | 
 | The error is return as an image. | 
| Blank | 
 | A blank image is returned. | 
| JSON | 
 | The error is reported as a simple JSON representation. |