热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Iris初试

官网:https:iris-go.com推荐文档:https:www.kancloud.cnadapago-web-iris1108131IrisMVC介绍什么是MVCModel(

 

官网:https://iris-go.com

推荐文档: https://www.kancloud.cn/adapa/go-web-iris/1108131


Iris MVC介绍



  • 什么是MVC

    Model(模型):它是应用程序的主体部分,主要包括业务的逻辑操作和数据模型
    View: 用户与之交互的界面
    Controller: 接受来自界面的请求并交给模型渲染

     MVC 工作流程:


    技术分享图片

  •  


    Iris MVC目录介绍

    ├── dataModels # 数据模型目录,主要放结构体,用以表示数据
    ├── go.mod
    ├── repositories #用以封装所有对数据库的操作,和dataModels中的表一一对应
    ├── service #models的业务逻辑放在service
    └── web
    ├── controllers #控制我们的请求
    └── views #存放模板
    └── main.go #项目入口



  • Iris MVC 人口文件 main.go, 下面我们通过简单的例子来介绍基本用法

    package main
    import "github.com/kataras/iris"
    func main() {
    app := iris.New() // 实例一个iris对象
    //配置路由
    app.Get("/", func(ctx iris.Context) {
    ctx.WriteString("Hello Iris")
    })
    app.Post("/", func(ctx iris.Context) {
    ctx.Write([]byte("Hello Iris"))
    })
    // 路由分组
    party := app.Party("/hello")
    // 此处它的路由地址是: /hello/world
    party.Get("/world", func(ctx iris.Context) {
    ctx.WriteString("hello world")
    })
    // 启动服务器
    app.Run(iris.Addr(":8085"),iris.WithCharset("UTF-8"))
    // 监听地址:本服务器上任意id端口8085,设置字符集utf8
    }



 

注意: 在go.mod 中导入的包, 如果能正常使用,但是goland飘好,可以采用以下方式


1. 在setting中 Go -> GOPATH -> 勾选Index entire GOPATH
2. 在环境变量中添加: GO111MODULE=on ; 在~/.bashrc 中添加 export ....
相关解释:可以用环境变量 GO111MODULE 开启或关闭模块支持,它有三个可选值:off、on、auto,默认: 1. GO111MODULE=off 无模块支持,go 会从 GOPATH 和 vendor 文件夹寻找包。
2. GO111MODULE=on 模块支持,go 会忽略 GOPATH 和 vendor 文件夹,只根据 go.mod 下载依赖。
3. GO111MODULE=auto 在 GOPATH/src 外面且根目录有 go.mod 文件时,开启模块支持。

 


路由部分



  • 普通路由

    package main
    import "github.com/kataras/iris"
    func main() {
    app := iris.New()
    //GET 方法
    app.Get("/", handler)
    // POST 方法
    app.Post("/", handler)
    // PUT 方法
    app.Put("/", handler)
    // DELETE 方法
    app.Delete("/", handler)
    //OPTIONS 方法
    app.Options("/", handler)
    //TRACE 方法
    app.Trace("/", handler)
    //CONNECT 方法
    app.Connect("/", handler)
    //HEAD 方法
    app.Head("/", handler)
    // PATCH 方法
    app.Patch("/", handler)
    //任意的http请求方法如option等
    app.Any("/", handler)
    app.Run(iris.Addr(":8085"),iris.WithCharset("UTF-8"))
    }
    // 处理函数
    func handler(ctx iris.Context) {
    ctx.Writef("methdo:%s path:%s",ctx.Method(),ctx.Path())
    }



  • 路由分组

    package main
    import "github.com/kataras/iris"
    func main() {
    app := iris.New()
    // 分组
    userRouter := app.Party("/user")
    // route: /user/{name}/home 例如:/user/dollarKiller/home
    userRouter.Get("/{name:string}/home", func(ctx iris.Context) {
    name := ctx.Params().Get("name") // 使用ctx请求对象中那参数
    ctx.Writef("you name: %s",name)
    })
    // route: /user/post
    userRouter.Post("/post", func(ctx iris.Context) {
    ctx.Writef("method:%s,path;%s",ctx.Method(),ctx.Path())
    })
    app.Run(iris.Addr(":8085"),iris.WithCharset("UTF-8"))
    }
    /*
    ctx.Params().Get() 获取参数
    ctx.Writef() 返回对象
    ctx.Method() 请求方式
    ctx.Path() 请求路径
    app.Party() 路由分组,路由派对
    */



  • 动态路由

    package main
    import "github.com/kataras/iris"
    func main() {
    app := iris.New()
    // 路由传参
    app.Get("/username/{name}", func(ctx iris.Context) {
    name := ctx.Params().Get("name")
    fmt.Println(name)
    })
    // 设置参数
    app.Get("/profile/{id:int min(1)}", func(ctx iris.Context) {
    i, e := ctx.Params().GetInt("id")
    if e != nil {
    ctx.WriteString("error you input")
    }
    ctx.WriteString(strconv.Itoa(i))
    })
    // 设置错误码
    app.Get("/profile/{id:int min(1)}/friends/{friendid:int max(8) else 504}", func(ctx iris.Context) {
    i, _ := ctx.Params().GetInt("id")
    getInt, _ := ctx.Params().GetInt("friendid")
    ctx.Writef("Hello id:%d looking for friend id: ",i,getInt)
    })// 如果没有传递所有路由的macros,这将抛出504错误代码而不是404.
    // 正则表达式
    app.Get("/lowercase/{name:string regexp(^[a-z]+)}", func(ctx iris.Context) {
    ctx.Writef("name should be only lowercase, otherwise this handler will never executed: %s", ctx.Params().Get("name"))
    })
    app.Run(iris.Addr(":8085"),iris.WithCharset("UTF-8"))
    }



 


简单的Web实例

目录结构:


├── dataModels # 数据中心
│   └── movice.go
├── go.mod # 包管理
├── go.sum
├── main.go # 程序入口
├── repositories # 数据管理组
│   └── movice_repositories.go # 数据管理员
├── service # 服务管理组
│   └── movie_server.go # 服务管理员
└── web
├── controllers # 逻辑中心
│   └── movice_controller.go # 请求的响应中心,通过服务管理员调度数据管理员调度数据
└── views # 模板中心
└── movie
└── index.html



  • movie.go 基础的数据, 对应数据库中的表等,使得数据库表结构可以映射到程序

    package dataModels
    // 数据
    type Movice struct {
    Name string
    }

     



  • movice_repositories.go 数据管理员, 接口数据库+数据中心的表结构映射,整理出各自的功能如.结合数据库的真是数据+基础表的程序代码结构, 使其可以ORM

    package repositories
    import "testIris/dataModels"
    // 需要实现的接口
    type MovieRepository interface {
    GetMovieName() string
    }
    // Movie 的封装类 数据管理员
    type MovieManager struct {
    }
    // 构造函数创建MovieManager, 返回的值的接口 由于MovieManager实现了这个接口
    func NewMovieManager() MovieRepository {
    return &MovieManager{}
    }
    func (m *MovieManager) GetMovieName() string {
    // 模拟已经从查询到数据
    movie := &dataModels.Movice{Name:"理查德姑妈"}
    return movie.Name
    }

     



  • movie_server.go 主要用来整理数据管理员的功能,同时在提供服务给controller

    package service
    import (
    "fmt"
    "testIris/repositories"
    )
    // 服务提供的接口,用来整合repositories, 服务管理员的功能接口
    type MovieServer interface {
    ShowMoviceName() string
    }
    // 服务管理员, 用来管理数据管理员
    type MovieServiceManager struct {
    repo repositories.MovieRepository
    }
    // 初始化服务管理员
    func NewMovieServiceManger(repo repositories.MovieRepository) MovieServer {
    return &MovieServiceManager{repo:repo}
    }
    // 服务管理员的功能实现
    func (m *MovieServiceManager) ShowMoviceName() string {
    fmt.Println("我们获取到的视频名称: "+m.repo.GetMovieName())
    return "我们获取到的视频名称: "+m.repo.GetMovieName()
    }

     



  • movie_controller.go 逻辑处理中心,通过请求的不同方式出发不同的函数,返回不同的View渲染结构

    package controllers
    import (
    "github.com/kataras/iris/mvc"
    "testIris/repositories"
    "testIris/service"
    )
    type MovieController struct {
    }
    // 这个controller有Get方法的监听, 最后返回一个视图
    func (c *MovieController) Get() mvc.View {
    // 创建一个Movie的管理者,他可以实例出movie也可以取movie的属性,相当于movie的管理员
    movieRepository := repositories.NewMovieManager() // 用来使得 repositories 管理 dataModelss
    // 初始化一个服务管理员, 调用他的接口功能 来操作数据管理员
    movieService := service.NewMovieServiceManger(movieRepository)
    // 其实本质上是 数据管理员去给服务管理员movie的名字
    movieResult := movieService.ShowMoviceName()
    return mvc.View{ // 模板实例
    Name:"movie/index.html",
    Data:movieResult,
    }
    }

     



  • index.html 模板

    {{.}}



     



  • main.go 程序入口

    package main
    import (
    "github.com/kataras/iris"
    "github.com/kataras/iris/mvc"
    "log"
    "testIris/web/controllers"
    )
    func main() {
    app := iris.New()
    app.Logger().SetLevel("debug")
    // 模板注册 将符合路径下的以指定结尾的文件作为模板
    app.RegisterView(iris.HTML("./web/views", ".html"))
    // 注册控制器, 请求过来后触发对应的controller
    mvc.New(app.Party("/hello")).Handle(new(controllers.MovieController))
    err := app.Run(
    iris.Addr("localhost:8080"),
    )
    if nil != nil {
    log.Fatal(err)
    }
    }

     

     

     

     

     

     


     

 


推荐阅读
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • 后台获取视图对应的字符串
    1.帮助类后台获取视图对应的字符串publicclassViewHelper{将View输出为字符串(注:不会执行对应的ac ... [详细]
  • Java验证码——kaptcha的使用配置及样式
    本文介绍了如何使用kaptcha库来实现Java验证码的配置和样式设置,包括pom.xml的依赖配置和web.xml中servlet的配置。 ... [详细]
  • 本文内容为asp.net微信公众平台开发的目录汇总,包括数据库设计、多层架构框架搭建和入口实现、微信消息封装及反射赋值、关注事件、用户记录、回复文本消息、图文消息、服务搭建(接入)、自定义菜单等。同时提供了示例代码和相关的后台管理功能。内容涵盖了多个方面,适合综合运用。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 本文介绍了C#中数据集DataSet对象的使用及相关方法详解,包括DataSet对象的概述、与数据关系对象的互联、Rows集合和Columns集合的组成,以及DataSet对象常用的方法之一——Merge方法的使用。通过本文的阅读,读者可以了解到DataSet对象在C#中的重要性和使用方法。 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 本文介绍了通过ABAP开发往外网发邮件的需求,并提供了配置和代码整理的资料。其中包括了配置SAP邮件服务器的步骤和ABAP写发送邮件代码的过程。通过RZ10配置参数和icm/server_port_1的设定,可以实现向Sap User和外部邮件发送邮件的功能。希望对需要的开发人员有帮助。摘要长度:184字。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
author-avatar
一切皆空2502861573
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有