Merge pull request #1423 from yunstanford/request-streaming-support
basic request streaming support with flow control
This commit is contained in:
		| @@ -88,6 +88,7 @@ Out of the box there are just a few predefined values which can be overwritten w | ||||
|     | Variable                  | Default   | Description                                            | | ||||
|     | ------------------------- | --------- | ------------------------------------------------------ | | ||||
|     | REQUEST_MAX_SIZE          | 100000000 | How big a request may be (bytes)                       | | ||||
|     | REQUEST_BUFFER_QUEUE_SIZE | 100       | Request streaming buffer queue size                    | | ||||
|     | REQUEST_TIMEOUT           | 60        | How long a request can take to arrive (sec)            | | ||||
|     | RESPONSE_TIMEOUT          | 60        | How long a response can take to process (sec)          | | ||||
|     | KEEP_ALIVE                | True      | Disables keep-alive when False                         | | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
|  | ||||
| ## Request Streaming | ||||
|  | ||||
| Sanic allows you to get request data by stream, as below. When the request ends, `request.stream.get()` returns `None`. Only post, put and patch decorator have stream argument. | ||||
| Sanic allows you to get request data by stream, as below. When the request ends, `await request.stream.read()` returns `None`. Only post, put and patch decorator have stream argument. | ||||
|  | ||||
| ```python | ||||
| from sanic import Sanic | ||||
| @@ -22,7 +22,7 @@ class SimpleView(HTTPMethodView): | ||||
|     async def post(self, request): | ||||
|         result = '' | ||||
|         while True: | ||||
|             body = await request.stream.get() | ||||
|             body = await request.stream.read() | ||||
|             if body is None: | ||||
|                 break | ||||
|             result += body.decode('utf-8') | ||||
| @@ -33,7 +33,7 @@ class SimpleView(HTTPMethodView): | ||||
| async def handler(request): | ||||
|     async def streaming(response): | ||||
|         while True: | ||||
|             body = await request.stream.get() | ||||
|             body = await request.stream.read() | ||||
|             if body is None: | ||||
|                 break | ||||
|             body = body.decode('utf-8').replace('1', 'A') | ||||
| @@ -45,7 +45,7 @@ async def handler(request): | ||||
| async def bp_handler(request): | ||||
|     result = '' | ||||
|     while True: | ||||
|         body = await request.stream.get() | ||||
|         body = await request.stream.read() | ||||
|         if body is None: | ||||
|             break | ||||
|         result += body.decode('utf-8').replace('1', 'A') | ||||
| @@ -55,7 +55,7 @@ async def bp_handler(request): | ||||
| async def post_handler(request): | ||||
|     result = '' | ||||
|     while True: | ||||
|         body = await request.stream.get() | ||||
|         body = await request.stream.read() | ||||
|         if body is None: | ||||
|             break | ||||
|         result += body.decode('utf-8') | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 7
					7