草庐IT

安全字典

全部标签

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:

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的所有处理程序都使用

go - 在 handlefunc 之外安全终止请求

如何在不在handlefunc中显式返回的情况下安全地终止调度程序(handlefunc)之外的请求?在下面的代码中,我最终在响应中同时看到“Badrequest”和“Notfound”,但我希望f()中止请求——这样我就不必用错误检查和返回。packagemainimport("net/http")funcf(whttp.ResponseWriter,r*http.Request,kstring)string{ifv,ok:=r.Form[k];!ok{http.Error(w,"Badrequest",http.StatusBadRequest)return""}else{retu

google-app-engine - 在 App Engine 上使用 pem 文件的安全方式

我想实现一个将签名URL返回给客户端的服务我使用此代码作为引用signing-code-go.我想上传文件,因为使用app.yaml将它提供给应用程序,只是类似的东西。-url:/filesstatic_dir:files在服务器内使用pem文件的最佳和安全方式是什么? 最佳答案 “静态文件”提供给用户,作为https://cloud.google.com/appengine/docs/go/config/appconfig#Go_app_yaml_Static_file_handlers说清楚了。引用此URL:Ifyouhaved

智能合约安全审计公司选型分析和审计报告资源下载---国内篇

国内影响力平台2020年9月6日,区块链行业三家知名安全公司slowmist、PeckShield和成都链安联合宣布完成对去中心化交易协议oneswap的全面安全审计。查看审计报告。慢雾slowmist慢雾科技是一家专注区块链生态安全的公司,成立于2018年01月,由一支拥有十多年一线网络安全攻防实战的团队创建,团队成员曾打造了拥有世界级影响力的安全工程。慢雾科技已经是国际化的区块链安全头部公司,主要通过“威胁发现到威胁防御一体化因地制宜的安全解决方案”服务了全球许多头部或知名的项目,已有商业客户上千家,客户分布在十几个主要国家与地区。慢雾产品MistTrack:链上追踪平台。是一个反洗钱跟踪

go - 同时读取和写入数组是否安全 Go

这样使用安全吗?读取例程是否读取部分更新的数组并不重要,但我需要它的所有值都完好无损。所有3个例程都在循环中运行vararr[100]bytegoReadFrom(arr)goReadFrom(arr)goWriteTo(arr) 最佳答案 @Pownyan,不,不安全,正如JimB在评论中提到的那样。您需要互斥锁来保证安全:https://golang.org/pkg/sync/#Mutex示例:https://gobyexample.com/mutexes 关于go-同时读取和写入数

安全地进行 http 重定向

我知道在PHP网络应用程序中,如果您使用header('Location:http://somewhere.com')进行重定向,但您没有die()/exit(),则始终执行并显示header函数之后的代码。我想知道在Go中使用http.Redirect(w,r,"/somewhere",302)时是否会发生同样的情况。如果是,如何避免。 最佳答案 http.Redirect函数写入一个完整的响应。程序在调用http.Redirect后继续执行。如果对http.Redirect的调用不是函数的最后一行,那么应用程序通常会在调用后立即

go - 如何在程序运行时安全地交换内存映射?

我有一个正在运行的go服务,它在内存中有一个map,比如map1。map数据(键和值)依赖于存储在S3中的文件。一个goroutine正在运行以监控这个文件,如果有变化,下载文件,解析它,并创建一个新的map,比如map2。如何在不导致其他线程读取不一致数据的情况下交换map1和map2的内容?下面我大致了解了我是如何考虑解决这个问题的。以下程序的输出是“map1-a”序列,后跟“map2-a”序列。map换了。这是最好的方法吗?packagemainimport("fmt""time")funcinitializeAndMonitor()*map[string]string{map1