The fastest HTTP/2 Go Web Framework. New, modern and easy to learn. Fast development with Code you control. Unbeatable cost-performance ratio 🚀
Go to file
Gerasimos (Makis) Maropoulos 52fab1bcc8
Some checks failed
CI / Test (1.23.x) (push) Successful in 15m44s
CodeQL / Analyze (go) (push) Failing after 5m13s
Happy new year everyone🎅
2025-01-01 03:40:30 +02:00
_benchmarks update view benchmarks and remove ace template parser 2023-03-17 12:38:07 +02:00
_examples update dependencies 2024-12-05 02:09:59 +02:00
_proposals minor improvements 2024-01-20 20:32:56 +02:00
.github rest json errors: handle unspported NaN values as the standard package's error doesn't give us more information 2024-09-13 11:52:03 +03:00
apps apps.Switch/Hosts minor doc improvement 2023-11-16 03:06:06 +02:00
auth auth package: export ExtractAccessToken method 2023-11-08 11:45:23 +02:00
cache update core deps 2023-10-12 20:09:54 +03:00
context minor 2024-04-24 18:41:24 +03:00
core errgroup: remove redundant len check (#2354) 2024-04-25 01:13:03 +03:00
hero add Party.HandleServer and macro.IsMacro methods 2023-12-06 01:09:43 +02:00
httptest release version 12.2.10 2024-01-18 03:11:54 +02:00
i18n rename master branch to main 2023-08-20 03:12:46 +03:00
macro minor improvements 2024-01-20 20:32:56 +02:00
middleware new app.MiddlewareExists method 2024-01-21 17:16:59 +02:00
mvc rename master branch to main 2023-08-20 03:12:46 +03:00
sessions upgrade badger db from v2 to v4 2024-09-26 15:48:20 +03:00
versioning fix #2158 and more 2023-07-08 02:08:18 +03:00
view add FS func in HTMLEngine (#2304) 2023-12-13 00:01:10 +02:00
websocket add Configuration.URLParamSeparator 2022-11-29 10:49:49 +02:00
x new x/jsonx season type 2024-09-20 00:59:27 +03:00
.deepsource.toml add a new _proposals folder and a silly idea 2022-04-10 01:08:11 +03:00
.fossa.yml new Application.SetContextErrorHandler method 2022-04-13 01:00:53 +03:00
.gitattributes minor 2020-01-05 18:27:21 +02:00
.gitignore Added support for third party packages on httptest package with tests & example. (#1992) 2022-10-22 18:02:55 +03:00
aliases.go x/jsonx: ISO8601: add support for unconventional offset timestamps 2024-05-23 15:23:29 +03:00
AUTHORS Update to version 8.5.5 | Read HISTORY.md 2017-11-02 05:54:33 +02:00
cli.go add support for embed.FS 2022-09-19 01:15:38 +03:00
CODE_OF_CONDUCT.md Update to version 8.5.5 | Read HISTORY.md 2017-11-02 05:54:33 +02:00
configuration_test.go release version 12.2.10 2024-01-18 03:11:54 +02:00
configuration.go release version 12.2.10 2024-01-18 03:11:54 +02:00
context_wrapper.go release v12.2.8 2023-11-05 22:20:20 +02:00
CONTRIBUTING.md rename master branch to main 2023-08-20 03:12:46 +03:00
doc.go rest json errors: handle unspported NaN values as the standard package's error doesn't give us more information 2024-09-13 11:52:03 +03:00
FAQ.md rename master branch to main 2023-08-20 03:12:46 +03:00
go.mod update dependencies 2024-12-28 14:20:51 +02:00
go.sum update dependencies 2024-12-28 14:20:51 +02:00
HISTORY.md release v12.2.11 2024-04-25 01:32:28 +03:00
iris_guide.go new app.MiddlewareExists method 2024-01-21 17:16:59 +02:00
iris.go release v12.2.11 2024-04-25 01:32:28 +03:00
LICENSE Happy New Year To Everyone! 🎅 2023-12-31 18:56:14 +02:00
NOTICE fix #2098 2023-03-20 18:16:35 +02:00
README_ES.md release v12.2.11 2024-04-25 01:32:28 +03:00
README_FA.md release v12.2.11 2024-04-25 01:32:28 +03:00
README_FR.md release v12.2.11 2024-04-25 01:32:28 +03:00
README_GR.md release v12.2.11 2024-04-25 01:32:28 +03:00
README_JA.md release v12.2.11 2024-04-25 01:32:28 +03:00
README_KO.md release v12.2.11 2024-04-25 01:32:28 +03:00
README_PT_BR.md release v12.2.11 2024-04-25 01:32:28 +03:00
README_RU.md release v12.2.11 2024-04-25 01:32:28 +03:00
README_VN.md release v12.2.11 2024-04-25 01:32:28 +03:00
README_ZH_HANS.md release v12.2.11 2024-04-25 01:32:28 +03:00
README_ZH_HANT.md release v12.2.11 2024-04-25 01:32:28 +03:00
README_ZH.md add Japanese README (#2188) 2023-08-14 11:56:02 +03:00
README.md Happy new year everyone🎅 2025-01-01 03:40:30 +02:00
SECURITY.md rename master branch to main 2023-08-20 03:12:46 +03:00
VERSION v12.2.0 2023-03-11 22:37:55 +02:00

Happy New Year 🎅

Dear Iris Community,

You might have noticed a recent lull in activity on the Iris repository, but this silence has a purpose. For the past 6-7 months, I've been working diligently on the next major release of Iris, fully embracing Generics and introducing a suite of new features, enhancements, and optimizations. My 8 years of Go experience guide this evolution, ensuring Iris grows with your needs.

As we welcome 2025, let's unite in peace, celebrate good health, and look forward to brighter horizons. Thank you for your continued support and patience. May this year bring new beginnings for us all.

Warm regards,
Gerasimos (Makis) Maropoulos

Iris Web Framework

build status view examples chat 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.

Learn what others saying about Iris and star this open-source project to support its potentials.

Benchmarks: Jul 18, 2020 at 10:46am (UTC)

package main

import "github.com/kataras/iris/v12"

func main() {
  app := iris.New()
  app.Use(iris.Compression)

  app.Get("/", func(ctx iris.Context) {
    ctx.HTML("Hello <strong>%s</strong>!", "World")
  })

  app.Listen(":8080")
}

As one Go developer once said, Iris got you covered all-round and standing strong over the years.

Some of the features Iris offers:

  • HTTP/2 (Push, even Embedded data)
  • Middleware (Accesslog, Basicauth, CORS, gRPC, Anti-Bot hCaptcha, JWT, MethodOverride, ModRevision, Monitor, PPROF, Ratelimit, Anti-Bot reCaptcha, Recovery, RequestID, Rewrite)
  • API Versioning
  • Model-View-Controller
  • Websockets
  • gRPC
  • Auto-HTTPS
  • Builtin support for ngrok to put your app on the internet, the fastest way
  • Unique Router with dynamic path as parameter with standard types like :uuid, :string, :int... and the ability to create your own
  • Compression
  • View Engines (HTML, Django, Handlebars, Pug/Jade and more)
  • Create your own File Server and host your own WebDAV server
  • Cache
  • Localization (i18n, sitemap)
  • Sessions
  • Rich Responses (HTML, Text, Markdown, XML, YAML, Binary, JSON, JSONP, Protocol Buffers, MessagePack, Content Negotiation, Streaming, Server-Sent Events and more)
  • Response Compression (gzip, deflate, brotli, snappy, s2)
  • Rich Requests (Bind URL Query, Headers, Form, Text, XML, YAML, Binary, JSON, Validation, Protocol Buffers, MessagePack and more)
  • Dependency Injection (MVC, Handlers, API Routers)
  • Testing Suite
  • And the most important... you get fast answers and support from the 1st day until now - that's six full years!

👑 Supporters

With your help, we can improve Open Source web development for everyone!

getsentry github lensesio thepunterbot h4rdc0m draFWM gf3 trading-peter AlbinoGeek basilarchia sumjoe simpleittools xiaozhuai Remydeme celsosz linxcoder jnelle TechMaster janwebdev altafino jakoubek alekperos day0ng hengestone thomasfr code-chimp CetinBasoz International Juanses SometimesMage ansrivas boreevyuri brentwilson camilbinas ekobayong lexrus li3p madhu72 mosorize se77en tstangenberg vincent-li DavidShaw sascha11110 clichi2002 derReineke Sirisap22 primadi agoncecelia chrisliang12 zyu hobysmith pluja antonio-pedrazzini clacroix njeff3 ixalender mubariz-ahmed Cesar th31nitiate stgrosshh Didainius DmarshalTU IwateKyle Little-YangYang Major2828 MatejLach amritpal042 andrefiorot boomhut cshum dtrifonov gadokrisztian geordee guanting112 iantuan ichenhe rodrigoghm icibiri jewe11er jfloresremar jingtianfeng kilarusravankumar leandrobraga lfbos lpintes macropas marcmmx mark2b miguel-devs mihado mmckeen75 narven odas0r olaf-lexemo pitexplore pr123 rsousacode sankethpb wixregiga GeorgeFourikis saz59 shadowfiga siriushaha skurtz97 srinivasganti syrm tuhao1020 BlackHole1 L-M-Sherlock claudemuller keymanye wahyuief xuyan2018 xvalen xytis ElNovi IpastorSan KKP4 Lernakow ernestocolombo francisstephan pixelheresy rcapraro soiestad spkarason thanasolykos ukitzmann DanielKirkwood colinf simonproctor FernandoLangOFC Firdavs9512 Flammable-Duck Gepetdo Hongjian0619 JoeD Jude-X Kartoffelbot KevinZhouRafael KrishManohar Laotanling Longf99999 Lyansun MihaiPopescu1985 TBNilles ajanicij aprinslo1 Mohammed8960 NA Neulhan kyoukhana spazzymoto victorgrey ArishSultan ehayun kukaki oshirokazuhide t6tg 15189573255 AGPDev AnatolyUA AwsIT NguyenPhuoc Oka00 PaddyFrenchman RainerGevers Ramblestsad SamuelNeves Scorpio69t Serissa4000 TianJIANG Ubun1 WangYajun39 XinYoungCN YukinaMochizuki a112121788 acdias aeonsthorn agent3bood ajb-neodynamics-io alessandromarotta algobot76 algoflows angelaahhu anhxuanpham annieruci antoniejiao artman328 b2cbd baoch254 bastengao beytullahakyuz bjoroen blackHoleNgc1277 bunnycodego carlos-enginner centratelemedia chrismalek civicwar cnzhangquan cuong48d damiensy danlanxiaohei dextercai dfaugusto dkzhang dloprodu donam-givita dph0899 dvitale ec0629 edwindna2 ekiyooka ekofedriyanto eli-yip eljefedelrodeodeljefe fenriz07 ffelipelimao frenchmajesty gastropulgite geGao123 globalflea gloudx gnosthi gogoswift goten002 guanzi008 hdezoscar93 hieungm hieunmg homerious hzxd inyellowbus iuliancarnaru iysaleh jackptoke jackysywk jeff2go jeremiahyan joelywz kamolcu kana99 edsongley katsubushiken kattaprasanth keeio keval6706 khasanovrs kkdaypenny knavels kohakuhubo korowiov kostasvk lafayetteDan lbsubash leki75 lemuelroberto liheyuan lingyingtan linuxluigi lipatti maikelcoke marek-kuticka marman-hp mattbowen maxgozou maxgozzz mitas mizzlespot mkell43 mnievesco mo3lyana motogo mtrense mukunhao mulyawansentosa nasoma ngseiyu nikharsaxena nronzel odelanno onlysumitg xPoppa yesudeep ymonk yonson2 yshengliao ytxmobile98 yusong-offx zhenggangpku zou8944 SergeShin - BelmonduS Diewald cty4ka martinjanda evan hazmi-e205 jtgoral ky2s lauweliam ozfive paulcockrell paulxu21 pesquive petros9282 phil535 pitt134 poscard qiepeipei qiuzhanghua rapita rbondi relaera remopavithran rfunix rhernandez-itemsoft rikoriswandha risallaw robivictor rubiagatra rubyangxg rxrw saleebm sbenimeli sebyno seun-otosho shobhitsinghal77 solohiroshi su1gen sukiejosh suresh16671 svirmi terjelafton thiennguyen93 unixedia vadgun valsorym vguhesan vpiduri vrocadev vuhoanglam walter-wang martinlindhe mdamschen letmestudy michaelsmanley Curtman SridarDhandapani madrigaltenor opusmagna ShahramMebashar b4zz4r bobmcallan fangli galois-tnp mblandr midhubalan netbaalzovf oliverjosefzimmer peacememories talebisinan valkuere lfaynman ArturWierzbicki aaxx crashCoder derekslenk dochoaj evillgenius75 gog200921 mauricedcastro mwiater sj671 statik supersherm5 thejones CSRaghunandan ndimorle rosales-stephanie shyyawn vcruzato wangbl11 wofka72 geoshan juanxme nguyentamvinhlong yoru74 xsokev oleang michalsz pomland-94 tejzpr theantichris tuxaanand raphael-brand willypuzzle dmcbane malcolm-white-dti HieuLsw carlosmoran092 yangxianglong

📖 Learning Iris

Installation

The only requirement is the Go Programming Language.

Create a new project

$ mkdir myapp
$ cd myapp
$ go mod init myapp
$ go get github.com/kataras/iris/v12@latest # or @v12.2.11
Install on existing project
$ cd myapp
$ go get github.com/kataras/iris/v12@latest

Run

$ go mod tidy -compat=1.23 # -compat="1.23" for windows.
$ go run .

Iris contains extensive and thorough documentation making it easy to get started with the framework.

For a more detailed technical documentation you can head over to our godocs. And for executable code you can always visit the ./_examples repository's subdirectory.

Do you like to read while traveling?

Book cover

follow author on twitter

follow Iris web framework on twitter

follow Iris web framework on facebook

You can request 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 file.

List of all Contributors

🛡 Security Vulnerabilities

If you discover a security vulnerability within Iris, please send an e-mail to iris-go@outlook.com. All security vulnerabilities will be promptly addressed.

📝 License

This project is licensed under the BSD 3-clause license, just like the Go project itself.

The project name "Iris" was inspired by the Greek mythology.