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 客戶端: