0
0
mirror of https://github.com/honojs/hono.git synced 2024-11-29 17:46:30 +01:00
hono/deno_dist
Derrick Farris 1adc9264fc
fix(validator): return HTTP 400 on malformed JSON request (#579)
* fix(validator): return http 400 on malformed JSON request

* chore(deno): denoify malformed json changes
2022-10-04 06:16:25 +09:00
..
deno refactor(serve-static): use context/next instead of MiddlewareHandler (#559) 2022-09-27 21:40:37 +09:00
middleware fix(validator): return HTTP 400 on malformed JSON request (#579) 2022-10-04 06:16:25 +09:00
router fix(reg-exp-router): Register path for all the methods if method === METHOD_NAME_ALL. (#580) 2022-10-03 07:50:57 +09:00
utils feat(validator): add support for JSON array path validation (#563) 2022-09-30 21:56:39 +09:00
compose.ts fix(compose): don't throw Error; set error response into c.res (#576) 2022-10-02 15:44:54 +09:00
context.ts fix(compose): don't throw Error; set error response into c.res (#576) 2022-10-02 15:44:54 +09:00
hono.ts fix(compose): don't throw Error; set error response into c.res (#576) 2022-10-02 15:44:54 +09:00
LICENSE feat: support Deno! (#336) 2022-07-02 15:09:45 +09:00
middleware.ts fix(cache): export cache middleware for Deno (#573) 2022-10-01 17:23:44 +09:00
mod.ts fix(context): export ContextVariableMap correctly (#476) 2022-08-23 11:51:18 +09:00
README.md docs(readme): update! 2022-09-20 23:06:05 +09:00
request.ts feat(validator): Enable verification results to be retrieved as structured data. (#547) 2022-09-21 09:40:17 +09:00
router.ts Introduce StaticRouter and SmartRouter (#501) 2022-09-12 20:49:18 +09:00


Documentation 👉 honojs.dev
v2.x has been released! Migration guide


GitHub Workflow Status GitHub npm npm npm type definitions GitHub commit activity GitHub last commit Deno badge Discord badge

Hono - [炎] means flame🔥 in Japanese - is a small, simple, and ultrafast web framework for Cloudflare Workers, Deno, Bun, and others.

import { Hono } from 'hono'
const app = new Hono()

app.get('/', (c) => c.text('Hono!!'))

export default app

Features

  • Ultrafast - The routers are really smart. Not using linear loops. The fastest one will be selected from three routers.
  • Zero-dependencies - Using only Web Standard API. Does not depend on other npm or Deno libraries.
  • Middleware - Hono has built-in middleware, custom middleware, and third-party middleware. Batteries included.
  • TypeScript - First-class TypeScript support. Now, we've got "Types".
  • Multi-runtime - Works on Cloudflare Workers, Fastly Compute@Edge, Deno, Bun, or Node.js. The same code runs on all platforms.

Benchmarks

Hono is fastest, compared to other routers for Cloudflare Workers.

Hono x 616,464 ops/sec ±4.76% (83 runs sampled)
itty-router x 203,074 ops/sec ±3.66% (88 runs sampled)
sunder x 314,306 ops/sec ±2.28% (87 runs sampled)
worktop x 194,111 ops/sec ±2.78% (81 runs sampled)
Fastest is Hono
✨  Done in 30.77s.

Documentation

The documentation is available on honojs.dev.

Migration

Migration guide is available on docs/MIGRATION.md.

Communication

Twitter and Discord channel are available.

Contributing

Contributions Welcome! You can contribute in the following ways.

  • Create an Issue - Propose a new feature. Report a bug.
  • Pull Request - Fix a bug and typo. Refactor the code.
  • Create third-party middleware - Instruct below.
  • Share - Share your thoughts on the Blog, Twitter, and others.
  • Make your application - Please try to use Hono.

For more details, see docs/CONTRIBUTING.md.

Contributors

Thanks to all contributors! Especially, @metrue and @usualoma!

Author

Yusuke Wada https://github.com/yusukebe

License

Distributed under the MIT License. See LICENSE for more information.