首頁 > 後端開發 > Golang > 主體

無法讓 Golang 函式庫向控制器傳回除 nil 之外的任何內容

王林
發布: 2024-02-11 15:45:09
轉載
722 人瀏覽過

无法让 Golang 库向控制器返回除 nil 之外的任何内容

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中文網其他相關文章!

相關標籤:
來源:stackoverflow.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!