草庐IT

安全通信存储

全部标签

go - golang中处理websocket通信的设计实践

我是新手,正在尝试通过更换nodejs服务器来学习它。我的nodejs服务器具有以下组件:它收到来自客户端的websocket消息。客户端将为消息提供唯一ID和key。服务器将根据key处理消息(很像REST接口(interface)),并使用唯一ID将消息返回给客户端,以便客户端知道服务器正在响应的消息。对于某些消息,服务器会生成一个外部进程(每个连接一个)。然后,服务器将充当生成进程的“客户端”,发送具有唯一ID的JSON消息并接收回数据。此实例中的服务器充当派生进程和客户端之间的中介。在node上让它正常工作是微不足道的。我只是将生成的进程添加到我的“主”中的连接并在主中使用了回

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 - 使用包作为全局变量的存储

我正在学习golang,我的第一个任务是开始构建一个简单的网站。问题是我需要有一些可用的全局变量,我了解到使用上下文发送这些全局变量是不明智的,因为每个请求的上下文都应该不同。因此,我考虑过创建一个包,在main()中填充所需的变量。我在其他项目中没有看到这个解决方案,所以我想问这是不是错了?配置包的简单示例:packageconfigvarDB*sql.DB还有主要的:packagemainimport"project/config"funcmain(){config.DB,err=sql.Open("postgres",conn)iferr!=nil{panic(err)}}然后我

sql-server - 使用 ODBC 驱动程序调用 Microsoft SQL Server 上的存储过程

我有一个存储过程,名称为“vijaystoredprocedure”,如果它是mssql中的一些查询,那么我将在Go中查询,如l_query_str=fmt.Sprintf(`select*fromUserswhereFname='%s'`,l_firstanme)row,err:=DBC.Query(l_query_str)iferr!=nil{log.Fatal("Preparefailed:",err.Error())}_,rows,r_err:=DBScan_fn(row)ifr_err!=nil{fmt.Println("nodatafounderr")return}现在因为

go - 为用户可以编辑的页面(例如维基百科/stackoverflow 页面)设计数据存储架构

想法是设计一个表/实体,其中包含一些基本信息,以及一个Markdown-Content字段,允许用户轻松创建表等。我是这样想的:typeTournamentstruct{IDin64`datastore:"-"`MDContent[]byte`datastore:",noindex"`NamestringURLstringDateCreatedint64CreatedBystringDateUpdatedint64UpdatedBystringApprovalStatusint64//0=tobedecided,1=approved,2=rejected,3=discontinuedA

amazon-web-services - 获取 s3 存储桶上的资源 URI

目前,我使用字符串插值手动构造URI:fmt.Sprintf("https://%s.%s.amazonaws.com/%s/%s",serviceId,region,namespace,filename)恕我直言,当我通过环境变量的参数传递它们时,哪个不好。我可以访问使用我们的s3存储桶正确初始化的aws.Session对象。是否有一种语义上正确的方式(可能使用awssdkAPI)来生成与dummystringbuilder相同的资源URI? 最佳答案 从一个例子...虽然aws-sdk-go确实在svc.GetObjectReq

go - 使用 net/http 将结构值存储在每个请求 Golang 中

我是Golang的新手,我正在测试net/http以运行一些路径,但我遇到了一些我不明白的问题。这是我的代码。packagemainimport("fmt""net/http")typeContentstruct{Datamap[interface{}]interface{}}funcmain(){mux:=http.NewServeMux()mux.Handle("/favicon.ico",http.NotFoundHandler())mux.HandleFunc("/",Index)mux.HandleFunc("/test",Testhandler)http.ListenAnd

go - go 对象组件可以以复合模式相互通信吗?

我正在尝试实现复合设计模式。我了解了如何组合对象的对象。在这个例子中,我有一个运动员和游泳功能。typeAthletestruct{namestring}typeCompositeAthletestruct{athleteAthleteTrainfunc(namestring)}但是如果我需要在创建组合对象后传递名称:comp:=CompositeAthlete{athlete:athlete,Train:Swim,}comp.Train(athlete.name)是否有可能注入(inject)一个能够读取被注入(inject)对象内部的方法;packagemainimport("fm

ssl - 通过存储与 Wireshark 一起使用的 SSL key 在 golang 中解密 TLS

我正在尝试通过提供tls.Config来建立TLS连接包含Rand的结构应始终返回相同的字段int调用他们时Read方法,参见这里的文档:https://golang.org/pkg/crypto/tls/#Config我写了这个构建器:funcnewZeroRand()*rand.Rand{returnrand.New(rand.NewSource(0))}并进行测试以确保rand.Rand总是返回相同的int什么时候Read被多次调用,注意不同的输入参数"foo"和"bar"提供相同的输出:funcTestPredictableZeroRandGenerator(t*testing