mirror of
https://github.com/cesanta/mongoose.git
synced 2025-01-07 11:41:26 +08:00
47 lines
1.6 KiB
Markdown
47 lines
1.6 KiB
Markdown
|
---
|
||
|
title: Serving files
|
||
|
---
|
||
|
|
||
|
API function `mg_serve_http()` makes it easy to serve files from a filesystem.
|
||
|
Generally speaking, that function is an implementation of the HTTP server
|
||
|
that serves static files, CGI and SSI. It's behavior is driven by a list
|
||
|
of options that are consolidated into the `struct mg_serve_http_opts`
|
||
|
structure. See [struct mg_serve_http_opts](#) definition for the full list
|
||
|
of capabilities of `mg_serve_http()`.
|
||
|
|
||
|
For example, in order to create a web server that serves static files
|
||
|
from the current directory, implement event handler function as follows:
|
||
|
|
||
|
```c
|
||
|
static void ev_handler(struct mg_connection *c, int ev, void *ev_data) {
|
||
|
if (ev == MG_EV_HTTP_REQUEST) {
|
||
|
struct mg_serve_http_opts opts;
|
||
|
|
||
|
memset(&opts, 0, sizeof(opts); // Reset all options to defaults
|
||
|
opts.document_root = "."; // Serve files from the current directory
|
||
|
|
||
|
mg_serve_http(c, (struct http_message *) ev_data, s_http_server_opts);
|
||
|
}
|
||
|
}
|
||
|
```
|
||
|
|
||
|
See working example at [simplest web server](https://github.com/cesanta/mongoose/tree/master/examples/simplest_web_server).
|
||
|
|
||
|
Sometimes there is no need to implement a full static web server, for example
|
||
|
if one works on a RESTful server. If certain endpoints must return the contents
|
||
|
of a static file, a simpler `mg_http_serve_file()` function can be used:
|
||
|
|
||
|
```c
|
||
|
static void ev_handler(struct mg_connection *c, int ev, void *ev_data) {
|
||
|
switch (ev) {
|
||
|
case MG_EV_HTTP_REQUEST: {
|
||
|
struct http_message *hm = (struct http_message *) ev_data;
|
||
|
mg_http_serve_file(c, hm, "file.txt",
|
||
|
mg_mk_str("text/plain"), mg_mk_str(""));
|
||
|
break;
|
||
|
}
|
||
|
...
|
||
|
}
|
||
|
}
|
||
|
```
|