2020-09-12 13:03:18 +01:00
|
|
|
# Simple HTTP web server
|
|
|
|
|
|
|
|
## Concepts
|
|
|
|
|
|
|
|
- Use the std library [http module](https://deno.land/std@$STD_VERSION/http) to
|
2020-09-27 10:49:41 -07:00
|
|
|
run your own web server.
|
2020-09-12 13:03:18 +01:00
|
|
|
|
|
|
|
## Overview
|
|
|
|
|
|
|
|
With just a few lines of code you can run your own http web server with control
|
|
|
|
over the response status, request headers and more.
|
|
|
|
|
|
|
|
## Sample web server
|
|
|
|
|
2020-09-27 10:49:41 -07:00
|
|
|
In this example, the user-agent of the client is returned to the client:
|
2020-09-12 13:03:18 +01:00
|
|
|
|
|
|
|
```typescript
|
2020-09-27 10:49:41 -07:00
|
|
|
/**
|
|
|
|
* webserver.ts
|
2020-09-12 13:03:18 +01:00
|
|
|
*/
|
|
|
|
import { serve } from "https://deno.land/std@$STD_VERSION/http/server.ts";
|
|
|
|
|
|
|
|
const server = serve({ hostname: "0.0.0.0", port: 8080 });
|
|
|
|
console.log(`HTTP webserver running. Access it at: http://localhost:8080/`);
|
|
|
|
|
|
|
|
for await (const request of server) {
|
|
|
|
let bodyContent = "Your user-agent is:\n\n";
|
|
|
|
bodyContent += request.headers.get("user-agent") || "Unknown";
|
|
|
|
|
|
|
|
request.respond({ status: 200, body: bodyContent });
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
Run this with:
|
|
|
|
|
|
|
|
```shell
|
|
|
|
deno run --allow-net webserver.ts
|
|
|
|
```
|