草庐IT

java程序

全部标签

go - 编写像 node.js 应用程序这样的 go 程序而无需 go 路径

在学习了go的基础知识后,我意识到我需要这个根gocode目录导出为GOPATH,我更愿意简单地拥有一个项目文件夹,我可以在其中安装包,并从中运行我的go代码,这真的是他们编程的方式吗……谁喜欢这个?我查看了vendor文件夹选项,但这仍然意味着需要一个gocodeGOPATH导出并且vendor目录需要位于该源文件夹结构中。我希望我的项目成为根,仅此而已。golang怎么可能做不到呢?或者是吗? 最佳答案 是的。你需要设置你的GOPATH,你所有的go-code、-binaries、-packages等都将放在这个文件夹中。您可以

go - FileServer 处理程序是否仅服务于您指定目录中的内容?

例如,用户可以将您的url与linux命令一起放在文件夹/目录中吗?假设我的服务器包括:bin/serverfile.go...public/index.htmlstyle.css“www.example.com/../bin/etc”与serverfile.go组成:pacakagemainimport"net/http"funcmain(){htttp.ListenAndServe(":8000",http.FileServer(http.Dir("public")))} 最佳答案 http.FileServer禁止突破您指定的

reactjs - 从具有 session token 的 oauth2 应用程序获取用户信息

我认为,我对与Oauth2协议(protocol)相关的概念存在误解。现在我有3个应用程序:使用React开发前端使用Golang开发的OAuth2服务器(未完成)另一个后端应用,我们称之为:业务逻辑应用首先,react的用户可以使用OAuth2服务器登录系统,OAuth2服务器发送token,一切都很完美。现在,当一些请求从React应用程序发送到业务逻辑应用程序时,token也会在header中发送。我的问题是:有了token,我是否应该能够从BussinessLogicApp获取用户向OAuth服务器发出请求的信息?OAuth协议(protocol)允许吗?问题是我需要在Buss

golang - 防止应用程序退出

在Go中,通过panic(),您可以使用defer和recover()到preventanappfromexiting并继续执行代码。但是,我试图阻止我的应用程序在获取dialtcp192.168.1.1:830:getsockopt:connectionrefused时退出。应用程序退出,状态代码为1。从技术上讲,这不是错误,所以我无法捕捉到错误。当这种情况发生时,我用来制作tcp拨号的外部包会导致应用程序退出。(在这种情况下,是因为端口被阻塞了。)那么我怎样才能从另一个包中恢复Exit并继续我的应用程序呢?以下面为例:funcmakeRequest(targetstring){//

docker - 无法从docker-machine(Virtual Box)上的docker图像运行Go(lang)应用程序

我有一个非常简单的应用程序。这是代码:packagemainimport("fmt""math/rand""time""net/http""encoding/base64""encoding/json")typeMessagestruct{Textstring`json:"text"`}varcookieQuotes=[]string{//Skippedallthestuff}constCOOKIE_NAME="your_cookie"funcmain(){http.HandleFunc("/set_cookie",setCookie)http.HandleFunc("/get_coo

firebase - 在 golang 应用程序中初始化 firebase 时出错

我正在使用firebasegosdk(https://github.com/acoshift/go-firebase-admin)并按照文档设置我的应用程序。但是当我尝试使用firebase.NewApp初始化应用程序时,我收到一条错误消息google:couldnotfinddefaultcredentials.谁能帮忙这是代码片段opt=option.WithCredentialsFile(viper.GetString("firebase"))app,err=firebase.NewApp(context.Background(),nil,opt)iferr!=nil{log.F

go - 检测哪个 Lock() 导致程序挂起?

在我的go程序中,执行被挂了,因为它在等待Lock()。go中是否有我可以用来找到它陷入僵局的确切行的工具? 最佳答案 您可以使用pprof获取堆栈跟踪.如果您遵循包中的示例代码,urlhttp://localhost:6060/debug/pprof/goroutine?debug=1将为您提供每个正在运行的goroutine的堆栈跟踪。 关于go-检测哪个Lock()导致程序挂起?,我们在StackOverflow上找到一个类似的问题: https://s

插件和主应用程序之间的 Golang 包版本

我不是围棋专家,所以我这样做的方式可能不是围棋的理想方法。本质上,我有一个主应用程序需要能够为其编写插件。这些插件都遵循给定的格式,并使用gobuild-buildmode=plugin构建。我不希望最终用户每次都需要重新编译主应用程序。理想情况下,您应该能够毫无问题地将它拖放到新计算机上。为了在插件和应用程序之间传递信息,我定义了第三个名为“common”的包,我将其视为C头文件。它只定义了接口(interface)和一些两者都可以使用的整数常量。应用程序生成符合接口(interface)的类型,并可以将它们传递给插件使用。当我编译时,它似乎工作正常,应用程序可以使用plugin.O

linux - 为什么 docker 容器中的应用程序不重启?

我已经部署了一些带有golang应用程序的docker容器。其中一个我需要通过这个命令启动:dockerrun--restartunless-stopped-itmyapp/bin/bash下一步我进入容器并编辑一些配置文件,然后我运行gobuildmain.go和./main之后,我按ctrl+q并将其保留。一切正常,重启服务器后我的所有容器都完美重启。但是有一个问题,当myapp容器重新启动时,golang应用程序不会运行,而容器仍在运行。我必须再次输入并运行./main。我该如何解决?DockerfileFROMgolang:1.8WORKDIR/go/src/appCOPY..

go - 尝试提取 API 请求 token 并包装我的处理程序

我想使用新的上下文来包装我的处理程序,这样我就可以在我的所有处理程序中使用一个用户结构(或者当前请求需要的任何其他内容来告诉我谁在发出请求)。我收到一个错误:funcmain(){router:=mux.NewRouter()router.HandleFunc("/api/v1/user/{id}",userService.GetUsers).Methods("GET")log.Fatal(http.ListenAndServe(":3001",router))}funcWithAuth(usUserService,nexthttp.Handler)http.Handler{retur