>我正在运行一个网络应用程序,该应用程序在用户使用强制门户成功登录 wifi 网络后立即显示。
在 iOS 上,用户登录后,我的 Web 应用程序将显示在 CNA(强制网络助手)弹出窗口中,并且右上角的按钮标签将变为"确定"以允许用户关闭此弹出窗口。
当它显示在此 CNA 弹出窗口中时,我想在我的 Web 应用程序中有一个特定的行为,所以我正在尝试检测(使用 Javascript)我的 Web 应用程序是否显示在这样的弹出窗口中。
我首先押注 window.innerHeight 值,但在我的 iPhone 5 上似乎很难:
- 460px 高度在 Safari 中
- 共享连接或电话通话时 Safari 内部高度为 440 像素
- 内置专网网络助手高度 459 像素
- 共享连接或电话呼叫期间强制网络助手内部高度为 439 像素
在我看来,1px 的差异不足以弄清楚我是否在这个 CNA 弹出窗口中。
我是否可以依靠任何其他 JavaScript 信息来确定我是否在这样的弹出窗口中?
谢谢
我用用户代理检测到了 CNA。在 CNA 内部时,用户代理不会在 UA 字符串中包含"Safari/"。还测试了十几种替代浏览器,如 歌剧迷你, 海豚, 水星, 海雀, 原子, 360 精简版, ...
例如,Safari UA 字符串是:
Mozilla/5.0 (iPad; CPU OS 6_0 like Mac OS X) AppleWebKit/536.26 (KHTML, like Gecko) Version/6.0 Mobile/10A5355d Safari/8536.25
在同一设备上,在 CNA 内,用户代理字符串将为:
Mozilla/5.0 (iPad; CPU OS 6_0 like Mac OS X) AppleWebKit/536.26 (KHTML, like Gecko) Version/6.0 Mobile/10A5355d
所以在PHP中,我的检测看起来像:
$userAgent = strtolower($_SERVER['HTTP_USER_AGENT']);
if ((strpos($userAgent, 'iphone') || strpos($userAgent, 'ipad')) &&
(strpos($userAgent, 'mozilla/') !== false) &&
(strpos($userAgent, 'applewebkit/') !== false) &&
(strpos($userAgent, 'mobile/') !== false) &&
(strpos($userAgent, 'safari') === false))
{
// Yes, we are in a CNA popup
[...]
}