草庐IT

安全漏洞修复

全部标签

multithreading - 引用计数资源的线程安全映射

关闭。这个问题需要更多focused。它目前不接受答案。想要改进这个问题?更新问题,使其只关注editingthispost的一个问题。关闭5年前。Improvethisquestion关于管理资源集合:可通过全局列表(例如HashMap)按名称访问从多个线程同时访问引用计数(Golang缺少“弱引用”;参见https://groups.google.com/forum/#!topic/golang-nuts/PYWxjT2v6ps)例子:vartheListtMap//global//inthreadA,B,CetcaThing:=theList.ref("aThing")//ife

postgresql - 如何修复 "missing FROM-clause entry for table"错误

我正在尝试根据游戏ID获取平台名称。我有如下三个表,我正在尝试连接它们以获得所需的结果:GamesId|.....|.....|---|------------|1|.|.|2|.|.|3|.|.|4|.|.|Game_PlatformsId|....|game_id|platform_id|...|---------------------------------1|.|1|1|..|2|.|1|2|..|3|.|3|3|..|..|.|4|4|..|PlatformsId|...|...|name|---------------------|1|.|.|iOS|2|.|.|Andr

go - Cloudfoundry 密码 - 代码漏洞

下面是从clientlibrary使用的GO代码连接到CloudFoundry。c:=&cfclient.Config{ApiAddress:"https://x.y.z.cloud",Username:"admin",Password:"admin",}client,_:=cfclient.NewClient(c)此源代码由于可读密码而变得易受攻击,进入源代码控制。目前使用上述代码的应用程序在Cloudfoundry(PAAS)之外运行。AWS云(IAAS)引入了名为roles的概念允许在没有凭据的情况下访问。避免在源代码中看到密码的最佳做法是什么?是否CredHub凭据配置帮助cl

go - 如何使用 go 修复 POST 404 错误?不是源代码错误

我用golangbook输入我的源代码。我的源码和我的golang书的源码是一样的查看源码--------golang--------packagemainimport("fmt""net/http")funcmain(){r:=&router{make(map[string]map[string]HandlerFunc)}r.HandleFunc("GET","/",func(c*Context){fmt.Fprintln(c.ResponseWriter,"welcome!")})r.HandleFunc("GET","/about",func(c*Context){fmt.Fpr

security - 存储加密的 PEM block 安全吗?

我有一些使用Go的经验,但现在我并不真正了解我正在做的事情在安全方面的复杂性,所以我需要问一下。我正在创建一个RSA私钥,将其转换为PEM,然后使用密码对其进行加密。那么,将它存放在公共(public)场所有多安全?我不是在寻找诸如“没关系,随着时间的推移更改密码”之类的答案,我真的想知道Golang正在使用哪种密码机制来执行此操作,以及将加密的PEM留在其中是否安全,因为例如,公共(public)区block链以及为什么我可以做到或为什么不能。我将在这里留下我现在正在使用的代码:funcNew(passphrasestring)(*pem.Block,error){pk,err:=c

go - append() 在原子/线程中是安全的吗?

阅读几个列表后,我想将每个列表中的所有行添加到一个大数组中。我在它自己的goroutine中运行每个列表阅读器。我可以在阅读后立即追加一行吗?这个线程是保存还是可以在我手中爆炸?typelistHolder{entries[]entry}func(h*listHolder)readAllLists(s[]list){c:=make(chanlist)varwgsync.WaitGroupfor_,l:=ranges{wg.Add(1)goh.readSomeList(&wg,l)}c.close()wg.Wait()}func(h*listHolder)readSomeList(wg*

api - 从 reddit api 获取时如何修复 'Error 503 cdn error'?

出于学习目的,我正在使用golang构建一个命令行工具,此cli使用以下api从GameDealssubreddit获取前十名帖子:https://www.reddit.com/r/gamedeals/hot.json?limit=10当我发送请求时,我得到的响应是503服务不可用和一些HTML:OurCDNwasunabletoreachourserversPleasecheckwww.redditstatus.comifyouconsistentlygetthiserror.我不明白为什么如果我从浏览器发出请求,我得到的是预期的json,而不是来self的cli的503错误。这是我

go - 一个 goroutine 从结构中读取而另一个 goroutine 正在修改它是否安全?

更具体地说,在我的例子中,我有一个网络服务器和一个全局可访问的结构,网络服务器使用它来生成页面。我有另一个Goroutine,它总是定期用新值更新该结构。这会引起问题吗?我是否需要实现一种机制来确保它在更新时不被读取? 最佳答案 不,这正是不安全的定义,会被racedetector捕获如果你测试过它。您绝对需要同步访问,例如使用sync.Mutexorsync.RWMutex.如果始终拥有最新值并不重要,您还可以允许每个goroutine缓存结构的副本,然后每隔一段时间定期从“主”副本更新它们的副本经常。如果经常访问该结构,这有助于

go - 如何确保自定义数据结构的编译时安全

我正在编写一些数据结构来尝试并了解Go语言,并且正在为Go缺乏泛型而苦苦挣扎。在我的实现中,我选择强制每个用户实现一个接口(interface),这样我的结构就可以抽象地引用这些对象,但我不喜欢我的解决方案,因为正如您将看到的那样,这在编译时没有得到验证。比较接口(interface)保存在容器中的每个对象都必须实现以下签​​名的比较函数(如果您想要保存的都是原始类型,那就麻烦了)typeComparerinterface{Compare(Comparer)int}然后您可以拥有实现接口(interface)的各种元素,如float64或自定义结构:float64typenumberf

go - 将一个 map 分配给另一个 map 在 golang 中是安全的吗?

代码如下:m:=make(map[interface{}]interface{})//readfori:=0;i有10000个readgoroutine访问m,另外10000个writegoroutine给m分配一个新的map,安全吗? 最佳答案 您有goroutines读取m变量,以及goroutines在没有显式同步的情况下写入m变量。这是一场数据竞赛,因此是未定义的行为。在启用竞争检测器的情况下运行它:$gorun-raceplay.go==================WARNING:DATARACEWriteat0x00