業(yè)務(wù)當(dāng)中有需要分發(fā)http.request.body的場景。比如微信回調(diào)消息只能指定一個地址,所以期望可以昌磨復(fù)制一份消息發(fā)給其他服務(wù)。由服務(wù)B和接收微信回調(diào)的服務(wù)A一起處理微信回調(diào)衫洞信息。
創(chuàng)新互聯(lián)是專業(yè)的利辛網(wǎng)站建設(shè)公司,利辛接單;提供成都網(wǎng)站制作、成都網(wǎng)站設(shè)計,網(wǎng)頁設(shè)計,網(wǎng)站設(shè)計,建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行利辛網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來合作!
最開始考慮的是直接轉(zhuǎn)發(fā)http.request。使用 ReverseProxy 直接將http.request由服務(wù)A轉(zhuǎn)發(fā)給服務(wù)B。但是微信涉及到驗(yàn)證等問題,完全調(diào)整好非常麻煩。所以轉(zhuǎn)換思路,打算將http.request.body的內(nèi)容直接post給服務(wù)B。
可是http.request是readcloser。我們將http.request readAll的時候講無法耐塌斗再次讀取http.request里面的信息。
其中c表示的是http的上下文
1.我們先將body從http.request里面讀取出來,保存到一個變量里面。
2.然后再將變量里面的數(shù)據(jù)使用ioutil.NopCloser方法寫回到http.request里面。
NopCloser returns a ReadCloser with a no-op Close method wrapping the provided Reader r.
NopCloser用一個無操作的Close方法包裝Reader r返回一個ReadCloser接口。
這樣我們就可以再次使用c.request來進(jìn)行處理了。
golang復(fù)用http-request-body
下面定義一個結(jié)構(gòu)體類鏈?zhǔn)孜招秃颓圬Q該類型的一個方法:
復(fù)制代碼代碼如下:
type User struct {
Name string
Email string
}
func (u User) Notify() error
首先我們定義了一個叫做 User 的結(jié)構(gòu)體類型,然后定義了一個該類型的方法叫做 Notify,該方法的接受者是一個 User 類型的值。要調(diào)用 Notify 方法我們需要一個 User 類型的值或者指針:
復(fù)制代碼代碼如下:
// User 類型的值可以調(diào)用接受者是值的方法
damon := User{"AriesDevil", "ariesdevil@xxoo點(diǎn)抗 "}
damon.Notify()
//棚慶 User 類型的指針同樣可以調(diào)用接受者是值的方法
alimon := User{"A-limon", "alimon@ooxx點(diǎn)抗 "}
alimon.Notify()
在 Go 語言中,如果一個接口在一個包里,其他包要實(shí)現(xiàn)該接口,需要遵循下列步驟:
1. 定義接口:
假設(shè)接口定義在 `foo` 包中:源畢絕
go
package foo
type MyInterface interface {
MyMethod() string
}
2. 實(shí)現(xiàn)接口:
定義一個新的類型 `Bar`,并為其實(shí)現(xiàn) `foo.MyInterface` 接口:
go
package bar
import "your-package/foo"
type Bar struct {
// ...
}
func (b Bar) MyMethod() string {
// implement method
return "bar"
}
在這里,需要導(dǎo)入 `foo` 包,并定義一個 `Bar` 類型,為其實(shí)現(xiàn) `foo.MyInterface` 接口,這樣就完成了在不同包中實(shí)現(xiàn)接口的目標(biāo)。
如果在其他包中使用 `Bar`,需要先導(dǎo)入 `bar` 包,然后聲明 `Bar` 實(shí)例,并將其轉(zhuǎn)換為 `foo.MyInterface`,然后就可以調(diào)用 `MyMethod` 方法了:
go
import "your-package/bar"
func main() {
var myInterface foo.MyInterface = new(bar.Bar)
myInterface.MyMethod()
}
在這里,我們定義了一個 `myInterface` 實(shí)例,將其類型聲明為 `foo.MyInterface`,并將其初始化為 `new(bar.Bar)`。這允許我們調(diào)用 `MyMethod` 方法,這個方法實(shí)際上是由 `bar.Bar` 類型實(shí)現(xiàn)的。
總結(jié)起來,在其他包雹姿中使用其它包的接口,需要數(shù)帶實(shí)現(xiàn)接口的包定義一個新的類型,并完成接口的實(shí)現(xiàn),另一個使用接口的包需要導(dǎo)入實(shí)現(xiàn)包的路徑,并將接口轉(zhuǎn)換成實(shí)現(xiàn)類型。