[![Black Lives Matter](https://iris-go.com/images/blacklivesmatter_banner.png)](https://support.eji.org/give/153413/#!/donation/checkout) # News > This is the under-**development branch** - contains the latest and greatest features. Stay tuned for the upcoming release [v12.2.0](HISTORY.md#Next). Looking for a more stable release? Head over to the [v12.1.8 branch](https://github.com/kataras/iris/tree/v12.1.8) instead. > > ![](https://iris-go.com/images/cli.png) Try the official [Iris Command Line Interface](https://github.com/kataras/iris-cli) today! > Due to the large workload, there may be delays in answering your [questions](https://github.com/kataras/iris/issues). # Iris Web Framework [![build status](https://img.shields.io/github/workflow/status/kataras/iris/CI/master?style=for-the-badge)](https://github.com/kataras/iris/actions) [![view examples](https://img.shields.io/badge/examples%20-253-a83adf.svg?style=for-the-badge&logo=go)](https://github.com/kataras/iris/tree/master/_examples) [![chat](https://img.shields.io/gitter/room/iris_go/community.svg?color=cc2b5e&logo=gitter&style=for-the-badge)](https://gitter.im/iris_go/community) [![donate](https://img.shields.io/badge/support-Iris-blue.svg?style=for-the-badge&logo=paypal)](https://iris-go.com/donate) Iris is a fast, simple yet fully featured and very efficient web framework for Go. It provides a beautifully expressive and easy to use foundation for your next website or API.
Simple Handler ```go package main import "github.com/kataras/iris/v12" type ( request struct { Firstname string `json:"firstname"` Lastname string `json:"lastname"` } response struct { ID string `json:"id"` Message string `json:"message"` } ) func main() { app := iris.New() app.Handle("PUT", "/users/{id:uuid}", updateUser) app.Listen(":8080") } func updateUser(ctx iris.Context) { id, _ := ctx.Params().Get("id") var req request if err := ctx.ReadJSON(&req); err != nil { ctx.StopWithError(iris.StatusBadRequest, err) return } resp := response{ ID: id, Message: req.Firstname + " updated successfully", } ctx.JSON(resp) } ``` > Read the [routing examples](https://github.com/kataras/iris/blob/master/_examples/routing) for more!
Handler with custom input and output arguments [![https://github.com/kataras/iris/blob/master/_examples/dependency-injection/basic/main.go](https://user-images.githubusercontent.com/22900943/105253731-b8db6d00-5b88-11eb-90c1-0c92a5581c86.png)](https://twitter.com/iris_framework/status/1234783655408668672) > Interesting? Read the [examples](https://github.com/kataras/iris/blob/master/_examples/dependency-injection).
Party Controller (NEW) > Head over to the [full running example](https://github.com/kataras/iris/blob/master/_examples/routing/party-controller)!
MVC ```go package main import ( "github.com/kataras/iris/v12" "github.com/kataras/iris/v12/mvc" ) type ( request struct { Firstname string `json:"firstname"` Lastname string `json:"lastname"` } response struct { ID uint64 `json:"id"` Message string `json:"message"` } ) func main() { app := iris.New() mvc.Configure(app.Party("/users"), configureMVC) app.Listen(":8080") } func configureMVC(app *mvc.Application) { app.Handle(new(userController)) } type userController struct { // [...dependencies] } func (c *userController) PutBy(id uint64, req request) response { return response{ ID: id, Message: req.Firstname + " updated successfully", } } ``` Want to see more? Navigate through [mvc examples](_examples/mvc)!
Learn what [others saying about Iris](https://www.iris-go.com/#review) and **[star](https://github.com/kataras/iris/stargazers)** this open-source project to support its potentials. [![](https://iris-go.com/images/reviews.gif)](https://iris-go.com/testimonials/) [![Benchmarks: Jul 18, 2020 at 10:46am (UTC)](https://iris-go.com/images/benchmarks.svg)](https://github.com/kataras/server-benchmarks) ## πŸ‘‘ Supporters With your help, we can improve Open Source web development for everyone! > Donations from **China** are now accepted!

lensesio trading-peter gf3 basilarchia xiaozhuai AlbinoGeek celsosz TechMaster altafino hengestone thomasfr li3p sumjoe se77en International Juanses ansrivas vincent-li lexrus sascha11110 derReineke Sirisap22 clacroix mubariz-ahmed ixalender rodrigoghm tuhao1020 sankethpb mihado cshum lpintes wahyuief icibiri dtrifonov kilarusravankumar mmckeen75 IwateKyle shadowfiga DmarshalTU DavidShaw lfbos Cesar srinivasganti olaf-lexemo skurtz97 marcmmx jingtianfeng leandrobraga macropas xytis saz59 coderperu Little-YangYang xvalen pr123 pitexplore odas0r KKP4 ukitzmann Lernakow syrm Major2828 MatejLach ElNovi siriushaha spazzymoto aprinslo1 kyoukhana mark2b t6tg kukaki oshirokazuhide hzxd vladimir-petukhov-sr nasoma mizzlespot guanzi008 ichenhe mnievesco AwsIT agent3bood vuhoanglam TianJIANG BlackHole1 Jude-X remopavithran motogo rhernandez-itemsoft KevinZhouRafael carlos-enginner svirmi saleebm mulyawansentosa rapita kana99 fenriz07 paulxu21 gnosthi mattbowen hdezoscar93 Neulhan knavels liheyuan MihaiPopescu1985 lingyingtan baoch254 risallaw NguyenPhuoc edwindna2 Ubun1 bunnycodego vguhesan pitt134 leki75 yonson2 sbenimeli khasanovrs lipatti cnzhangquan unixedia rxrw SamuelNeves qiuzhanghua Laotanling iantuan draFWM civicwar bastengao goten002 ozfive acdias b2cbd rfunix SergeShin martinlindhe netbaalzovf mtrense blackHoleNgc1277 lfaynman rbondi gog200921 crashCoder RainerGevers nikharsaxena NA aaxx statik ArturWierzbicki thejones dochoaj vcruzato hazmi-e205 wangbl11 shyyawn CSRaghunandan evan mblandr letmestudy primadi ky2s grassshrimp GeorgeFourikis edsongley jtgoral L-M-Sherlock wofka72 xsokev ndimorle lauweliam oleang michalsz Curtman claudemuller SridarDhandapani midhubalan rosales-stephanie opusmagna b4zz4r juanxme galois-tnp fangli tejzpr theantichris tuxaanand nguyentamvinhlong bobmcallan geoshan narven raphael-brand Tang634724712 HieuLsw carlosmoran092 yangxianglong

## πŸ“– Learning Iris ### Create a new project ```sh $ mkdir myapp $ cd myapp $ go mod init myapp $ go get github.com/kataras/iris/v12@master # or @v12.2.0-beta1 ```
Install on existing project ```sh $ cd myapp $ go get github.com/kataras/iris/v12@master ``` **Run** ```sh $ go mod tidy -compat=1.18 $ go run . ```
![](https://www.iris-go.com/images/gifs/install-create-iris.gif) Iris contains extensive and thorough **[documentation](https://www.iris-go.com/docs)** making it easy to get started with the framework. For a more detailed technical documentation you can head over to our [godocs](https://pkg.go.dev/github.com/kataras/iris/v12@master). And for executable code you can always visit the [./_examples](_examples) repository's subdirectory. ### Do you like to read while traveling? Book cover [![follow author on twitter](https://img.shields.io/twitter/follow/makismaropoulos?color=3D8AA3&logoColor=3D8AA3&style=for-the-badge&logo=twitter)](https://twitter.com/intent/follow?screen_name=makismaropoulos) [![follow Iris web framework on twitter](https://img.shields.io/twitter/follow/iris_framework?color=ee7506&logoColor=ee7506&style=for-the-badge&logo=twitter)](https://twitter.com/intent/follow?screen_name=iris_framework) [![follow Iris web framework on facebook](https://img.shields.io/badge/Follow%20%40Iris.framework-522-2D88FF.svg?style=for-the-badge&logo=facebook)](https://www.facebook.com/iris.framework) You can [request](https://www.iris-go.com/#ebookDonateForm) a PDF and online access of the **Iris E-Book** (New Edition, **future v12.2.0+**) today and be participated in the development of Iris. ## πŸ™Œ Contributing We'd love to see your contribution to the Iris Web Framework! For more information about contributing to the Iris project please check the [CONTRIBUTING.md](CONTRIBUTING.md) file. [List of all Contributors](https://github.com/kataras/iris/graphs/contributors) ## πŸ›‘ Security Vulnerabilities If you discover a security vulnerability within Iris, please send an e-mail to [iris-go@outlook.com](mailto:iris-go@outlook.com). All security vulnerabilities will be promptly addressed. ## πŸ“ License This project is licensed under the [BSD 3-clause license](LICENSE), just like the Go project itself. The project name "Iris" was inspired by the Greek mythology.