返回顶部
首页 > 资讯 > 后端开发 > GO >无法让 Golang 库向控制器返回除 nil 之外的任何内容
  • 389
分享到

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

golang开发 2024-02-11 15:02:57 389人浏览 八月长安
摘要

PHP小编百草为您介绍问题:golang库无法向控制器返回除nil之外的任何内容的解决方法。在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 之外的任何内容的详细内容,更多请关注编程网其它相关文章!

您可能感兴趣的文档:

--结束END--

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

本文链接: https://lsjlt.com/news/563508.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作