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. eclipse导入svn检出的maven项目问题

    1.修改项目jdk环境和编译环境.消除红叉. 2.windows-preferences-java-installed jres,修改工作空间的jdk,在Default vm arguments栏中添 ...

  2. Linux(14):集群架构进阶 --- CentOS 7

    CentOS 7 CentOS 7 管理软件常用命令: vim /etc/selinux/config # 修改 SELINUX 开机自启动与否 setenforce 0 # 关闭 SELINUX g ...

  3. hdu 5691 Sitting in Line

    传送门 Sitting in Line Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/O ...

  4. yii 之删除数据

    public function actionTest(){ //删除 //方法一 $result = Test::find()->where(['id' => 1])->all(); ...

  5. Redis数据结构之字典

    Redis的字典使用哈希表作为底层实现,一个哈希表里面可以有多个哈希表节点,而每个哈希表节点就保存了字典中的一个键值对. 一.字典结构定义1. 哈希表节点结构定义: 2. 哈希表结构定义: 3. 字典 ...

  6. 汉若塔系列续:汉诺塔VIII、汉诺塔IX、汉诺塔X。

    汉诺塔VIII,在经典汉若塔问题上,问n个盘子的情况下,移动m次以后,是什么状态.(与第七代互为逆命题) 我的思路:本质还是dfs,但是用m的值来指引方向,每搜一层确定第i个盘子在哪个塔,o(n)的算 ...

  7. npm start 修改启动端口的不同方式

    antd的启动配置文件基于package.json文件,配合roadhog使用时,启动配置是: "scripts": { "start": "road ...

  8. Wormholes(spfa判负环)

      POJ - 3259—— Wormholes Time Limit: 2000MS   Memory Limit: 65536KB   64bit IO Format: %I64d & % ...

  9. 安装Django时解决的问题-mysql及访问(附pycharm激活)

    1.做些软链接和virtualenv的基本使用: ln -s /data/linkdood/im/vrv/python36/bin/python3.6 /usr/bin/python3 ln -s / ...

  10. Systemtap examples, Network - 4 Monitoring TCP Packets

    http://blog.163.com/digoal@126/blog/static/16387704020131014104256627/   例子来自tcpdumplike.stp脚本, 当tcp ...