由于EasyNTS智能组网是网络穿透平台,用户在外网可以在通过EasyNTS访问到内网的EasyNVR设备。上周我们在测试EasyNTS的功能时,发现同时在浏览器访问EasyNVR和EasyNTS会导致EasyNTS无法登陆。

问题分析
首先EasyNVR和EasyNTS是在同一服务器中部署的,用的是同一域名或者ip,在浏览器访问EasyNVR和EasyNTS,此时如果先登陆EasyNVR会在浏览器中的cookie中存入token,但是在EasyNTS的服务中首先会在cookie中检测token,但是此时的token是EasyNVR的就会导致验证错误,导致EasyNTS无法登陆。

输入登陆账号和密码,点击登陆,账号密码随即被清空无法正常登入。
解决问题
在登录EasyNTS的时候,我们可以设置不需要在cookie中验证token,因为EasyNTS中的token是存在session中的。
调整下代码:
token := sessions.GetToken(c)
// 如果查找到了 token
if token != consts.EmptyString {
username, password, str := security.ResolveToken(token)
if str == consts.EmptyString && username != consts.EmptyString

最低0.47元/天 解锁文章

被折叠的 条评论
为什么被折叠?



