草庐IT

安全攻防

全部标签

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

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

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

【攻防世界】Web very_easy_sql

做了web才发现,原来自己是真的什么都不懂啊,不过也好,说明我有很大的进步空间呢······不闲聊了,来看题目打开是一个登录界面,我们抓包看看返回些什么返回包有三个需要注意的地方,我都用框框圈起来了有一个Set-Cookie代表如果输入正确的账号跟密码是可以返回的,可以尝试爆破第二个发现了一个新的页面use.php,我们可以访问看看第三个,返回了一句话:youarenotaninneruser,sowecannotletyouhaveidentify~翻译就是:您不是内部用户,所以我们不能让您有身份~意思应该是我们要从内部登录吧?我们访问一下use.php这个页面看起来是一个输入url能跳转的

linux - 使用 Go 在 Linux 中以编程方式安全地挂载网络位置

在Linux中,我可以像这样使用Go以编程方式挂载网络位置:funcmain(){varuser,passstringfmt.Println("username:")fmt.Scanln(&user)//ignoreerrorsforbrevityfmt.Println("password:")fmt.Scanln(&pass)cmd:=exec.Command("mount","-t","cifs","-o","username="+user+",password="+pass,"//server/dir","media/dir")cmd.Run()}问题:如果不使用sudo提升权限

http - 在请求进行中修改 golang Http Transport 是否安全?

我有一个基于每个请求通过代理轮换的应用程序。目前我有一些代码是:func(mon*Monitor)MassUrlRetrieve(nint,urlstring)(respBytes[]byte){funnel:=make(chan[]byte)goProductRetrieveTimeout(TIMEOUT_RETRIEVE_URL,funnel)fori:=0;i基本上发送多个请求并返回第一个请求以响应/如果没有及时响应则超时。在WrapGetUrlToChannel中,我创建了一个新的代理url,并将其分配给mon的client.tr.Proxy。我的问题是-在请求进行期间修改客户

macos - 安全 : SecKeychainSearchCopyNext Error - Unable to Install Delve on MacOS

我使用以下方法安装了Delve:brewinstalldelve日志显示了一些问题:brewinstallgo-delve/delve/delveUpdatingHomebrew...==>Installingdelvefromgo-delve/delve==>Downloadinghttps://github.com/derekparker/delve/archive/v1.0.0.tar.gzAlreadydownloaded:/Users/user/Library/Caches/Homebrew/delve-1.0.0.tar.gzsecurity:SecKeychainSear

go - 在没有锁的情况下并发读取函数指针是否安全?

假设我有这个:gofunc(){forrangetime.Tick(1*time.Millisecond){a,b=b,a}}()其他地方:i:=a//对于这个问题,i相对于原始a或b的值是什么并不重要。唯一的问题是阅读a是否安全。也就是说,a是否有可能为nil、部分分配、无效、未定义……除有效值之外的任何值?I'vetriedtomakeitfail但到目前为止它总是成功(在我的Mac上)。我无法在TheGoMemoryModel中找到除此引用之外的任何具体信息文档:Readsandwritesofvalueslargerthanasinglemachinewordbehaveasm

go - 如何使变量成为线程安全的

我是Go的新手,我需要创建一个线程安全的变量。我知道在Java中您只能使用synchronized关键字,但是go中似乎不存在这样的内容。有什么方法可以同步变量? 最佳答案 Java中的synchronized是仅允许单个线程(在任何给定时间)执行代码块的方法。在Go中,有许多构造可以实现该目标(例如mutt,channel,waitgroups,sync/atomic中的原语),但是Go的谚语是:“不要通过共享内存进行通信;而是通过通信来共享内存。”因此,与其锁定和共享变量,不如不要这么做,而要在goroutines之间传递结果,

kkfileview阿里云安全扫描:威胁类型敏感信息回显 (Sensitive Information Response)

在阿里云部署的kkfileview,阿里云安全性扫描有漏洞网络流量内容GET/getCorsFile?urlPath=file:///etc/passwdHTTP/1.1Host:XXX.XXX.XXXX.XXX:80XXUser-Agent:Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/66.6.2333.33Safari/537.36AliyunTaiShiGanZhihttps://www.aliyun.com/product/sasAccept-Encoding:gzip,de

multithreading - 阅读缓存DIY书时的一个Go map线程安全问题

我正在读一本书,它教我如何编写像Redis这样的简单缓存。以实现分布式哈希为目标,项目必须有key迁移,这需要一个迭代器。而且我认为可能存在一些问题。他的书是关于迭代map的,但是在迭代的同时,读取锁的保持不是连续的。原因是尽量不影响主缓存进程。我相信一定存在线程安全问题,因为主缓存线程仍在写入映射。我写了一个演示,但不确定。//bookcodetypeinMemoryScannerstruct{pairpairChan*paircloseChchanstruct{}}func(c*inMemoryCache)NewScanner()Scanner{pairCh:=make(chan*