123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309 |
- = REST hello world example
- To try this example, you need GNU `make` and `git` in your PATH.
- To build and run the example, use the following command:
- [source,bash]
- $ make run
- Then point your browser to http://localhost:8080
- == HTTP/1.1 example output
- Request HTML:
- [source,bash]
- ----
- $ curl -i http://localhost:8080
- HTTP/1.1 200 OK
- connection: keep-alive
- server: Cowboy
- date: Fri, 28 Sep 2012 04:15:52 GMT
- content-length: 136
- content-type: text/html
- vary: Accept
- <html>
- <head>
- <meta charset="utf-8">
- <title>REST Hello World!</title>
- </head>
- <body>
- <p>REST Hello World as HTML!</p>
- </body>
- </html>
- ----
- Request JSON:
- [source,bash]
- ----
- $ curl -i -H "Accept: application/json" http://localhost:8080
- HTTP/1.1 200 OK
- connection: keep-alive
- server: Cowboy
- date: Fri, 28 Sep 2012 04:16:46 GMT
- content-length: 24
- content-type: application/json
- vary: Accept
- {"rest": "Hello World!"}
- ----
- Request plain text:
- [source,bash]
- ----
- $ curl -i -H "Accept: text/plain" http://localhost:8080
- HTTP/1.1 200 OK
- connection: keep-alive
- server: Cowboy
- date: Fri, 28 Sep 2012 04:18:35 GMT
- content-length: 25
- content-type: text/plain
- vary: Accept
- REST Hello World as text!
- ----
- Request a non acceptable content-type:
- [source,bash]
- ----
- $ curl -i -H "Accept: text/css" http://localhost:8080
- HTTP/1.1 406 Not Acceptable
- connection: keep-alive
- server: Cowboy
- date: Fri, 28 Sep 2012 04:18:51 GMT
- content-length: 0
- ----
- == HTTP/2 example output
- Request HTML:
- [source,bash]
- ----
- $ nghttp -v http://localhost:8080
- [ 0.000] Connected
- [ 0.000] send SETTINGS frame <length=12, flags=0x00, stream_id=0>
- (niv=2)
- [SETTINGS_MAX_CONCURRENT_STREAMS(0x03):100]
- [SETTINGS_INITIAL_WINDOW_SIZE(0x04):65535]
- [ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=3>
- (dep_stream_id=0, weight=201, exclusive=0)
- [ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=5>
- (dep_stream_id=0, weight=101, exclusive=0)
- [ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=7>
- (dep_stream_id=0, weight=1, exclusive=0)
- [ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=9>
- (dep_stream_id=7, weight=1, exclusive=0)
- [ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=11>
- (dep_stream_id=3, weight=1, exclusive=0)
- [ 0.000] send HEADERS frame <length=38, flags=0x25, stream_id=13>
- ; END_STREAM | END_HEADERS | PRIORITY
- (padlen=0, dep_stream_id=11, weight=16, exclusive=0)
- ; Open new stream
- :method: GET
- :path: /
- :scheme: http
- :authority: localhost:8080
- accept: */*
- accept-encoding: gzip, deflate
- user-agent: nghttp2/1.7.1
- [ 0.000] recv SETTINGS frame <length=0, flags=0x00, stream_id=0>
- (niv=0)
- [ 0.000] send SETTINGS frame <length=0, flags=0x01, stream_id=0>
- ; ACK
- (niv=0)
- [ 0.000] recv SETTINGS frame <length=0, flags=0x01, stream_id=0>
- ; ACK
- (niv=0)
- [ 0.001] recv (stream_id=13) :status: 200
- [ 0.001] recv (stream_id=13) content-length: 136
- [ 0.001] recv (stream_id=13) content-type: text/html
- [ 0.001] recv (stream_id=13) date: Thu, 09 Jun 2016 14:28:50 GMT
- [ 0.001] recv (stream_id=13) server: Cowboy
- [ 0.001] recv (stream_id=13) vary: accept
- [ 0.001] recv HEADERS frame <length=52, flags=0x04, stream_id=13>
- ; END_HEADERS
- (padlen=0)
- ; First response header
- <html>
- <head>
- <meta charset="utf-8">
- <title>REST Hello World!</title>
- </head>
- <body>
- <p>REST Hello World as HTML!</p>
- </body>
- </html>[ 0.001] recv DATA frame <length=136, flags=0x01, stream_id=13>
- ; END_STREAM
- [ 0.001] send GOAWAY frame <length=8, flags=0x00, stream_id=0>
- (last_stream_id=0, error_code=NO_ERROR(0x00), opaque_data(0)=[])
- ----
- Request JSON:
- [source,bash]
- ----
- $ nghttp -v -H "accept: application/json" http://localhost:8080
- [ 0.000] Connected
- [ 0.000] send SETTINGS frame <length=12, flags=0x00, stream_id=0>
- (niv=2)
- [SETTINGS_MAX_CONCURRENT_STREAMS(0x03):100]
- [SETTINGS_INITIAL_WINDOW_SIZE(0x04):65535]
- [ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=3>
- (dep_stream_id=0, weight=201, exclusive=0)
- [ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=5>
- (dep_stream_id=0, weight=101, exclusive=0)
- [ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=7>
- (dep_stream_id=0, weight=1, exclusive=0)
- [ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=9>
- (dep_stream_id=7, weight=1, exclusive=0)
- [ 0.001] send PRIORITY frame <length=5, flags=0x00, stream_id=11>
- (dep_stream_id=3, weight=1, exclusive=0)
- [ 0.001] send HEADERS frame <length=46, flags=0x25, stream_id=13>
- ; END_STREAM | END_HEADERS | PRIORITY
- (padlen=0, dep_stream_id=11, weight=16, exclusive=0)
- ; Open new stream
- :method: GET
- :path: /
- :scheme: http
- :authority: localhost:8080
- accept: application/json
- accept-encoding: gzip, deflate
- user-agent: nghttp2/1.7.1
- [ 0.001] recv SETTINGS frame <length=0, flags=0x00, stream_id=0>
- (niv=0)
- [ 0.001] send SETTINGS frame <length=0, flags=0x01, stream_id=0>
- ; ACK
- (niv=0)
- [ 0.001] recv SETTINGS frame <length=0, flags=0x01, stream_id=0>
- ; ACK
- (niv=0)
- [ 0.001] recv (stream_id=13) :status: 200
- [ 0.001] recv (stream_id=13) content-length: 24
- [ 0.001] recv (stream_id=13) content-type: application/json
- [ 0.001] recv (stream_id=13) date: Thu, 09 Jun 2016 14:29:00 GMT
- [ 0.001] recv (stream_id=13) server: Cowboy
- [ 0.001] recv (stream_id=13) vary: accept
- [ 0.001] recv HEADERS frame <length=55, flags=0x04, stream_id=13>
- ; END_HEADERS
- (padlen=0)
- ; First response header
- {"rest": "Hello World!"}[ 0.002] recv DATA frame <length=24, flags=0x01, stream_id=13>
- ; END_STREAM
- [ 0.002] send GOAWAY frame <length=8, flags=0x00, stream_id=0>
- (last_stream_id=0, error_code=NO_ERROR(0x00), opaque_data(0)=[])
- ----
- Request plain text:
- [source,bash]
- ----
- $ nghttp -v -H "accept: text/plain" http://localhost:8080
- [ 0.000] Connected
- [ 0.000] send SETTINGS frame <length=12, flags=0x00, stream_id=0>
- (niv=2)
- [SETTINGS_MAX_CONCURRENT_STREAMS(0x03):100]
- [SETTINGS_INITIAL_WINDOW_SIZE(0x04):65535]
- [ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=3>
- (dep_stream_id=0, weight=201, exclusive=0)
- [ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=5>
- (dep_stream_id=0, weight=101, exclusive=0)
- [ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=7>
- (dep_stream_id=0, weight=1, exclusive=0)
- [ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=9>
- (dep_stream_id=7, weight=1, exclusive=0)
- [ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=11>
- (dep_stream_id=3, weight=1, exclusive=0)
- [ 0.000] send HEADERS frame <length=42, flags=0x25, stream_id=13>
- ; END_STREAM | END_HEADERS | PRIORITY
- (padlen=0, dep_stream_id=11, weight=16, exclusive=0)
- ; Open new stream
- :method: GET
- :path: /
- :scheme: http
- :authority: localhost:8080
- accept: text/plain
- accept-encoding: gzip, deflate
- user-agent: nghttp2/1.7.1
- [ 0.000] recv SETTINGS frame <length=0, flags=0x00, stream_id=0>
- (niv=0)
- [ 0.000] send SETTINGS frame <length=0, flags=0x01, stream_id=0>
- ; ACK
- (niv=0)
- [ 0.000] recv SETTINGS frame <length=0, flags=0x01, stream_id=0>
- ; ACK
- (niv=0)
- [ 0.000] recv (stream_id=13) :status: 200
- [ 0.000] recv (stream_id=13) content-length: 25
- [ 0.000] recv (stream_id=13) content-type: text/plain
- [ 0.000] recv (stream_id=13) date: Thu, 09 Jun 2016 14:28:25 GMT
- [ 0.000] recv (stream_id=13) server: Cowboy
- [ 0.000] recv (stream_id=13) vary: accept
- [ 0.000] recv HEADERS frame <length=51, flags=0x04, stream_id=13>
- ; END_HEADERS
- (padlen=0)
- ; First response header
- REST Hello World as text![ 0.000] recv DATA frame <length=25, flags=0x01, stream_id=13>
- ; END_STREAM
- [ 0.000] send GOAWAY frame <length=8, flags=0x00, stream_id=0>
- (last_stream_id=0, error_code=NO_ERROR(0x00), opaque_data(0)=[])
- ----
- Request a non acceptable content-type:
- [source,bash]
- ----
- $ nghttp -v -H "accept: text/css" http://localhost:8080
- [ 0.000] Connected
- [ 0.000] send SETTINGS frame <length=12, flags=0x00, stream_id=0>
- (niv=2)
- [SETTINGS_MAX_CONCURRENT_STREAMS(0x03):100]
- [SETTINGS_INITIAL_WINDOW_SIZE(0x04):65535]
- [ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=3>
- (dep_stream_id=0, weight=201, exclusive=0)
- [ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=5>
- (dep_stream_id=0, weight=101, exclusive=0)
- [ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=7>
- (dep_stream_id=0, weight=1, exclusive=0)
- [ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=9>
- (dep_stream_id=7, weight=1, exclusive=0)
- [ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=11>
- (dep_stream_id=3, weight=1, exclusive=0)
- [ 0.000] send HEADERS frame <length=41, flags=0x25, stream_id=13>
- ; END_STREAM | END_HEADERS | PRIORITY
- (padlen=0, dep_stream_id=11, weight=16, exclusive=0)
- ; Open new stream
- :method: GET
- :path: /
- :scheme: http
- :authority: localhost:8080
- accept: text/css
- accept-encoding: gzip, deflate
- user-agent: nghttp2/1.7.1
- [ 0.007] recv SETTINGS frame <length=0, flags=0x00, stream_id=0>
- (niv=0)
- [ 0.007] recv SETTINGS frame <length=0, flags=0x01, stream_id=0>
- ; ACK
- (niv=0)
- [ 0.007] send SETTINGS frame <length=0, flags=0x01, stream_id=0>
- ; ACK
- (niv=0)
- [ 0.021] recv (stream_id=13) :status: 406
- [ 0.021] recv (stream_id=13) content-length: 0
- [ 0.021] recv (stream_id=13) date: Thu, 09 Jun 2016 14:29:15 GMT
- [ 0.021] recv (stream_id=13) server: Cowboy
- [ 0.021] recv HEADERS frame <length=39, flags=0x04, stream_id=13>
- ; END_HEADERS
- (padlen=0)
- ; First response header
- [ 0.021] recv DATA frame <length=0, flags=0x01, stream_id=13>
- ; END_STREAM
- [ 0.021] send GOAWAY frame <length=8, flags=0x00, stream_id=0>
- (last_stream_id=0, error_code=NO_ERROR(0x00), opaque_data(0)=[])
- ----
|