package com.testm.util;
import javax.servlet.http.HttpServletRequest;
public class HttpRequestDeviceUtils {
/**
* User-Agent in Via header for Wap gateway
*/
private static String mobileGateWayHeaders[] = new String[] {
"ZXWAP", // ZTE,e.g. Via=ZXWAP
// GateWayZTE
// Technologies,
"chinamobile.com", // China Mobile, e.g. Via=WTP/1.1
// GDSZ-PB-GW003-WAP07.gd.chinamobile.com (Nokia
// WAP Gateway 4.1 CD1/ECD13_D/4.1.04)
"monternet.com", // China Mobile, e.g. Via=WTP/1.1
// BJBJ-PS-WAP1-GW08.bj1.monternet.com. (Nokia
// WAP Gateway 4.1 CD1/ECD13_E/4.1.05)
"infoX", // Huawei, e.g. Via=HTTP/1.1 GDGZ-PS-GW011-WAP2
// (infoX-WISG Huawei Technologies),或Via=infoX WAP
// Gateway V300R001 Huawei Technologies
"XMS 724Solutions HTG",
"Bytemobile",//Via=1.1 Bytemobile OSN
// WebProxy/5.1
};
/**
* the User-Agent in Firefox for PC
*/
private static String[] pcHeaders = new String[] { "Windows 98", "Windows ME", "Windows 2000", "Windows XP",
"Windows NT", "Ubuntu" };
/**
* the User-Agent in cell phone browser
*/
private static String[] mobileUserAgents = new String[] { "Nokia", //Mozilla/5.0
// (Nokia5800
// XpressMusic)UC
// AppleWebkit(like
// Gecko)
// Safari/530
"SAMSUNG", // SAMSUNG-GT-B7722/1.0+SHP/VPP/R5+Dolfin/1.5+Nextreaming+SMM-MMS/1.2.0+profile/MIDP-2.1+configuration/CLDC-1.1
"MIDP-2", // j2me2.0,Mozilla/5.0 (SymbianOS/9.3; U; Series60/3.2
// NokiaE75-1 /110.48.125 Profile/MIDP-2.1
// Configuration/CLDC-1.1 ) AppleWebKit/413 (KHTML like
// Gecko) Safari/413
"CLDC1.1", // M600/MIDP2.0/CLDC1.1/Screen-240X320
"SymbianOS",
"MAUI",
"UNTRUSTED/1.0",
"Windows CE", // Windows CE,Mozilla/4.0 (compatible; MSIE 6.0;
// Windows CE; IEMobile 7.11)
"iPhone", // Mozilla/5.0 (iPhone; U; CPU
// iPhone OS 4_1 like Mac OS X; zh-cn) AppleWebKit/532.9
// (KHTML like Gecko) Mobile/8B117
"iPad", // Mozilla/5.0 (iPad; U; CPU OS 3_2 like Mac OS X;
// zh-cn) AppleWebKit/531.21.10 (KHTML like Gecko)
// Version/4.0.4 Mobile/7B367 Safari/531.21.10
"Android", //Mozilla/5.0 (Linux; U; Android
// 2.1-update1; zh-cn; XT800 Build/TITA_M2_16.22.7)
// AppleWebKit/530.17 (KHTML like Gecko) Version/4.0
// Mobile Safari/530.17
"BlackBerry", // BlackBerry8310/2.7.0.106-4.5.0.182
"UCWEB", // Nokia5800
// XpressMusic/UCWEB7.5.0.66/50/999
"ucweb", // Mozilla/6.0 (compatible; MSIE 6.0;)
// Opera ucweb-squid
"BREW", // REW-Applet/0x20068888 (BREW/3.1.5.20; DeviceId:
// 40105; Lang: zhcn) ucweb-squid
"J2ME",
"YULONG", //YULONG-CoolpadN68/10.14 IPANEL/2.0 CTC/1.0
"YuLong",
"COOLPAD", //YL-COOLPADS100/08.10.S100 POLARIS/2.9 CTC/1.0
"TIANYU", //TIANYU-KTOUCH/V209/MIDP2.0/CLDC1.1/Screen-240X320
"TY-", //TY-F6229/701116_6215_V0230 JUPITOR/2.2 CTC/1.0
"K-Touch", //K-Touch_N2200_CMCC/TBG110022_1223_V0801 MTK/6223
// Release/30.07.2008 Browser/WAP2.0
"Haier", //Haier-HG-M217_CMCC/3.0 Release/12.1.2007
// Browser/WAP2.0
"DOPOD",
"Lenovo", //Lenovo-P650WG/S100 LMP/LML Release/2010.02.22
// Profile/MIDP2.0 Configuration/CLDC1.1
"LENOVO", //LENOVO-P780/176A
"HUAQIN",
"AIGO-", //AIGO-800C/2.04 TMSS-BROWSER/1.0.0 CTC/1.0
"CTC/1.0",
"CTC/2.0",
"CMCC", //K-Touch_N2200_CMCC/TBG110022_1223_V0801 MTK/6223
// Release/30.07.2008 Browser/WAP2.0
"DAXIAN", //DAXIAN X180 UP.Browser/6.2.3.2(GUI) MMP/2.0
"MOT-", //MOT-MOTOROKRE6/1.0 LinuxOS/2.4.20 Release/8.4.2006
// Browser/Opera8.00 Profile/MIDP2.0 Configuration/CLDC1.1
// Software/R533_G_11.10.54R
"SonyEricsson", //SonyEricssonP990i/R100 Mozilla/4.0
// (compatible; MSIE 6.0; Symbian OS; 405) Opera
// 8.65 [zh-CN]
"GIONEE",
"HTC",
"ZTE", //ZTE-A211/P109A2V1.0.0/WAP2.0 Profile
"HUAWEI",
"webOS", //Mozilla/5.0 (webOS/1.4.5; U; zh-CN)
// AppleWebKit/532.2 (KHTML like Gecko) Version/1.0
// Safari/532.2 Pre/1.0
"GoBrowser", // 3g GoBrowser.User-Agent=Nokia5230/GoBrowser/2.0.290
// Safari
"IEMobile", // Windows CE
"WAP2.0"
};
/**
* check whether the request comes from mobile browser or not
* @param request
* @return true if the request is from mobile browser, otherwise return false
*/
public static boolean isMobileDevice(HttpServletRequest request) {
boolean pcFlag = false;
boolean mobileFlag = false;
String via = request.getHeader("Via");
String userAgent = request.getHeader("user-agent");
for (int i = 0; via != null && !via.trim().equals("") && i < mobileGateWayHeaders.length; i++) {
if (via.contains(mobileGateWayHeaders[i])) {
mobileFlag = true;
break;
}
}
for (int i = 0; !mobileFlag && userAgent != null && !userAgent.trim().equals("")
&& i < mobileUserAgents.length; i++) {
if (userAgent.contains(mobileUserAgents[i])) {
mobileFlag = true;
break;
}
}
for (int i = 0; userAgent != null && !userAgent.trim().equals("") && i < pcHeaders.length; i++) {
if (userAgent.contains(pcHeaders[i])) {
pcFlag = true;
}
}
if (mobileFlag == true && mobileFlag != pcFlag) {
return true;
}
return false;
}
}
相关推荐
判断是否电脑端打开,判断是否是手机端打开。 百度搜索到的文章,基本上是抄袭,如果用pc端浏览器模拟手机端,都是能通过的,此代码是真实检测是否是pc端/手机端,即使浏览器模拟也能判断。
PHP实现判断访问端是手机还是电脑 一、 开发环境 1、环境搭建:Windows 7+Apache 2.4.18+MySQL 5.7.11+PHP 7.1.0。 2、文本编辑器:Sublime 3。 二、主要技术 本案例主要使用PHP 7中的HTTP头信息via、浏览器代理...
JS判断客户端是否是手机还是PC、直接放入自己的代码里即可使用。
"JS判断手机端与电脑访问"这个话题就是关于如何使用JavaScript来检测用户是通过移动设备(如智能手机或平板)还是桌面电脑(如笔记本或台式机)访问网站的。这通常涉及到设备的屏幕尺寸、触屏支持、浏览器特性等因素...
### 手机端字体判断与动态调整技术解析 #### 一、引言 在移动互联网时代,为了确保网站能够在不同尺寸的屏幕上呈现良好的视觉效果,前端开发者常常需要根据设备屏幕的宽度来动态调整页面中的字体大小。这种方法...
本教程将详细介绍如何使用PHP判断用户是通过PC端还是手机端进行访问,并提供了一个简单的示例代码。 首先,我们要理解的是,PHP是一种服务器端的脚本语言,它不能直接获取用户的浏览器信息,但可以通过分析HTTP请求...
"php判断手机访问"这个主题主要涉及到如何利用PHP来检测用户代理(User-Agent)字符串,从而识别访问者使用的设备类型。 User-Agent是一个HTTP头部字段,由浏览器发送给服务器,包含了浏览器的类型、版本以及操作...
"php入口文件自动判断手机web端跳转"这一主题,主要涉及到如何在PHP的入口文件(如index.php)中检测用户的设备类型,并据此进行相应处理。以下将详细介绍这一过程。 首先,我们需要理解“入口文件”在PHP Web应用...
"JS判断手机端和PC端后跳转对应页面"这个话题就是关于如何使用JavaScript来检测用户的设备类型,并据此决定加载哪个页面。下面将详细介绍这一技术的实现原理和步骤。 首先,我们可以通过检测浏览器的User Agent字符...
几种判断设备是否是移动端还是pc端,然后在进行是否跳转页面,达到匹配的效果
主要介绍了JS前端开发判断是否是手机端并跳转操作,非常不错,具有参考借鉴价值,需要的朋友可以参考下
"php手机端访问网站和平板电脑登录判断"这个话题涉及到如何利用PHP脚本检测用户是通过手机、平板还是桌面电脑访问网站。Mobile-Detect-2.6.4是一个流行的PHP库,专门用于检测设备类型,它提供了丰富的功能来识别各种...
if((navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|wOSBrowser|BrowserNG|WebOS)/i))) { [removed]('<link href="css/mobile.css" rel="stylesheet" type=... }判断手机端访问调用的css
alert("在手机端微信上打开的"); } else { alert("在手机上非微信上打开的"); } } ``` 最后,判断是否在微信浏览器上打开。这里定义了一个`isWechart`函数,它首先通过`isMobile`函数检测是否为移动端,然后...
在网页开发中,判断用户访问的是手机端还是桌面端是一个常见的需求,这有助于提供不同的页面布局或功能,以优化用户体验。这段"检测是否是手机端的JS代码"就是解决这个问题的关键。下面,我们将深入探讨这个知识点,...
手机端微商城和PC端商城一体化,集成微信登录和微信支付接口,同一个数据库同一个后台管理,同一个域名网址实现手机端和PC端自动判断,手机访问即显示手机端,电脑访问即显示PC端。OpenWBS X5.3.4_190909 更新日志V5...
通过JS语句判断WEB网站的访问端是电脑还是手机,copy即可使用!
本文将详细介绍如何在ThinkPHP中判断用户是使用手机还是PC进行访问。 首先,我们要获取用户的浏览器发送到服务器的`HTTP_USER_AGENT`头信息。这个头信息包含了用户使用的浏览器类型、版本以及其他设备信息。在...
在JavaScript编程中,判断手机端跳转是一种常见的需求,特别是在构建响应式网站或者需要针对不同设备提供不同体验的场景下。这个主题涉及到几个关键知识点,包括用户代理检测、设备适配以及JavaScript事件处理。 ...
在"shiro管理多登录入口配置,手机端登录与网页端登录"这个场景下,我们需要考虑如何为不同的登录入口(手机端和网页端)设置独立的验证流程。 首先,Shiro 的核心组件 Realm 负责与应用数据源交互,验证用户身份。...