Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/koajs/send
Transfer static files
https://github.com/koajs/send
Last synced: 27 days ago
JSON representation
Transfer static files
- Host: GitHub
- URL: https://github.com/koajs/send
- Owner: koajs
- License: mit
- Created: 2013-12-12T05:28:54.000Z (almost 11 years ago)
- Default Branch: master
- Last Pushed: 2023-06-30T16:22:48.000Z (over 1 year ago)
- Last Synced: 2024-04-14T13:08:40.677Z (7 months ago)
- Language: TypeScript
- Size: 105 KB
- Stars: 424
- Watchers: 7
- Forks: 89
- Open Issues: 20
-
Metadata Files:
- Readme: README.md
- Changelog: History.md
- License: LICENSE
Awesome Lists containing this project
- awesome-koa - send - Transfer static files (Middleware)
- awesome-koa - koa-send - 传送静态文件。 ![](https://img.shields.io/github/stars/koajs/send.svg?style=social&label=Star) ![](https://img.shields.io/npm/dm/koa-send.svg?style=flat-square) (仓库 / 中间件)
README
# [**@koa/send**](https://github.com/koajs/send)
[![NPM version][npm-image]][npm-url]
![Build Status][github-action-image]
[![Test coverage][coveralls-image]][coveralls-url]
[![License][license-image]][license-url]
[![Downloads][downloads-image]][downloads-url][npm-image]: https://img.shields.io/npm/v/@koa/send.svg?style=flat-square
[npm-url]: https://npmjs.org/package/@koa/send
[github-action-image]: https://github.com/koajs/send/actions/workflows/ci.yml/badge.svg?style=flat-square
[coveralls-image]: https://img.shields.io/coveralls/koajs/send.svg?style=flat-square
[coveralls-url]: https://coveralls.io/r/koajs/send?branch=master
[license-image]: http://img.shields.io/npm/l/koa-send.svg?style=flat-square
[license-url]: LICENSE
[downloads-image]: http://img.shields.io/npm/dm/koa-send.svg?style=flat-square
[downloads-url]: https://npmjs.org/package/koa-sendKoa static file serving middleware.
## Install
[![NPM](https://nodei.co/npm/@koa/send.png?downloads=true)](https://nodei.co/npm/@koa/send)
```js
$ npm i @koa/send
```## Options
- `maxage` Browser cache max-age in milliseconds. (defaults to `0`).
- `immutable` Tell the browser the resource is immutable and can be cached indefinitely. (defaults to `false`).
- `hidden` Allow transfer of hidden files. (defaults to `false`).
- [`root`](#root-path) Root directory to restrict file access.
- `index` Name of the index file to serve automatically when visiting the root location. (defaults to none).
- `gzip` Try to serve the gzipped version of a file automatically when `gzip` is supported by a client and if the requested file with `.gz` extension exists. (defaults to `true`).
- `brotli` Try to serve the brotli version of a file automatically when `brotli` is supported by a client and if the requested file with `.br` extension exists. (defaults to `true`).
- `format` If not `false` (defaults to `true`), format the path to serve static file servers and not require a trailing slash for directories, so that you can do both `/directory` and `/directory/`.
- [`setHeaders`](#setheaders) Function to set custom headers on response.
- `extensions` Try to match extensions from passed array to search for file when no extension is sufficed in URL. First found is served. (defaults to `false`)### Root path
Note that `root` is required, defaults to `''` and will be resolved,
removing the leading `/` to make the path relative and this
path must not contain "..", protecting developers from
concatenating user input. If you plan on serving files based on
user input supply a `root` directory from which to serve from.For example to serve files from `./public`:
```js
app.use(async (ctx) => {
await send(ctx, ctx.path, { root: __dirname + "/public" });
});
```To serve developer specified files:
```js
app.use(async (ctx) => {
await send(ctx, "path/to/my.js");
});
```### setHeaders
The function is called as `fn(res, path, stats)`, where the arguments are:
- `res`: the response object.
- `path`: the resolved file path that is being sent.
- `stats`: the stats object of the file that is being sent.You should only use the `setHeaders` option when you wish to edit the `Cache-Control` or `Last-Modified` headers, because doing it before is useless (it's overwritten by `send`), and doing it after is too late because the headers are already sent.
If you want to edit any other header, simply set them before calling `send`.
## Example
```js
const send = require("@koa/send");
const Koa = require("koa");
const app = new Koa();// $ GET /package.json
// $ GET /app.use(async (ctx) => {
if ("/" == ctx.path) return (ctx.body = "Try GET /package.json");
await send(ctx, ctx.path);
});app.listen(3000);
console.log("listening on port 3000");
```## License
[MIT](/LICENSE)