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)
}

boogo08---中间件的更多相关文章

  1. ASP.NET Core 中的那些认证中间件及一些重要知识点

    前言 在读这篇文章之间,建议先看一下我的 ASP.NET Core 之 Identity 入门系列(一,二,三)奠定一下基础. 有关于 Authentication 的知识太广,所以本篇介绍几个在 A ...

  2. ASP.NET Core应用的错误处理[3]:ExceptionHandlerMiddleware中间件如何呈现“定制化错误页面”

    DeveloperExceptionPageMiddleware中间件利用呈现出来的错误页面实现抛出异常和当前请求的详细信息以辅助开发人员更好地进行纠错诊断工作,而ExceptionHandlerMi ...

  3. ASP.NET Core应用的错误处理[2]:DeveloperExceptionPageMiddleware中间件如何呈现“开发者异常页面”

    在<ASP.NET Core应用的错误处理[1]:三种呈现错误页面的方式>中,我们通过几个简单的实例演示了如何呈现一个错误页面,这些错误页面的呈现分别由三个对应的中间件来完成,接下来我们将 ...

  4. ASP.NET Core 中间件之压缩、缓存

    前言 今天给大家介绍一下在 ASP.NET Core 日常开发中用的比较多的两个中间件,它们都是出自于微软的 ASP.NET 团队,他们分别是 Microsoft.AspNetCore.Respons ...

  5. .NET Core中间件的注册和管道的构建(3) ---- 使用Map/MapWhen扩展方法

    .NET Core中间件的注册和管道的构建(3) ---- 使用Map/MapWhen扩展方法 0x00 为什么需要Map(MapWhen)扩展 如果业务逻辑比较简单的话,一条主管道就够了,确实用不到 ...

  6. .NET Core中间件的注册和管道的构建(2)---- 用UseMiddleware扩展方法注册中间件类

    .NET Core中间件的注册和管道的构建(2)---- 用UseMiddleware扩展方法注册中间件类 0x00 为什么要引入扩展方法 有的中间件功能比较简单,有的则比较复杂,并且依赖其它组件.除 ...

  7. .NET Core中间件的注册和管道的构建(1)---- 注册和构建原理

    .NET Core中间件的注册和管道的构建(1)---- 注册和构建原理 0x00 问题的产生 管道是.NET Core中非常关键的一个概念,很多重要的组件都以中间件的形式存在,包括权限管理.会话管理 ...

  8. 从中间件的历史来看移动App开发的未来

    在移动开发领域我们发现一个很奇怪的现象:普通菜鸟新手经过3个月的培训就可以拿到 8K 甚至上万的工作:在北京稍微有点工作经验的 iOS 开发,就要求 2 万一个月的工资.不知道大家是否想过:移动应用开 ...

  9. ASP.NET Core的路由[4]:来认识一下实现路由的RouterMiddleware中间件

    虽然ASP.NET Core应用的路由是通过RouterMiddleware这个中间件来完成的,但是具体的路由解析功能都落在指定的Router对象上,不过我们依然有必要以代码实现的角度来介绍一下这个中 ...

  10. ASP.NET Core应用针对静态文件请求的处理[5]: DefaultFilesMiddleware中间件如何显示默认页面

    DefaultFilesMiddleware中间件的目的在于将目标目录下的默认文件作为响应内容.我们知道,如果直接请求的就是这个默认文件,那么前面介绍的StaticFileMiddleware中间件会 ...

随机推荐

  1. 浅谈中途相遇攻击--meet-in-the-middle attack

    貌似挖的坑也够多了....好多都没填,这篇最后会不会TJ还得看心情TUT 看过大白书的人应该都会发现一种神奇的算法:中途相遇法.(在第58页)这种算法将以空间换时间的思路运用到了极致,但事实上它在密码 ...

  2. LINUX支持哪些文件系统

    我们在Linux中常用的文件系统主要有ext3.ext2及reiserfs :Windows和Dos常用的文件系统是fat系列(包括fat16及fat32等)和ntfs 文件系统:光盘文件系统是ISO ...

  3. miller_rabin + pollard_rho模版

    #include<stdio.h> #include<stdlib.h> #include<time.h> #include<math.h> #incl ...

  4. Android 之 下拉框(Spinner)的使用-转

    下拉列表 Spinner. Spinner的使用,可以极大提高用户的体验性.当需要用户选择的时候,可以提供一个下拉列表将所有可选的项列出来.供用户选择. Demo如下,可以留作参考 一.使用数组作为数 ...

  5. django学习之- simple_tag

    如何将前端的数据直接通过python模块进行渲染,使用django的simple_tag功能,如下 django后端编写: 1:在对应的app目录下创建目录:templatetags 2:在templ ...

  6. 网络安全(超级详细)零基础带你一步一步走进缓冲区溢出漏洞和shellcode编写!

    零基础带你走进缓冲区溢出,编写shellcode. 写在前面的话:本人是以一个零基础者角度来带着大家去理解缓冲区溢出漏洞,当然如果你是开发者更好. 注:如果有转载请注明出处!创作不易.谢谢合作. 0. ...

  7. 虽然今天angular5发布了,但我还是吧这篇angularjs(1)+webpack的文章发出来吧哈哈哈

    本文为原创,转载请注明出处: cnzt       文章:cnzt-p http://www.cnblogs.com/zt-blog/p/7779384.html 写在前面: 因为最近总结自己之前做过 ...

  8. connectTimeOut和readTimeout

    网络编程时,经常遇到很多timeout异常,下面是java URLConnection 中经典的2种 timeout参数,这些参数设置不当的话,就会遇到timeout 异常. 1. ConnectTi ...

  9. 揭秘jbpm流程引擎内核设计思想及构架

    揭秘jbpm流程引擎内核设计思想及构架 作者 胡长城(银狐999)   1     前言 2     阅读本篇的基础准备 2.1      概念的基础 2.2      环境的基础 3     什么是 ...

  10. 【转】 使用 Python 获取 Linux 系统信息

    在本文中,我们将会探索使用Python编程语言工具来检索Linux系统各种信息.走你. 哪个Python版本? 当我提及Python,所指的就是CPython 2(准确的是2.7).我会显式提醒那些相 ...