草庐IT

端点安全

全部标签

go - 为什么我将 DELETE 路由器放在 GET 之后,DELETE 端点没有被触发

我正在使用Golang创建restfulAPI,我按索引将删除路由器放在getOne路由器之后,删除路由器从未被触发?我不知道为什么?当我反转它们时,它起作用了!有人能知道原因吗??这是为了使用Golang构建RestfulAPI。无效:myRouter.HandleFunc("/article",createNewArticle).Methods("POST")myRouter.HandleFunc("/article/{id}",getOneArticle)myRouter.HandleFunc("/article/{id}",deleteArticle).Methods("DEL

go - 由于 slice 中的项目数正在变化,如何安全地从 slice 中删除项目

在我遍历用户slice后,我需要根据某些条件从slice中删除一些用户。我将多次遍历此用户slice,慢慢删除一些元素。我从其他语言了解到,在循环时从集合中删除项目是不安全的。所以我正在做的是将我想要删除的元素存储在maptoMutate中。原始循环完成后,我会继续尝试从slice中删除元素。toMutate:=make(map[int]User,100)foridx,u:=rangec.users{ifsomeCondition{toMutate[idx]=u}}然后我调用此函数从用户的slice中删除项目。foridx,u:=rangetoMutate{c.users=append

multithreading - App Engine Channel API 的线程安全/原子性

当我尝试使用GoogleAppEngine的ChannelAPI从两个或多个goroutines和/或任务队列发送消息时会发生什么?例如gochannel.Send(context,clientID,"Hello")gochannel.Send(context,clientID,"World")我知道在GAEGo中,所有goroutines都被多路复用到一个线程上。然而,这仍然允许在I/O期间进行抢占,并且channel发送可能符合I/O的条件。GAE开发服务器似乎序列化了所有请求,所以我没有看到任何channel发送重叠。生产服务器似乎允许一些请求并发,但channel发送看起来是原

java - 谷歌云端点生成 Java api HTTP 400 错误

嘿,我正在尝试使用此文档开发一个休息APIgo-endpoints我可以在本地和应用引擎上测试我的应用。但我无法创建Java客户端以便在Android设备上使用它,出于某种原因,我得到了一个HTTP400NoJSONobjectcouldbedecoded在这个命令上GO_SDK/endpointscfg.pygen_client_libjavaMY_FILE_NAME这是完整的堆栈跟踪mik@mik-Aspire-S3:~/go-programs/src/cloudEndPoints/app$$HOME/go_appengine/endpointscfg.pygen_client_l

json - golang Google 端点接收 JSON 以进行 Google IAB 验证并存储到 Google Datastore

我是Go的新手,几乎尝试了所有方法来获取由Go运行的GoogleEndpoint,接收带有JSON的POST以进行验证,然后将其存储在GoogleDatastore中。Golang端点包https://github.com/GoogleCloudPlatform/go-endpoints这是我尝试POST到我的Go端点的JSON示例:{\"json\":{\"orderId\":\"123456789.12341234\",\"packageName\":\"com.company.name\",\"productId\":\"productName\",\"purchaseTime\

javascript - XMLHttpRequest 无法加载 localhost 资源,安全检查是 Chrome

我在OSX10.11.4上运行Chrome版本49.0.2623.108(64位)。从终端:我跑了:>ls/tmpwtf.jpg>ps-ef|grep-ichrome|grep-vgrep退出Chrome后,只需确保没有实例仍在运行。然后我使用以下参数打开Chrome以跳过跨源检查:>open/Applications/Google\Chrome.app/--args--allow-file-access-from-files"我也试过:>open/Applications/Google\Chrome.app/--args--disable-web-security"现在,我运行简单的

Go logging struct 实例化实用方法的 Goroutine 线程安全

我正在使用一个新的go服务,我有一个SetupLogger实用函数,它创建一个新的go-kit日志结构实例log.Logger。从在单独的go-routines中处理请求的代码调用此方法是否安全?packageutilsimport("fmt""github.com/go-kit/kit/log""io""os""path/filepath")//Iftheenvironment-specifieddirectoryforwritinglogfilesexists,opentheexistinglogfile//ifitalreadyexistsorcreatealogfileifno

ruby - 这个示例 tcp 套接字编程事件顺序安全吗?

我计划提供两项服务。用Ruby编写的HTTPREST服务用Go编写的JSONRPC服务Ruby服务将打开一个到GoJSONRPC服务的TCP套接字连接。它将为收到的每个传入HTTP请求执行此操作。它会通过套接字向Go服务发送一些数据,然后该服务会通过套接字发回相应的数据。Go代码Go服务go看起来像这样(简化):srv:=new(service.App)//thiswouldexposeaProcessmethodrpc.Register(srv)listener,err:=net.Listen("tcp",":8080")iferr!=nil{//handleerror}for{co

google-app-engine - Go Appengine 端点测试的问题

我正在尝试在使用appengine时创建端点测试。不幸的是,由于在创建测试*Request结构时使用的url中缺少模式(和主机),测试一直失败。运行应用引擎测试时,会为在半随机端口号上运行的特定测试生成一个服务器,这使得似乎无法定义完整的url来执行测试。像这样运行测试的officialdocs非常稀疏,只给出了一半的例子,所以我一直在摸索如何让它发挥作用。这是我从代码片段中标记的行得到的错误错误:收到意外错误“发布/auth:不支持的协议(protocol)方案\”\“”测试代码funcTestEndpoints_Auth(t*testing.T){//inputdataaccoun

json - 在带有 json 文件数据存储的 Golang 应用程序中,直接从客户端接受 json 是不安全的/不好的做法吗?

我有一个简单的Golang应用程序,它带有一个控制应用程序的HTTPAPI,该API有一个由React.js应用程序提供支持的前端。前端允许用户更改设置并将名为settings的json对象直接发布到API/api/settings端点(内置简单的JWT身份验证)。我将该对象解码为应用程序要使用的结构,以防应用程序使用默认结构并向客户端发送错误。我的问题是;我这样做是正确的还是不安全的?将json直接发送到应用程序,无需任何服务器端验证,而是一个简单的json.unmarshal?PS:我来自PHP+MySQL网络应用程序背景,在这种情况下接受数据库的客户端输入而不转义是一件非常危险的