ASP.net用户代理检测移动应用程序加载站点

3
我们成功地使用以下asp.net正则表达式来进行服务器端检测移动浏览器访问我们的网站(取自http://detectmobilebrowsers.com/)。
Public Shared Function IsMobileBrowser(httpUserAgentString As String) As Boolean

    ' set up user agent sniffing (http://detectmobilebrowsers.com/)

    Dim b As New Regex("(android|ipad|playbook|silk|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows (ce|phone)|xda|xiino", RegexOptions.IgnoreCase)
    Dim v As New Regex("1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-", RegexOptions.IgnoreCase)

    If (b.IsMatch(httpUserAgentString) Or v.IsMatch(Left(httpUserAgentString, 4))) Then
        Return True
    Else
        Return False
    End If

End Function

然而,我们收到了用户通过QR阅读应用程序(如Qrafter)打开网站时失败的报告。这似乎是因为该应用程序(至少在iOS上的Qrafter的情况下)通过在应用程序内加载代码页面来“测试”该网站。在执行此操作时传递的User Agent字符串与移动浏览器测试不匹配,因此我们设置了一个会话变量,将站点模式存储为桌面/非移动设备。当通过应用程序进行完整加载后,它将以桌面模式而不是移动模式启动。
应用程序向我们的ASP.net代码呈现的User Agent字符串是:
Qrafter/6.3+CFNetwork/609+Darwin/13.0.0 200 0 0 178

因此,我们使用以下正则表达式方法来检测和忽略站点的“应用内”加载

Public Shared Function IsAppSniffer(httpUserAgentString As String) As Boolean

    Dim b As New Regex("\bCFNetwork\b.+\bDarwin\b", RegexOptions.IgnoreCase)

    If (b.Matches(httpUserAgentString).Count > 0) Then
        Return True
    Else
        Return False
    End If

End Function

基本上,我想知道这种测试是否可靠,以及在运行QRafter等应用程序的Android / Windows /其他手机上检测类似问题需要寻找什么。它们的基于应用程序的用户代理字符串是什么?还是说这可能是QRafter应用程序中特定的问题,因为它具有“URL测试”功能?

如果可能,请自由(建设性地)批评我们将移动/桌面站点模式存储在会话对象中的方法,但对于这个项目来说,进行重新设计可能有点晚了。

对于问题的冗长表示歉意,希望它仍然可以作为问答的适合部分,非常感谢您提供任何有用的信息。


编辑:正如史蒂芬(Stephen)所指出的那样,简而言之,我的问题实质上是,“是否有实际的方法可以检测直接从移动设备(任何品牌)发送的用户代理字符串以及它们的移动浏览器?”

例如(对于iOS / Safari配对)直接从应用程序中

AppName/CFNetwork/609+Darwin/13.0.0 200 0 0 178

Safari用户代理字符串

Mozilla/5.0+(iPhone;+CPU+iPhone+OS+6_0_1+like+Mac+OS+X)+AppleWebKit/536.26+(KHTML,+like+Gecko)+Mobile/10A523 200 0 0 20
2个回答

3
基本上,您的问题可以总结为:您通常可以检测浏览器,但有时候您无法获得预期的用户代理字符串,并且会将桌面版本发送到移动设备。
解决此问题的方法存在问题,因为每次出现新程序时,您都需要修改检测正则表达式。虽然这可以在循环和数据库表中完成,但仍需要大量维护和麻烦。不过,说实话,其他解决方案也是如此。必须有人维护“移动”浏览器列表。这可以是您自己,也可以是您付费使用的服务。
我会让桌面端执行浏览器及其版本的JavaScript检测(您如何检测浏览器的版本?)。如果它检测到正在移动设备上显示自己,则提供链接以将用户带到相关的移动页面。
您甚至可以更进一步,只有在用户代理不在Detect Mobile Browsers网站提供的列表中时,才将此逻辑添加到页面中。当然,这可能有点过度杀伤力。
很遗憾,在某个时候,你只能说“我们尽最大努力让某人看到网站的正确视图”,并对其工作方式感到满意。这种方式只能执行有限的自动检测,程序设计师会乐意尝试打破该逻辑,仅仅因为他们可以这样做。

感谢您对情况的简明总结和建议,Stephen。您说得对,基本上这个问题是在检测移动浏览器方面增加了一些复杂性,这并不是一门精确的科学,因此您只需尽力而为,但要允许轻松切换移动/桌面模式(可能是该网站设计的一个薄弱环节,从而加剧了自动检测问题)。 - Ted

2
你可以尝试使用类似51degrees.mobi这样的工具来进行浏览器检测,而不是自己编写解决方案。由于存在许多带有各种怪癖的组合,因此编写全面的解决方案很困难。

感谢你的建议,Scott。我想现在我们可能会继续在当前的移动设备检测正则表达式上使用额外的贴纸,并希望一旦客户停止通过QR码营销网站,这一切都会消失。但如果不行,那么51度似乎是我们进一步研究的东西。 - Ted

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接