我有一些冗余邏輯要提取到一個(gè)實(shí)用程序中以將請(qǐng)求綁定到結(jié)構(gòu),我希望我能以某種方式動(dòng)態(tài)地做到這一點(diǎn)。我想要的是基本上一般地將任何請(qǐng)求綁定到我傳入的結(jié)構(gòu)類型。這將大大減少我程序中的一些代碼。我可以有一個(gè)Task結(jié)構(gòu),或者我可以有一個(gè)Information結(jié)構(gòu)。所有這些信息都通過 JSON 進(jìn)入服務(wù)器,但我希望能夠傳入類型名稱并讓它自動(dòng)綁定以減少我正在編寫的代碼。示例調(diào)用者func StoreTask(dbWrapper *database.DB) func(http.ResponseWriter, *http.Request) { return func(rw http.ResponseWriter, r *http.Request) { data := &utilities.DynamicStruct{entities.Task, r, rw} utilities.PersistRequest(data) }}這是我的小例子:type DynamicStruct struct { cType interface{} writer http.ResponseWriter req *http.Request}func PersistRequest(s *DynamicStruct, decoderOpts *DecoderMetadata) { r := s.req rw := s.writer // I want the struct to basically be able to take any type data := s.cType err := r.ParseForm() if err != nil { log.Printf("HTTP %d - %s", 500, err.Error()) http.Error(rw, err.Error(), 500) } // This is where the dynamic nature of the param would come into play that I'm looking for.. newTask := new(data) decoder := utilities.GenerateDecoder(decoderOpts) // Using gorilla/schema here err = decoder.Decode(newTask, r.Form) if err != nil { log.Printf("HTTP %d - %s", 500, err.Error()) http.Error(rw, err.Error(), 500) } rw.Header().Set("Content-Type", "application/json") json.NewEncoder(rw).Encode(newTask)}
1 回答

30秒到達(dá)戰(zhàn)場
TA貢獻(xiàn)1828條經(jīng)驗(yàn) 獲得超6個(gè)贊
當(dāng)你像這樣編組或解碼未知結(jié)構(gòu)時(shí),你不需要做任何額外的事情:只需將接口值傳遞給編碼器,它就會(huì)使用反射對(duì)底層值進(jìn)行編碼,或者MashalJSON
如果它實(shí)現(xiàn)了自定義編組器,則調(diào)用.
dynamicStruct.cType=someStructValue
如果要解組,則可以通過將指針傳遞給結(jié)構(gòu)來執(zhí)行相同的操作:
dynamicStruct.cType=&SomeStruct{}
然后你不需要?jiǎng)?chuàng)建一個(gè)未知類型的新實(shí)例,只需將接口傳遞給 unmarshal。
- 1 回答
- 0 關(guān)注
- 109 瀏覽
添加回答
舉報(bào)
0/150
提交
取消