golang net/http tls客户端频繁请求 401 Unauthorized

golang net/http tls客户端频繁请求 401 Unauthorized

一、烟零蛋

其实这个问题是《golang操作华为防火墙ACL实现远程启停》里遇到的,项目做完准备交付,测试偶尔遇到前端一直转圈(前后端不分离项目)。经过定位发现卡在了获取防火墙策略状态那里,再fiddler抓包看到了请求发出后一直没数据返回,加上默认http.Client没设置超时处理,导致后端也无法返回数据。

为什么restConf服务不返回数据呢? 用fiddler直接模拟请求,也卡住了,根本没返回消息;再用python来请求,也是没任何数据响应;最后重启restConf服务,api https enable,问题暂时解决,但是前端多刷新几次后,又出现卡顿了。

zepto.js双击事件及双击DIV时不要选中文字

一个小项目中使用到了zepto库,前端想实现双击div触发事件,开始用的是doubleTap,移动端可以实现双击点击,但是PC端却没反应。试了jquery的dbclick没生效,google找了很久没找到。

后来在zepto.js源码中搜索click,找到了dblclick,直接测试,成功!

           /*
           $('.status-bar').doubleTap(() => {
                             
                $.toptip('doubleTap','success')
            });
            */

            $('.status-bar').dblclick(() => {
                $.toptip('doubleclick', 'warning')
            });

golang操作华为防火墙ACL实现远程启停2

golang操作华为防火墙ACL实现远程启停2---寻找真相

一、摸索

上文提到用go开发的程序对接防火墙api时出现remote error: tls: handshake failure,虽然通过调低防火墙api security加密算法强度解决了,但是总感觉怪怪的。因为用python和curl 简单测试了下,都能正常访问,难道golang还落后了?

为了搞清楚原因,先是设置了InsecureSkipVerify,测试没效果;再指定tls版本MaxVersion: tls.VersionTLS12, MinVersion: tls.VersionTLS12,也没效果;改写VerifyPeerCertificate ,直接return nil,测试还是没效果。

怀疑go需要手动指定证书,把cer转成pem后==(用openssl可以转)==,加载到RootCAs,测试还是不行。

golang操作华为防火墙ACL实现远程启停1

golang操作华为防火墙ACL实现远程启停

一、需求

某个服务端应用A在地点P1,地点P2通过网关建立的VPN来访问P1(A服务器禁止上外网,外网也不能访问A的服务)。这个A服务上线运行后,P2日常访问没什么问题。某天来了个新需求,为了增加A服务的安全性,P2不能再随意访问。要求:

  • 指定的管理人员可以在任意地方查看当前服务的状态==开启或关闭==。
  • 指定的管理人员可以随时在任意地方开启或关闭服务

Golang实现windows两个应用程序进程间通信之二Winio的Bug

Golang实现windows两个应用程序进程间通信之二Winio的Bug

上回提到源码能正常跑起来了,但多次测试后发现有个很严重的问题。在win7下,客户端首次dial时成功连接上后write就阻塞了,而且服务端并没有收到新的请求,一直阻塞在Accept。刚开始还以为自己的代码有问题,试了很多次,才发现这个Bug。网上的代码其实没问题,只是我这Win7系统,直接触发Bug了。

github https://github.com/microsoft/go-winio/issues/173 上有提到这个问题,但官方并没有修复,有人判断是因为微软不再更新Win7了。

I was trying go-winio in my project, but I noticed that the same code had diffe