登录
首页 >  Golang >  Go问答

如何在Windows上使用Golang exec.Command阻止服务的套接字和网络访问?

来源:stackoverflow

时间:2024-02-29 11:06:29 390浏览 收藏

编程并不是一个机械性的工作,而是需要有思考,有创新的工作,语法是固定的,但解决问题的思路则是依靠人的思维,这就需要我们坚持学习和更新自己的知识。今天golang学习网就整理分享《如何在Windows上使用Golang exec.Command阻止服务的套接字和网络访问?》,文章讲解的知识点主要包括,如果你对Golang方面的知识点感兴趣,就不要错过golang学习网,在这可以对大家的知识积累有所帮助,助力开发能力的提升。

问题内容

我正在尝试使用 exec.command().output() 执行第 3 方工具 (steamcmd) 来下载我运行的服务器的更新。当我通过 powershell 正常运行命令时,一切运行正常。

我运行的示例命令:

c:\steamcmd\steamcmd.exe +force_install_dir "c:\gameserver" +login mallachar +app_update 233780

当我检查应用程序的日志时,它工作正常。

[2022-01-05 23:13:23] 日志会话开始 [2022-01-05 23:13:23] [0,0] setsteamid( [u:1:0] ) [2022-01-05 23:13:23] ccminterface::onnetworkdevicestatechange -- 看到设备启动 (192.168.1.254) [2022-01-05 23:13:23] ccminterface::onnetworkdevicestatechange -- 开始连接到 steam [2022-01-05 23:13:23] ccminterface::onnetworkdevicestatechange -- 看到设备启动 (192.168.1.254) [2022-01-05 23:13:23] ccminterface::onnetworkdevicestatechange -- 开始连接到 steam [2022-01-05 23:13:23] ccminterface::onnetworkdevicestatechange -- 看到设备启动 (192.168.1.254) [2022-01-05 23:13:23] ccminterface::onnetworkdevicestatechange -- 开始连接到 steam [2022-01-05 23:13:23] [0,0] setsteamid( [u:1:879488788] ) [2022-01-05 23:13:23] [0,0] setsteamid( [u:1:879488788] ) [2022-01-05 23:13:23] [0,0] 服务器说 50% 的连接应该是 websocket,我们滚动了 41 - 默认使用 websocket。

但是,当我通过 golang 运行它时,它不起作用

import (
    "fmt"
    "os/exec"
    "strings"
)

const armA3ServerID string = "+app_update 233780"

func steamSession(configData Server, steamCMDUser string, steamCMDPass string) {
    var steamCMDCommand strings.Builder
    steamCMDCommand.WriteString("+force_install_dir \"" + configData.Arma3path + "\" ")
    steamCMDCommand.WriteString("+login " + steamCMDUser + " " + steamCMDPass + " ")
    steamCMDCommand.WriteString(armA3ServerID)

    steamCMDCommand.WriteString(" +quit")

    out, err := exec.Command(configData.Steamcmdpath+"steamcmd.exe", steamCMDCommand.String()).Output()

    if err != nil {
        fmt.Printf("Error Is", err)
    }

    fmt.Printf("%s\n", string(out))
}

由于网络问题,命令挂起,我得到此日志输出

[2022-01-05 23:35:59] 日志会话开始 [2022-01-05 23:35:59] [0,0] setsteamid( [u:1:0] ) [2022-01-05 23:35:59] ccminterface::onnetworkdevicestatechange -- 看到设备启动 (192.168.1.254) [2022-01-05 23:35:59] ccminterface::onnetworkdevicestatechange -- 开始连接到 steam [2022-01-05 23:35:59] ccminterface::onnetworkdevicestatechange -- 看到设备启动 (192.168.1.254) [2022-01-05 23:35:59] ccminterface::onnetworkdevicestatechange -- 开始连接到 steam [2022-01-05 23:35:59] ccminterface::onnetworkdevicestatechange -- 看到设备启动 (192.168.1.254) [2022-01-05 23:35:59] ccminterface::onnetworkdevicestatechange -- 开始连接到 steam [2022-01-05 23:35:59] ipv6 http 连接测试 (ipv6check-http.steamcontent.com / 0.0.0.0:80 (0.0.0.0:80)) - 超时 [2022-01-05 23:35:59] ipv6 udp 连接测试 (ipv6check-udp.steamcontent.com) - 失败,未解析地址

当我终止运行的 steamcmd 后台实例时,我的 golang 程序打印出输出,显示它确实尝试执行,但只是挂在连接部分。

据我所知,当我使用 exec.command 时,我用它启动的服务似乎没有互联网/套接字访问权限?我尝试以管理员身份运行,但似乎没有解决任何问题。不确定是否可能缺少一个步骤或需要更改标志。

因此命令确实运行,后端应用程序运行,但无法解析地址/建立连接。所以看来我的命令本身不是问题,而是 golang exec.command 的问题?


正确答案


您正在向命令传递一个参数,即所有参数的串联。试试这个:

out, err := exec.Command(
     configData.Steamcmdpath+"steamcmd.exe",
     "+force_install_dir", configData.Arma3path,
     "+login ",steamCMDUser,steamCMDPass,
      "+app_update", "233780",
     "+quit",
  ).Output()

今天关于《如何在Windows上使用Golang exec.Command阻止服务的套接字和网络访问?》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>