To get started with DICOMweb, there are a few key concepts to understand.
- An imaging structure consists of a Patient (typically corresponds to a single "person"), a Study (typically corresponds to a single "diagnostic order"), a Series (typically corresponds to a single "imaging event" within a study, for example, multiple views, or with/without contrast), and an Instance (typically corresponds to a single image).
- First, you must QUERY for studies and their underlying structure, using the QIDO-RS feature of DICOMweb.
- Then, you can RETRIEVE individual instances for rendering, using the WADO-RS feature of DICOMweb.
- If desired, you can STORE individual instances, using the STOW-RS feature of DICOMweb.
- SIIM Hackathon API key
- (Optional) Postman
When making requests against the end points below, ensure you include an HTTP header like so:
apikey: [your API key]
If you don't have a SIIM Hackathon API key, see Hackathon Server.
A simple Hello World type query for DICOMweb, would look as follows, to query for all studies for all patients with the last name of SIIM:
https://hackathon.siim.org/dicomweb/studies/?00100010=SIIM*
NOTE: If you having trouble formulating a QIDO request, an alternative way to discover patients/studies is to use Orthanc's web UI at: https://hackathon.siim.org/vna/
Once you've picked a study to download, extract the study UID from the response and you can download its study structure by making a subsequent QIDO-RS query:
https://hackathon.siim.org/dicomweb/studies/1.3.6.1.4.1.14519.5.2.1.4792.2001.103189108764313019491934667255/instances
If you want to control the format of the server response, add an Accept
header with application/json
for JSON or text/xml
for XML.
NOTE: When you choose XML, DICOMweb returns results in multipart
format, which is used to combine multiple objects into one response. Read more about multipart at here and here.
And once you've done that, select an image to download from the response, extract the series UID and instance UID from the response and you can download the DICOM image by making a subsequent WADO-RS query:
https://hackathon.siim.org/dicomweb/studies/1.3.6.1.4.1.14519.5.2.1.4792.2001.103189108764313019491934667255/series/1.3.6.1.4.1.14519.5.2.1.4792.2001.104616474240757574154876423123/instances/1.3.6.1.4.1.14519.5.2.1.4792.2001.267212981954448819074140522716
Ensure your request includes a header that specifies the return type, i.e.
Accept: application/dicom
Add /frames/1/rendered
to the URL from the last step, and change your Accept
header to either image/jpeg
or image/png
. Here's the full URL:
http://hackathon.siim.org/dicomweb/studies/1.3.6.1.4.1.14519.5.2.1.7777.9002.198875685720513246512710453733/series/1.3.6.1.4.1.14519.5.2.1.7777.9002.207203214132667549392101803048/instances/1.3.6.1.4.1.14519.5.2.1.7777.9002.327873213718058651550666129029/frames/1/rendered
If you are working with a server that does not support DICOMweb, you can retrieve images (as DICOM, or rendered JPEG/PNG) using the older WADO-URL standard. For example:
https://hackathon.siim.org/wadouri/?requestType=WADO&studyUID=1.3.6.1.4.1.14519.5.2.1.4792.2001.103189108764313019491934667255&seriesUID=1.3.6.1.4.1.14519.5.2.1.4792.2001.104616474240757574154876423123&objectUID=1.3.6.1.4.1.14519.5.2.1.4792.2001.267212981954448819074140522716
The URL above returns DICOM. If you want a rendered JPEG or PND, simply add &contentType=image/jpeg
or &contentType=image/png
to your URL (not header) request.
Who wouldn't? Right?!? Have a look at https://replit.com/@mohannadhussain/dicom-web-example)
Interested in pushing data to the server? This article provides tips on how to do that using cURL, which can easily be adapted for use with other tools, like Postman.
- DICOMweb documentation
- DICOMweb CheatSheet
- QIDO-RS
- WADO-RS
- STOW-RS