2018-06-05 00:24:35 +02:00
# Iris Web Framework <a href="README_ZH.md"> <img width="20px" src="https://iris-go.com/images/flag-china.svg?v=10" /></a> <a href="README_RU.md"><img width="20px" src="https://iris-go.com/images/flag-russia.svg?v=10" /></a> <a href="README_ID.md"> <img width="20px" src="https://iris-go.com/images/flag-indonesia.svg?v=10" /></a> <a href="README_GR.md"><img width="20px" src="https://iris-go.com/images/flag-greece.svg?v=10" /></a> <a href="README_PT_BR.md"><img width="20px" src="https://iris-go.com/images/flag-pt-br.svg?v=10" /></a> <a href="README_JPN.md"><img width="20px" src="https://iris-go.com/images/flag-japan.svg?v=10" /></a>
2017-12-18 06:22:55 +01:00
2018-02-12 05:10:57 +01:00
< a href = "https://iris-go.com" > < img align = "right" width = "169px" src = "https://iris-go.com/images/icon.svg?v=a" title = "logo created by @merry .dii" /> </ a >
2017-12-18 06:22:55 +01:00
2018-04-22 15:22:24 +02:00
[![build status ](https://img.shields.io/travis/kataras/iris/master.svg?style=flat-square )](https://travis-ci.org/kataras/iris)<!-- [![release ](https://img.shields.io/github/release/kataras/iris.svg?style=flat-square )](https://github.com/kataras/iris/releases)--> [![report card ](https://img.shields.io/badge/report%20card-a%2B-ff3333.svg?style=flat-square )](http://goreportcard.com/report/kataras/iris) [![vscode-iris ](https://img.shields.io/badge/ext%20-vscode-0c77e3.svg?style=flat-square )](https://marketplace.visualstudio.com/items?itemName=kataras2006.iris)<!--[![github closed issues](https://img.shields.io/github/issues-closed-raw/kataras/iris.svg?style=flat-square)](https://github.com/kataras/iris/issues?q=is%3Aissue+is%3Aclosed)--> [![chat ](https://img.shields.io/badge/community-%20chat-00BCD4.svg?style=flat-square )](https://kataras.rocket.chat/channel/iris) [![view examples ](https://img.shields.io/badge/learn%20by-examples-0077b3.svg?style=flat-square )](https://iris-go.com/v10/recipe) [![release ](https://img.shields.io/badge/release%20-v10.6-0077b3.svg?style=flat-square )](https://github.com/kataras/iris/releases)
2017-12-18 06:22:55 +01:00
2017-12-30 19:40:52 +01:00
Iris is a fast, simple yet fully featured and very efficient web framework for Go.
2017-12-18 06:22:55 +01:00
2017-12-30 19:40:52 +01:00
Iris provides a beautifully expressive and easy to use foundation for your next website or API.
2017-12-18 06:22:55 +01:00
2017-12-30 19:40:52 +01:00
Finally, a real expressjs equivalent for the Go Programming Language.
2017-11-07 00:55:24 +01:00
2017-12-30 19:40:52 +01:00
Learn what [others say about Iris ](#support ) and [star ](https://github.com/kataras/iris/stargazers ) this github repository to stay [up to date ](https://facebook.com/iris.framework ).
2017-11-02 04:54:33 +01:00
2017-12-30 19:40:52 +01:00
## Backers
2017-11-02 04:54:33 +01:00
2018-02-12 03:04:46 +01:00
Thank you to all our backers! 🙏 [Become a backer ](https://iris-go.com/donate )
2017-12-30 19:40:52 +01:00
2018-04-22 12:52:36 +02:00
< a href = "https://iris-go.com/donate" target = "_blank" > < img src = "https://iris-go.com/backers.svg?v=2" / > < / a >
2017-12-30 19:40:52 +01:00
2017-12-31 05:45:12 +01:00
```sh
2018-07-23 14:58:55 +02:00
$ cat _examples/cookies/basic/main.go
2017-12-31 05:45:12 +01:00
```
```go
package main
import "github.com/kataras/iris"
2018-07-23 14:58:55 +02:00
func newApp() *iris.Application {
2017-12-31 05:45:12 +01:00
app := iris.New()
2018-07-23 14:58:55 +02:00
// Set A Cookie.
app.Get("/cookies/{name}/{value}", func(ctx iris.Context) {
name := ctx.Params().Get("name")
value := ctx.Params().Get("value")
ctx.SetCookieKV(name, value)
ctx.Writef("cookie added: %s = %s", name, value)
2017-12-31 05:45:12 +01:00
})
2018-07-23 14:58:55 +02:00
// Retrieve A Cookie.
app.Get("/cookies/{name}", func(ctx iris.Context) {
name := ctx.Params().Get("name")
value := ctx.GetCookie(name)
ctx.WriteString(value)
2017-12-31 05:45:12 +01:00
})
2018-07-23 14:58:55 +02:00
// Delete A Cookie.
app.Delete("/cookies/{name}", func(ctx iris.Context) {
name := ctx.Params().Get("name")
ctx.RemoveCookie(name)
ctx.Writef("cookie %s removed", name)
})
return app
}
func main() {
app := newApp()
// GET: http://localhost:8080/cookies/my_name/my_value
// GET: http://localhost:8080/cookies/my_name
// DELETE: http://localhost:8080/cookies/my_name
2017-12-31 05:45:12 +01:00
app.Run(iris.Addr(":8080"))
}
```
2018-07-23 14:58:55 +02:00
* Alternatively, use a regular `http.Cookie` : `ctx.SetCookie(&http.Cookie{...})`
* If you want to set custom the path: `ctx.SetCookieKV(name, value, iris.CookiePath("/custom/path/cookie/will/be/stored"))` .
* If you want to be available only to the current request path: `ctx.SetCookieKV(name, value, iris.CookieCleanPath /* or iris.CookiePath("") */)`
* `iris.CookieExpires(time.Duration)`
* `iris.CookieHTTPOnly(false)`
* `ctx.Request().Cookie(name)` is also available, it's the `net/http` approach
* Learn more about path parameter's types by clicking [here ](_examples/routing/dynamic-path/main.go#L31 ).
### Testing your Application? Easy with Iris
```go
package main
import (
"fmt"
"testing"
"github.com/kataras/iris/httptest"
)
// go test -v -run=TestCookiesBasic$
func TestCookiesBasic(t *testing.T) {
app := newApp()
e := httptest.New(t, app, httptest.URL("http://example.com"))
cookieName, cookieValue := "my_cookie_name", "my_cookie_value"
// Test Set A Cookie.
t1 := e.GET(fmt.Sprintf("/cookies/%s/%s", cookieName, cookieValue)).Expect().Status(httptest.StatusOK)
t1.Cookie(cookieName).Value().Equal(cookieValue) // validate cookie's existence, it should be there now.
t1.Body().Contains(cookieValue)
path := fmt.Sprintf("/cookies/%s", cookieName)
// Test Retrieve A Cookie.
t2 := e.GET(path).Expect().Status(httptest.StatusOK)
t2.Body().Equal(cookieValue)
// Test Remove A Cookie.
t3 := e.DELETE(path).Expect().Status(httptest.StatusOK)
t3.Body().Contains(cookieName)
t4 := e.GET(path).Expect().Status(httptest.StatusOK)
t4.Cookies().Empty()
t4.Body().Empty()
}
2017-12-31 05:45:12 +01:00
```
2018-07-23 14:58:55 +02:00
### Serve your Application
2017-12-31 05:45:12 +01:00
```sh
2018-07-23 14:58:55 +02:00
$ go run main.go
2017-12-31 05:45:12 +01:00
Now listening on: http://localhost:8080
Application Started. Press CTRL+C to shut down.
_
```
2017-12-30 19:40:52 +01:00
## Installation
The only requirement is the [Go Programming Language ](https://golang.org/dl/ )
2017-11-02 04:54:33 +01:00
2017-12-30 19:40:52 +01:00
```sh
$ go get -u github.com/kataras/iris
```
Iris takes advantage of the [vendor directory ](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo ) feature. You get truly reproducible builds, as this method guards against upstream renames and deletes.
2017-11-02 04:54:33 +01:00
2017-12-24 05:24:45 +01:00
[![Iris vs .NET Core(C#) vs Node.js (Express) ](https://iris-go.com/images/benchmark-new-gray.png )](_benchmarks/README_UNIX.md)
2017-11-02 04:54:33 +01:00
2017-12-30 19:40:52 +01:00
_Updated at: [Tuesday, 21 November 2017 ](_benchmarks/README_UNIX.md )_
2017-11-02 04:54:33 +01:00
< details >
< summary > Benchmarks from third-party source over the rest web frameworks< / summary >
![Comparison with other frameworks ](https://raw.githubusercontent.com/smallnest/go-web-framework-benchmark/4db507a22c964c9bc9774c5b31afdc199a0fe8b7/benchmark.png )
< / details >
2017-12-30 19:40:52 +01:00
## Support
2017-11-02 04:54:33 +01:00
2018-06-05 00:24:35 +02:00
- [HISTORY ](HISTORY.md#tu-05-june-2018--v1066 ) file is your best friend, it contains information about the latest features and changes
2017-12-30 19:40:52 +01:00
- Did you happen to find a bug? Post it at [github issues ](https://github.com/kataras/iris/issues )
- Do you have any questions or need to speak with someone experienced to solve a problem at real-time? Join us to the [community chat ](https://chat.iris-go.com )
2018-02-08 13:04:39 +01:00
- Complete our form-based user experience report by clicking [here ](https://docs.google.com/forms/d/e/1FAIpQLSdCxZXPANg_xHWil4kVAdhmh7EBBHQZ_4_xSZVDL-oCC_z5pA/viewform?usp=sf_link )
2017-12-30 19:40:52 +01:00
- Do you like the framework? Tweet something about it! The People have spoken:
2017-11-02 04:54:33 +01:00
2017-12-30 19:40:52 +01:00
< a href = "https://twitter.com/gelnior/status/769100480706379776" >
< img src = "https://comments.iris-go.com/comment27_mini.png" width = "350px" >
< / a >
2017-11-02 04:54:33 +01:00
2017-12-30 19:40:52 +01:00
< a href = "https://twitter.com/MeAlex07/status/822799954188075008" >
< img src = "https://comments.iris-go.com/comment28_mini.png" width = "350px" >
< / a >
< a href = "https://twitter.com/_mgale/status/818591490305761280" >
< img src = "https://comments.iris-go.com/comment29_mini.png" width = "350px" >
< / a >
< a href = "https://twitter.com/VeayoX/status/813273328550973440" >
< img src = "https://comments.iris-go.com/comment30_mini.png" width = "350px" >
< / a >
2017-11-02 04:54:33 +01:00
2017-12-30 19:40:52 +01:00
< a href = "https://twitter.com/pvsukale/status/745328224876408832" >
< img src = "https://comments.iris-go.com/comment31_mini.png" width = "350px" >
< / a >
2017-11-02 04:54:33 +01:00
2017-12-30 19:40:52 +01:00
< a href = "https://twitter.com/blainsmith/status/745338092211560453" >
< img src = "https://comments.iris-go.com/comment32_mini.png" width = "350px" >
< / a >
2017-11-02 04:54:33 +01:00
2017-12-30 19:40:52 +01:00
< a href = "https://twitter.com/tjbyte/status/758287014210867200" >
< img src = "https://comments.iris-go.com/comment33_mini.png" width = "350px" >
< / a >
2017-11-02 04:54:33 +01:00
2017-12-30 19:40:52 +01:00
< a href = "https://twitter.com/tangzero/status/751050577220698112" >
< img src = "https://comments.iris-go.com/comment34_mini.png" width = "350px" >
< / a >
< a href = "https://twitter.com/tjbyte/status/758287244947972096" >
< img src = "https://comments.iris-go.com/comment33_2_mini.png" width = "350px" >
< / a >
< a href = "https://twitter.com/ferarias/status/902468752364773376" >
< img src = "https://comments.iris-go.com/comment41.png" width = "350px" >
< / a >
2017-12-31 01:50:04 +01:00
< br / > < br / >
2017-12-30 19:40:52 +01:00
2017-12-31 01:42:26 +01:00
For more information about contributing to the Iris project please check the [CONTRIBUTING.md ](CONTRIBUTING.md ) file.
2017-12-30 19:40:52 +01:00
[List of all Contributors ](https://github.com/kataras/iris/graphs/contributors )
## Learn
First of all, the most correct way to begin with a web framework is to learn the basics of the programming language and the standard `http` capabilities, if your web application is a very simple personal project without performance and maintainability requirements you may want to proceed just with the standard packages. After that follow the guidelines:
- Navigate through **100+1** ** [examples ](_examples )** and some [iris starter kits ](#iris-starter-kits ) we crafted for you
- Read the [godocs ](https://godoc.org/github.com/kataras/iris ) for any details
2017-12-31 06:22:31 +01:00
- Prepare a cup of coffee or tea, whatever pleases you the most, and read some [articles ](#articles ) we found for you
2017-12-30 19:40:52 +01:00
### Iris starter kits
2018-06-05 00:24:35 +02:00
<!-- table form
2017-12-30 19:40:52 +01:00
| Description | Link |
| -----------|-------------|
| Hasura hub starter project with a ready to deploy golang helloworld webapp with IRIS! | https://hasura.io/hub/project/hasura/hello-golang-iris |
| A basic web app built in Iris for Go |https://github.com/gauravtiwari/go_iris_app |
| A mini social-network created with the awesome Iris💖💖 | https://github.com/iris-contrib/Iris-Mini-Social-Network |
| Iris isomorphic react/hot reloadable/redux/css-modules starter kit | https://github.com/iris-contrib/iris-starter-kit |
| Demo project with react using typescript and Iris | https://github.com/ionutvilie/react-ts |
| Self-hosted Localization Management Platform built with Iris and Angular | https://github.com/iris-contrib/parrot |
| Iris + Docker and Kubernetes | https://github.com/iris-contrib/cloud-native-go |
| Quickstart for Iris with Nanobox | https://guides.nanobox.io/golang/iris/from-scratch |
2017-12-31 01:32:28 +01:00
-->
1. [A basic web app built in Iris for Go ](https://github.com/gauravtiwari/go_iris_app )
2. [A mini social-network created with the awesome Iris💖💖 ](https://github.com/iris-contrib/Iris-Mini-Social-Network )
3. [Iris isomorphic react/hot reloadable/redux/css-modules starter kit ](https://github.com/iris-contrib/iris-starter-kit )
4. [Demo project with react using typescript and Iris ](https://github.com/ionutvilie/react-ts )
5. [Self-hosted Localization Management Platform built with Iris and Angular ](https://github.com/iris-contrib/parrot )
6. [Iris + Docker and Kubernetes ](https://github.com/iris-contrib/cloud-native-go )
7. [Quickstart for Iris with Nanobox ](https://guides.nanobox.io/golang/iris/from-scratch )
8. [A Hasura starter project with a ready to deploy Golang hello-world web app with IRIS ](https://hasura.io/hub/project/hasura/hello-golang-iris )
2017-12-30 19:40:52 +01:00
> Did you build something similar? Let us [know](https://github.com/kataras/iris/pulls)!
### Middleware
Iris has a great collection of handlers[[1]](middleware/)[[2]](https://github.com/iris-contrib/middleware) that you can use side by side with your web apps. However you are not limited to them - you are free to use any third-party middleware that is compatible with the [net/http ](https://golang.org/pkg/net/http/ ) package, [_examples/convert-handlers ](_examples/convert-handlers ) will show you the way.
2018-02-23 03:06:05 +01:00
Iris, unlike others, is 100% compatible with the standards and that's why the majority of the big companies that adapt Go to their workflow, like a very famous US Television Network, trust Iris; it's up-to-date and it will be always aligned with the std `net/http` package which is modernized by the Go Authors on each new release of the Go Programming Language.
2017-12-30 19:40:52 +01:00
### Articles
2018-01-09 03:37:23 +01:00
* [A Todo MVC Application using Iris and Vue.js ](https://hackernoon.com/a-todo-mvc-application-using-iris-and-vue-js-5019ff870064 )
2018-04-01 04:20:21 +02:00
* [A Hasura starter project with a ready to deploy Golang hello-world web app with IRIS ](https://bit.ly/2lmKaAZ )
2017-11-20 19:16:59 +01:00
* [Top 6 web frameworks for Go as of 2017 ](https://blog.usejournal.com/top-6-web-frameworks-for-go-as-of-2017-23270e059c4b )
2017-11-02 22:33:26 +01:00
* [Iris Go Framework + MongoDB ](https://medium.com/go-language/iris-go-framework-mongodb-552e349eab9c )
2017-11-02 04:54:33 +01:00
* [How to build a file upload form using DropzoneJS and Go ](https://hackernoon.com/how-to-build-a-file-upload-form-using-dropzonejs-and-go-8fb9f258a991 )
* [How to display existing files on server using DropzoneJS and Go ](https://hackernoon.com/how-to-display-existing-files-on-server-using-dropzonejs-and-go-53e24b57ba19 )
* [Iris, a modular web framework ](https://medium.com/@corebreaker/iris-web-cd684b4685c7 )
* [Go vs .NET Core in terms of HTTP performance ](https://medium.com/@kataras/go-vs-net-core-in-terms-of-http-performance-7535a61b67b8 )
* [Iris Go vs .NET Core Kestrel in terms of HTTP performance ](https://hackernoon.com/iris-go-vs-net-core-kestrel-in-terms-of-http-performance-806195dc93d5 )
* [How to Turn an Android Device into a Web Server ](https://twitter.com/ThePracticalDev/status/892022594031017988 )
* [Deploying a Iris Golang app in hasura ](https://medium.com/@HasuraHQ/deploy-an-iris-golang-app-with-backend-apis-in-minutes-25a559bf530b )
* [A URL Shortener Service using Go, Iris and Bolt ](https://medium.com/@kataras/a-url-shortener-service-using-go-iris-and-bolt-4182f0b00ae7 )
2018-04-22 15:22:24 +02:00
### Video Courses
* [Daily Coding - Web Framework Golang: Iris Framework ]( https://www.youtube.com/watch?v=BmOLFQ29J3s ) by WarnabiruTV, source: youtube, cost: **FREE**
* [Tutorial Golang MVC dengan Iris Framework & Mongo DB ](https://www.youtube.com/watch?v=uXiNYhJqh2I&list=PLMrwI6jIZn-1tzskocnh1pptKhVmWdcbS ) (19 parts so far) by Musobar Media, source: youtube, cost: **FREE**
* [Go/Golang 27 - Iris framework : Routage de base ](https://www.youtube.com/watch?v=rQxRoN6ub78 ) by stephgdesign, source: youtube, cost: **FREE**
* [Go/Golang 28 - Iris framework : Templating ](https://www.youtube.com/watch?v=nOKYV073S2Y ) by stephgdesignn, source: youtube, cost: **FREE**
* [Go/Golang 29 - Iris framework : Paramètres ](https://www.youtube.com/watch?v=K2FsprfXs1E ) by stephgdesign, source: youtube, cost: **FREE**
* [Go/Golang 30 - Iris framework : Les middelwares ](https://www.youtube.com/watch?v=BLPy1So6bhE ) by stephgdesign, source: youtube, cost: **FREE**
* [Go/Golang 31 - Iris framework : Les sessions ](https://www.youtube.com/watch?v=RnBwUrwgEZ8 ) by stephgdesign, source: youtube, cost: **FREE**
2017-12-30 19:40:52 +01:00
### Get hired
There are many companies and start-ups looking for Go web developers with Iris experience as requirement, we are searching for you every day and we post those information via our [facebook page ](https://www.facebook.com/iris.framework ), like the page to get notified, we have already posted some of them.
2017-11-02 04:54:33 +01:00
## License
2017-12-30 19:40:52 +01:00
Iris is licensed under the [3-Clause BSD License ](LICENSE ). Iris is 100% free and open-source software.
2017-11-02 04:54:33 +01:00
2017-12-30 19:40:52 +01:00
For any questions regarding the license please send [e-mail ](mailto:kataras2006@hotmail.com?subject=Iris%20License ).