草庐IT

安全管理机构

全部标签

go - 查看当前用户是否为管理员

有没有办法确定当前执行应用程序的用户是否是管理员?我环顾四周http://golang.org/pkg/os/user/并且找不到任何关于权限的信息。 最佳答案 这更像是一个特定于操作系统的问题。我假设你在谈论Windows,所以我查找了:http://support.microsoft.com/kb/243330这表明管理员的SID是:“S-1-5-32-544”。这意味着如果在管理员组中,user.Gid将是该值。似乎还有一个特殊的系统管理员SIDS-1-5-21domain-500。

google-app-engine - Golang、App Engine、 channel 和线程安全

http://blog.golang.org/go-and-google-app-engine“此外,尽管存在goroutine和channel,但当Go应用程序在AppEngine上运行时,在给定实例中仅运行一个线程。也就是说,所有goroutine都在单个操作系统线程中运行,因此没有CPU并行性可用于给定的客户请求。我们希望在某个时候可以取消此限制”那是在2011年5月。现在仍然如此吗?我有一个应用程序,它除了利用Golang的速度之外什么都不做;获取一些输入数据,对其执行内存计算,返回结果。切勿接触数据存储区或任何其他AppEngineAPI。我需要应用程序执行许多计算,最好是具

winapi - 从 unsafe.Pointer 获取特定 byte slice 的最佳(最安全 + 最高性能)方法是什么

我正在尝试转换thisc++去。简而言之,这就是C代码正在做的事情:staticconstchar*pSharedMem=NULL;intsessionInfoOffset;returnpSharedMem+pHeader->sessionInfoOffset;这是我的(伪)go代码:varpSharedMemunsafe.PointersessionInfoLenC.intbyteSlice:=C.GoBytes(pSharedMem,pHeader.sessionInfoLen)returnbyteSlice[pHeader.sessionInfoOffset:]我从来没有真正编写

go - 在启用安全和隐私的情况下开始对等时出错

当我尝试使用启动对等体时peernodestart出现以下错误hyperledger@linux-box:/opt/gopath/src/github.com/hyperledger/fabric$peernodestart20:42:02.999[crypto]main->INFO001Loglevelrecognized'info',settoINFO20:42:03.017[main]serve->INFO002Securityenabledstatus:true20:42:03.017[main]serve->INFO004Privacyenabledstatus:true20

go - 如何在 travis-ci 上管理构建 golang 项目

我正在开发Golang项目并使用TravisCI。作为依赖工具,使用Godeps。通过gitpush运行测试后,出现如下错误。#command-line-argumentscmd/proj/main_test.go:6:2:cannotfindpackage"command-line-/vendor/github.com/xxxxx/xxxxx/abc"inanyof:/home/travis/.gimme/versions/go1.6.linux.amd64/src/command-line-/vendor/github.com/xxxxx/xxxxx/xxx为什么找不到包?作为构建

go - Go中如何使用 channel 安全同步数据

下面是一个如何使用互斥锁来安全访问数据的例子。我如何使用CSP(communicationsequentialprocesses)而不是使用互斥锁和解锁来做同样的事情?typeStackstruct{top*Elementsizeintsync.Mutex}func(ss*Stack)Len()int{ss.Lock()size:=ss.sizess.Unlock()returnsize}func(ss*Stack)Push(valueinterface{}){ss.Lock()ss.top=&Element{value,ss.top}ss.size++ss.Unlock()}func

go - 从内部函数引用外部函数中的值安全吗?

我正从Node.js转向Go,我担心我将在Node中使用的结构在Go中是否安全,以及是否有更惯用的方法来完成同样的事情。我正在使用Echo框架并希望设置一个特定于路由的结构,该结构将在上下文对象中可用。我可以为中间件中的每个调用生成结构,但这样做很昂贵。相反,我在外部函数中设置一次结构,然后返回一个内部函数,该内部函数引用外部函数中的结构。我希望我只承担一次生成成本,然后每次调用都有与我的路由相关联的正确结构。e.POST(path,POST.GenericPostHandler,func(nextecho.HandlerFunc)echo.HandlerFunc{operation:

session - 基于 cookie 的 session 管理中的身份验证和加密 key

我的查询来自尝试使用session存储,例如。RedisStore在Golang中,商店将可变参数作为最后一个参数,根据文档,这是成对的身份验证和加密key。我看到的大多数示例在这里只使用一个参数(例如“secret”、“mysecret”等),我无法获得有关通过发送多对身份验证和加密key实现的结果的任何信息.有人可以解释更多或指导我一些关于使用cookie的session管理中的身份验证和加密key的目的的信息。 最佳答案 来自文档:Keysaredefinedinpairstoallowkeyrotation,buttheco

go - 如何安全地将我的数据库结果缓存在内存缓存中

我有返回用户的函数。我正在为我的数据库ORM使用gorm:func(dbs*DbService)GetUser(userIdstring)User{varuser=&User{}dbs.db..Find(&user)returnuser}如果我缓存结果,即用户,这是否会导致内存分配问题,因为我将用户放在引用类型的缓存中,所以它会导致变量user超出此函数的范围?更新鉴于上述功能,我想使用memcache将其更新为缓存(下面不是存储我的用户的实际代码,只是一个例子):mc.Set(&memcache.Item{Key:"foo",Value:[]byte("myvalue")})这是进程

database - 这种数据访问模式是线程安全的吗?

我已经通过以下实现实现了dao.go文件:类型DbClient结构{db*gorm.DB}GetDBClient()初始化与数据库的连接并返回(*DbClient,error)func(db*DbClient)Close(){db.db.关闭()}DbClient的不同增删改查方法服务于所有处理程序的main.go文件像这样使用它:vardbClient*DbClientfuncmain(){db,err:=GetDBClient()iferr!=nil{panic(err)}dbClient=dbdeferdbClient.Close()...}因此main.go的所有处理程序都使用