boogo08---中间件

简介:
复制代码
package main

//中间件1:只允许特定host请求过来
import (
    "fmt"
    "net/http"
)

//SingleHost是一个中间件,
type SingleHost struct {
    hander http.Handler //这不是继承http.Handler接口,后面重写了ServeHTTP方法。
    /*
        type Handler interface {
            ServeHTTP(ResponseWriter, *Request)
        }*/
    allowedHost string //只准允许某个host发来的请求
}

//Handler这个接口只有一个方法,SingleHost实现了这个方法就相当于继承了Handler interface接口
//请求来的时候会来这里
func (this *SingleHost) ServeHTTP(w http.ResponseWriter, r *http.Request) {

    fmt.Println(r.Host)

    if r.Host == this.allowedHost { //从Request里面可以获取Host
        this.hander.ServeHTTP(w, r)
    } else {
        w.WriteHeader(403)
    }
}

func myHandler(w http.ResponseWriter, r *http.Request) {
    w.Write([]byte("helloworld"))
}

func main() {
    sing := &SingleHost{
        hander:      http.HandlerFunc(myHandler),
        allowedHost: "example.com", //只有example.com过来的才合法
    }
    http.ListenAndServe(":8080", sing)
}
复制代码

 中间件形式2:函数形式

复制代码
package main

//中间件2:只允许特定host请求过来。
//函数的形式。
import (
    "fmt"
    "net/http"
)

/*
type HandlerFunc func(ResponseWriter, *Request)

// ServeHTTP calls f(w, r).
func (f HandlerFunc) ServeHTTP(w ResponseWriter, r *Request) {
    f(w, r)
}
*/

func SingleHost(handler http.Handler, allowstring string) http.Handler {
    fn := func(w http.ResponseWriter, r *http.Request) {
        if r.Host == allowstring { //从Request里面可以获取Host
            this.hander.ServeHTTP(w, r)
        } else {
            w.WriteHeader(403)
        }
    }
    return http.HandlerFunc(fn)
}

func myHandler(w http.ResponseWriter, r *http.Request) {
    w.Write([]byte("helloworld"))
}

func main() {
    sing := SingleHost(http.HandlerFunc(myHandler), "example.com")
    http.ListenAndServe(":8080", sing)
}
复制代码

 

复制代码
package main

//中间件3:只允许特定host请求过来。
//追加内容形式。
import (
    _ "fmt"
    "net/http"
)

type AppendMiddleware struct {
    handler http.Handler
}

func (this *AppendMiddleware) ServeHTTP(w http.ResponseWriter, r *http.Request) {
    this.handler.ServeHTTP(w, r)              //正常是响应
    w.Write([]byte("Hey,this is middleware")) //多输出一行内容,告诉用户这是中间价
}

func myHandler(w http.ResponseWriter, r *http.Request) {
    w.Write([]byte("helloworld"))
}

func main() {
    mid := &AppendMiddleware{http.HandlerFunc(myHandler)}
    http.ListenAndServe(":8080", mid)
}
复制代码

 

复制代码
package main

//中间件3:只允许特定host请求过来。
//自定义响应。
import (
    _ "fmt"
    "net/http"
    "net/http/httpest"
)

//先将所有的响应保存起来,完成所有操作之后,然后一起输出

type ModifiedMiddleware struct {
    handler http.Handler
}

func (this *ModifiedMiddleware) ServeHTTP(w http.ResponseWriter, r *http.Request) {
    rec := httptest.NewRecorder()
    this.handler.ServeHTTP(rec, r) //rec将所有的响应记录下来
    for k, v := range rec.Header() {
        w.Header()[k] = v
    }
    w.Header().Set("go-web-foundation", "vip")
    w.WriteHeader(418)
    w.Write([]byte("this is middleware"))
    w.Write(rec.Body.Bytes())
}

func myHandler(w http.ResponseWriter, r *http.Request) {
    w.Write([]byte("helloworld"))
}

func main() {
    mid := &ModifiedMiddleware{http.HandlerFunc(myHandler)}
    http.ListenAndServe(":8080", mid)
}
复制代码

 


本文转自农夫山泉别墅博客园博客,原文链接:http://www.cnblogs.com/yaowen/p/8260515.html,如需转载请自行联系原作者

相关文章
|
7天前
|
JSON API 数据格式
OpenCode入门使用教程
本教程介绍如何通过安装OpenCode并配置Canopy Wave API来使用开源模型。首先全局安装OpenCode,然后设置API密钥并创建配置文件,最后在控制台中连接模型并开始交互。
3178 7
|
13天前
|
人工智能 JavaScript Linux
【Claude Code 全攻略】终端AI编程助手从入门到进阶(2026最新版)
Claude Code是Anthropic推出的终端原生AI编程助手,支持40+语言、200k超长上下文,无需切换IDE即可实现代码生成、调试、项目导航与自动化任务。本文详解其安装配置、四大核心功能及进阶技巧,助你全面提升开发效率,搭配GitHub Copilot使用更佳。
|
3天前
|
人工智能 API 开发者
Claude Code 国内保姆级使用指南:实测 GLM-4.7 与 Claude Opus 4.5 全方案解
Claude Code是Anthropic推出的编程AI代理工具。2026年国内开发者可通过配置`ANTHROPIC_BASE_URL`实现本地化接入:①极速平替——用Qwen Code v0.5.0或GLM-4.7,毫秒响应,适合日常编码;②满血原版——经灵芽API中转调用Claude Opus 4.5,胜任复杂架构与深度推理。
|
15天前
|
存储 人工智能 自然语言处理
OpenSpec技术规范+实例应用
OpenSpec 是面向 AI 智能体的轻量级规范驱动开发框架,通过“提案-审查-实施-归档”工作流,解决 AI 编程中的需求偏移与不可预测性问题。它以机器可读的规范为“单一真相源”,将模糊提示转化为可落地的工程实践,助力开发者高效构建稳定、可审计的生产级系统,实现从“凭感觉聊天”到“按规范开发”的跃迁。
2240 18
|
7天前
|
人工智能 前端开发 Docker
Huobao Drama 开源短剧生成平台:从剧本到视频
Huobao Drama 是一个基于 Go + Vue3 的开源 AI 短剧自动化生成平台,支持剧本解析、角色与分镜生成、图生视频及剪辑合成,覆盖短剧生产全链路。内置角色管理、分镜设计、视频合成、任务追踪等功能,支持本地部署与多模型接入(如 OpenAI、Ollama、火山等),搭配 FFmpeg 实现高效视频处理,适用于短剧工作流验证与自建 AI 创作后台。
1122 5
|
6天前
|
人工智能 运维 前端开发
Claude Code 30k+ star官方插件,小白也能写专业级代码
Superpowers是Claude Code官方插件,由核心开发者Jesse打造,上线3个月获3万star。它集成brainstorming、TDD、系统化调试等专业开发流程,让AI写代码更规范高效。开源免费,安装简单,实测显著提升开发质量与效率,值得开发者尝试。
|
17天前
|
人工智能 测试技术 开发者
AI Coding后端开发实战:解锁AI辅助编程新范式
本文系统阐述了AI时代开发者如何高效协作AI Coding工具,强调破除认知误区、构建个人上下文管理体系,并精准判断AI输出质量。通过实战流程与案例,助力开发者实现从编码到架构思维的跃迁,成为人机协同的“超级开发者”。
1268 102
|
13天前
|
人工智能 JSON 自然语言处理
【2026最新最全】一篇文章带你学会Qoder编辑器
Qoder是一款面向程序员的AI编程助手,集智能补全、对话式编程、项目级理解、任务模式与规则驱动于一体,支持模型分级选择与CLI命令行操作,可自动生成文档、优化提示词,提升开发效率。
1011 10
【2026最新最全】一篇文章带你学会Qoder编辑器

热门文章

最新文章