php小編百草為您介紹問題:Golang函式庫無法向控制器傳回nil以外的任何內容的解決方法。在Golang開發中,控制器是處理請求的關鍵元件,但有時可能遇到無法傳回nil以外的內容的問題。這可能會導致某些功能無法正常運作。幸運的是,我們可以採取一些解決方案來解決這個問題,確保庫能夠返回所需的內容。在本文中,我們將探討幾種常見的解決方法,幫助您解決這個問題。
這裡是 golang 小孩,所以我想我錯過了一些明顯的東西。經過幾天的嘗試後,我決定尋求一些幫助。 :-)
我發布的程式碼正在運行,除了用戶要求創建新的客戶端證書/密鑰包(這是 openvpn 伺服器管理 webui)且同名客戶端已存在的情況之外。即使在這種情況下,也不會建立新的用戶端包,但會顯示錯誤的警報訊息,表示已建立新的用戶端包。
我知道我需要重新設計控制器以根據名稱是否存在來顯示不同的警報橫幅。然而,我一直堅持從圖書館取回「nil」以外的任何東西。
golang控制器程式碼如下:
func (c *certificatescontroller) post() { c.tplname = "certificates.html" flash := beego.newflash() cparams := newcertparams{} if err := c.parseform(&cparams); err != nil { beego.error(err) flash.error(err.error()) flash.store(&c.controller) } else { if vmap := validatecertparams(cparams); vmap != nil { c.data["validation"] = vmap } else { if err := lib.createcertificate(cparams.name, cparams.passphrase); err != nil { beego.error(err) flash.error(err.error()) flash.store(&c.controller) } else { fmt.println(err) flash.success("certificate for the name \"" + cparams.name + "\" created") flash.store(&c.controller) } } } c.showcerts() }
以及透過lib.createcertificate呼叫的函式庫函數:
func CreateCertificate(name string, passphrase string) error { rsaPath := models.GlobalCfg.OVConfigPath + "easy-rsa" rsaIndex := models.GlobalCfg.OVConfigPath + "easy-rsa/pki/index.txt" pass := false if passphrase != "" { pass = true } certs, err := ReadCerts(rsaIndex) if err != nil { // beego.Debug(string(output)) beego.Error(err) // return err } Dump(certs) exists := false for _, v := range certs { if v.Details.Name == name { exists = true } } if !exists && !pass { cmd := exec.Command("/bin/bash", "-c", fmt.Sprintf( "%s/easyrsa --batch build-client-full %s nopass", rsaPath, name)) cmd.Dir = models.GlobalCfg.OVConfigPath output, err := cmd.CombinedOutput() if err != nil { beego.Debug(string(output)) beego.Error(err) return err } return nil } if !exists && pass { cmd := exec.Command("/bin/bash", "-c", fmt.Sprintf( "%s/easyrsa --passout=pass:%s build-client-full %s", rsaPath, passphrase, name)) cmd.Dir = models.GlobalCfg.OVConfigPath output, err := cmd.CombinedOutput() if err != nil { beego.Debug(string(output)) beego.Error(err) return err } return nil } if exists { return err } return err }
我已經將庫中的每個返回更改為 err,並在控制器的第二個“else”語句中插入 fmt.println(err),但我得到的只是 nil。
所以,我能夠弄清楚如何處理這個問題。再用谷歌搜尋一下,我發現了一篇至少與我想要實現的目標相鄰的貼文。最後,我只需要在我的憑證庫中新增/更改 3 行。我需要導入“errors”庫,以newerror :=errors.new("error! there is already a valid or invalidcertificate for that name")
的形式添加自定義錯誤,並僅更改最後一個返回return newerror
。我確實學到了一兩點關於 go 如何處理錯誤的知識!
以下是憑證庫的更新程式碼:
func CreateCertificate(name string, passphrase string) error { rsaPath := models.GlobalCfg.OVConfigPath + "easy-rsa" rsaIndex := models.GlobalCfg.OVConfigPath + "easy-rsa/pki/index.txt" pass := false newError := errors.New("Error! There is already a valid or invalid certificate for that name") if passphrase != "" { pass = true } certs, err := ReadCerts(rsaIndex) if err != nil { // beego.Debug(string(output)) beego.Error(err) // return err } Dump(certs) exists := false for _, v := range certs { if v.Details.Name == name { exists = true } } if !exists && !pass { cmd := exec.Command("/bin/bash", "-c", fmt.Sprintf( "%s/easyrsa --batch build-client-full %s nopass", rsaPath, name)) cmd.Dir = models.GlobalCfg.OVConfigPath output, err := cmd.CombinedOutput() if err != nil { beego.Debug(string(output)) beego.Error(err) return err } return nil } if !exists && pass { cmd := exec.Command("/bin/bash", "-c", fmt.Sprintf( "%s/easyrsa --passout=pass:%s build-client-full %s", rsaPath, passphrase, name)) cmd.Dir = models.GlobalCfg.OVConfigPath output, err := cmd.CombinedOutput() if err != nil { beego.Debug(string(output)) beego.Error(err) return err } return nil } return newError }
現在,如果我嘗試新增名稱已存在的 openvpn 用戶端:
以上是無法讓 Golang 函式庫向控制器傳回除 nil 之外的任何內容的詳細內容。更多資訊請關注PHP中文網其他相關文章!