程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> JSP編程 >> 關於JSP >> JSP判斷移動設備

JSP判斷移動設備

編輯:關於JSP

日期: 2014年3月6日

人員::鐵錨

看到了一篇很好的文章, 《在天貓,前端做什麼?》,裡面有天貓php判斷移動設備的正則(個人猜測),覺得很好用,於是就決定移植到JSP裡面。

jsp文件名為 index.jsp,其實也可以使用過濾器來進行攔截,然後跳轉到其他域名去。

完整代碼如下:

<%@page import="java.util.regex.Matcher"%>
<%@page import="java.util.regex.Pattern"%>
<%@ page language="java" pageEncoding="UTF-8"%>
<%!

// \b 是單詞邊界(連著的兩個(字母字符 與 非字母字符) 之間的邏輯上的間隔),
// 字符串在編譯時會被轉碼一次,所以是 "\\b"
// \B 是單詞內部邏輯間隔(連著的兩個字母字符之間的邏輯上的間隔)
String phoneReg = "\\b(ip(hone|od)|android|opera m(ob|in)i"
		+"|windows (phone|ce)|blackberry"
		+"|s(ymbian|eries60|amsung)|p(laybook|alm|rofile/midp"
		+"|laystation portable)|nokia|fennec|htc[-_]"
		+"|mobile|up.browser|[1-4][0-9]{2}x[1-4][0-9]{2})\\b";
String tableReg = "\\b(ipad|tablet|(Nexus 7)|up.browser"
		+"|[1-4][0-9]{2}x[1-4][0-9]{2})\\b";
Pattern phonePat = Pattern.compile(phoneReg, Pattern.CASE_INSENSITIVE);
Pattern tablePat = Pattern.compile(tableReg, Pattern.CASE_INSENSITIVE);

public boolean checkMobile(String userAgent){
	if(null == userAgent){
		userAgent = "";
	}
	// 匹配
	Matcher matcherPhone = phonePat.matcher(userAgent);
	Matcher matcherTable = tablePat.matcher(userAgent);
	if(matcherPhone.find() || matcherTable.find()){
		return true;
	} else {
		return false;
	}
}
%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";

//
String userAgent = request.getHeader( "USER-AGENT" ).toLowerCase();

if(null == userAgent){
	userAgent = "";
}
if(checkMobile(userAgent)){
	response.sendRedirect(basePath+"download.html");
	//request.getRequestDispatcher("/download.html").forward(request,response);
} else {
	response.sendRedirect(basePath+"index.html");
	//request.getRequestDispatcher("/index.html").forward(request,response);
}
//
%>



  
    
    
    測試移動設備跳轉
	
	
	    
	
	
	
  
  
  
  
  
  
    正在運行!


  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved