Swagger for API Documentation

Develop RESTful Java Web Services Using Spring Boot Get Started with REST and Spring Boot
8 minutes
Share the link to this page
Copied
  Completed
You need to have access to the item to view this lesson.
One-time Fee
$49.99
List Price:  $69.99
You save:  $20
€46.53
List Price:  €65.14
You save:  €18.61
£39.80
List Price:  £55.73
You save:  £15.92
CA$68.29
List Price:  CA$95.61
You save:  CA$27.32
A$75.92
List Price:  A$106.30
You save:  A$30.37
S$67.59
List Price:  S$94.64
You save:  S$27.04
HK$390.62
List Price:  HK$546.91
You save:  HK$156.28
CHF 45.35
List Price:  CHF 63.50
You save:  CHF 18.14
NOK kr546.18
List Price:  NOK kr764.69
You save:  NOK kr218.51
DKK kr347.06
List Price:  DKK kr485.92
You save:  DKK kr138.85
NZ$83.56
List Price:  NZ$117
You save:  NZ$33.43
د.إ183.60
List Price:  د.إ257.06
You save:  د.إ73.45
৳5,472.53
List Price:  ৳7,661.98
You save:  ৳2,189.45
₹4,170.94
List Price:  ₹5,839.65
You save:  ₹1,668.71
RM236.95
List Price:  RM331.75
You save:  RM94.80
₦61,737.65
List Price:  ₦86,437.65
You save:  ₦24,700
₨13,922.21
List Price:  ₨19,492.21
You save:  ₨5,570
฿1,839.58
List Price:  ฿2,575.56
You save:  ฿735.98
₺1,615.93
List Price:  ₺2,262.43
You save:  ₺646.50
B$255.52
List Price:  B$357.76
You save:  B$102.23
R925.67
List Price:  R1,296.01
You save:  R370.34
Лв90.98
List Price:  Лв127.38
You save:  Лв36.40
₩67,934.14
List Price:  ₩95,113.23
You save:  ₩27,179.09
₪185.78
List Price:  ₪260.11
You save:  ₪74.32
₱2,856.70
List Price:  ₱3,999.61
You save:  ₱1,142.91
¥7,653.44
List Price:  ¥10,715.43
You save:  ¥3,061.99
MX$846.70
List Price:  MX$1,185.45
You save:  MX$338.74
QR181.98
List Price:  QR254.79
You save:  QR72.81
P682.59
List Price:  P955.69
You save:  P273.09
KSh6,733.65
List Price:  KSh9,427.65
You save:  KSh2,694
E£2,396.77
List Price:  E£3,355.67
You save:  E£958.90
ብር2,849.43
List Price:  ብር3,989.43
You save:  ብር1,140
Kz41,866.62
List Price:  Kz58,616.62
You save:  Kz16,750
CLP$47,373.02
List Price:  CLP$66,326.02
You save:  CLP$18,953
CN¥361.77
List Price:  CN¥506.51
You save:  CN¥144.74
RD$2,892.40
List Price:  RD$4,049.59
You save:  RD$1,157.19
DA6,728.32
List Price:  DA9,420.19
You save:  DA2,691.86
FJ$112.64
List Price:  FJ$157.70
You save:  FJ$45.06
Q387.56
List Price:  Q542.62
You save:  Q155.05
GY$10,437.32
List Price:  GY$14,613.08
You save:  GY$4,175.76
ISK kr6,994.10
List Price:  ISK kr9,792.30
You save:  ISK kr2,798.20
DH504.29
List Price:  DH706.05
You save:  DH201.75
L885.56
List Price:  L1,239.86
You save:  L354.29
ден2,864.78
List Price:  ден4,010.92
You save:  ден1,146.14
MOP$401.51
List Price:  MOP$562.15
You save:  MOP$160.63
N$930.33
List Price:  N$1,302.54
You save:  N$372.20
C$1,836.63
List Price:  C$2,571.43
You save:  C$734.80
रु6,655.03
List Price:  रु9,317.58
You save:  रु2,662.54
S/187.71
List Price:  S/262.81
You save:  S/75.10
K191.79
List Price:  K268.53
You save:  K76.73
SAR187.49
List Price:  SAR262.51
You save:  SAR75.01
ZK1,342.57
List Price:  ZK1,879.71
You save:  ZK537.13
L231.55
List Price:  L324.19
You save:  L92.63
Kč1,163.97
List Price:  Kč1,629.65
You save:  Kč465.68
Ft18,122.66
List Price:  Ft25,373.17
You save:  Ft7,250.51
SEK kr541.93
List Price:  SEK kr758.75
You save:  SEK kr216.81
ARS$43,903.87
List Price:  ARS$61,468.94
You save:  ARS$17,565.06
Bs344.52
List Price:  Bs482.36
You save:  Bs137.83
COP$194,950.93
List Price:  COP$272,946.91
You save:  COP$77,995.97
₡25,444.18
List Price:  ₡35,623.88
You save:  ₡10,179.70
L1,237.75
List Price:  L1,732.95
You save:  L495.20
₲373,658.53
List Price:  ₲523,151.84
You save:  ₲149,493.31
$U1,916.38
List Price:  $U2,683.09
You save:  $U766.70
zł201.31
List Price:  zł281.85
You save:  zł80.54
Already have an account? Log In

Transcript

Now that we have done the RESTful web service, it's important to add API documentation to our service. Otherwise, when we share this to some customers who want to make use of our REST endpoints, now it is very difficult for them to read or understand our API's. And many of the occasions, we wouldn't be sharing the source code with them. So how do we do this? Now this is where you have a fantastic API called swagger. So if you go to swagger.io, you can learn about how API development is simplified with the documentation of swagger.

Now, I don't want to go too deep into how this works. But I want to show you how to add swagger to our application and get the API up and running. So the first thing we want to do is to get the swagger so if you go to spring initializer and look for swagger here, you may not see that now somehow Spring Boot does not have default dependencies included over Hear, so we may have to explicitly go to MV and repository comm and look for swagger to press enter. You can see it comes from IO dot spring Fox dot spring Fox swagger two, so I'm going to select that. And the current version happens to be 292. So I just have a copy this go back to our POM dot XML, add this as a dependency.

So I can go to the end of the dependency list here and paste it. Save this and now I have one dependency that is added. With this dependency we will be able to scan and get information about all the APS we have. If you want a graphical user interface that displays all the API's provide some testing options, then you have to add one more dependency which is from let's go to swagger UI and if To see that it's again from IO dot spring fork, spring fork swagger UI. The version also is the same thing 292. I copy that, once again, go back to my POM dot XML, add as the last dependency, save it, it's going to download the jar files for the same.

There are two more steps involved in enabling swagger. Number one, we go to application dot java. And we say that we want to enable swagger documentation. So I'm going to go here and then type at the rate enable swagger and it says enable swagger two, and we have to add a bean definition here. So now what is this bean definition? Now when we say enable swagger to it's going to look for an object that is going to scan your entire project for all the API's and then build the documentation.

Now this is called as a docket. And the way you do that is by typing public docket. So Docker is supposed to come from spring Fox documentations Spring dot web dot plugins. And then we can call any name we want. Let's call it as API. And we have to return some docket object.

So with the return new docket, and then we supply a, what version? So you can see that it says, What's the documentation type? That's argument. So we say your documentation type dot swagger one, or swagger two. So we want to say swagger two. Now, technically, we should be able to return this object and everything should be okay.

But this gives us configuration as well. Now we have to mark this as a bean. So that spring automatically instantiate this object. And then this Docker object can be used for reading the API documentation. Now to specify some configuration here we say here dot select, and then this is what to say, what appears to be selected which says select the API's like dot API's and Then say what are the AP is that we want to document and we say any request handlers or dates such as the get mapping, post mapping, etc. So we want that.

So we say Request Handler, selectors, dot any saying that any type of handlers we want. And then we also say any type of paths that we want to specify. And again, you can say path selector of any. Now, once again, we are seeing that we want to just document everything. But here is where instead of saying any I can add some filter saying that a provide documentation for only get handlers not for post, or I can say slash API slash secured should not be included, etc, etc. I can do that.

And then I can say, bill to finally build this. So the lot of documentation configuration you can do over here. Then let's let's see, what is the error here? So we see some kind of a console log. Let's see what is that It is your class not found docket. So this could be because when we actually added the Maven dependencies it was still building.

So we may have to stop this once. Let's clear the console and run the application once again and see if everything is okay. Alright, looks like everything is fine. It's being scanning, you can see that scanning for API listing references. tonker has been started application has been started in 10 seconds. So I'm going to go back to the browser and first look for something like localhost 7777 slash, and then I type your v2 slash API docs.

Now, this is where you will be able to see some JSON documentation, representing a lot of information. Let's copy this and open in postman let's paste it press enter, you can see that it's going to give me a JSON representing lots of API URLs. Now, this is not very useful for us. But this is going to be used by swagger UI. So how do I get into that? Very simple, you just have to say your swagger UI dot html.

But when I press enter, you can see we get Hello Spring Boot. And this is because we have mapped the slash to this particular Hello Spring Boot. Now what I can do is I can just change this to slash Hello. So that when slash Hello is lost. This is the answer that we're going to get. If you are accessing the root of your service, then swagger UI should give the response so now if I explicitly access slash Hello, we get this Hello Spring Boot.

But if I say your swagger UI dot html, and now you should see that we got an APA documentation over here. Now the APA document Addition includes application which has a slash Hello, as one API. There is a basic error controller. Now, we did not configure any error controllers. But if we do that we will get, but there is a slash error with all get head post, etc. So this is not configured by us.

But you can see customer rest controller. That's the name we gave in our application. So if it's expanded, you have slash API customers get all customers is a function of the handler for the same. There's a post for API customers, there's a get put and delete for this particular URL. If you select API customers, you can see that I'm able to supply some parameters. Also here, it says there's an underscore limit underscore page as query string parameters that are optional, because there's a default value of 10 and one here respectively.

These could be the possible responses if it is 200. There's going to be okay. Example values and so on and so forth. Now, what you can do is you can also test the same thing by Clicking on try it out. So let's do that. When I do that it says, These are the two values defaults Do you want to execute, let's execute and see.

And it comes back and say, Hey, this is how you do a C URL or curl. So like on a Macintosh or Linux, I can just copy this and paste and I should be able to get it on a terminal. But if you want to access from the browser, this is going to be and this is the response that we got, or we were supposed to get when we make a request. And of course, there's some options to download, and so on and so forth. So this is how you use swagger to create API documentation for all your micro services.

Sign Up

Share

Share with friends, get 20% off
Invite your friends to LearnDesk learning marketplace. For each purchase they make, you get 20% off (upto $10) on your next purchase.