首页  >  文章  >  后端开发  >  无法让 Golang 库向控制器返回除 nil 之外的任何内容

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

王林
王林转载
2024-02-11 15:45:09747浏览

无法让 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删除