JSP中實現(xiàn)判斷客戶端手機類型并跳轉到app下載頁面
更新時間:2014年09月04日 09:38:02 投稿:junjie
這篇文章主要介紹了JSP中實現(xiàn)判斷客戶端手機類型并跳轉到app下載頁面,實現(xiàn)的原理,是檢測瀏覽器的 USER-AGENT 這個header,然后根據(jù)正則表達式來確定客戶端類型,需要的朋友可以參考下
判斷客戶端手機類型,并跳轉到相應的app下載頁面
實現(xiàn)的原理,是檢測瀏覽器的 USER-AGENT 這個header,然后根據(jù)正則表達式來確定客戶端類型。
如果都不匹配,F(xiàn)allback回退策略是顯示對應的頁面,讓用戶自己選擇。
適合采用二維碼掃描方式下載APP:
JSP版本的代碼如下所示:其他服務端版本請百度搜索。
<%@page import="java.util.regex.Matcher"%>
<%@page import="java.util.regex.Pattern"%>
<%@ page language="java" pageEncoding="UTF-8"%>
<%!
// \b 是單詞邊界(連著的兩個(字母字符 與 非字母字符) 之間的邏輯上的間隔),字符串在編譯時會被轉碼一次,所以是 "\\b"
// \B 是單詞內部邏輯間隔(連著的兩個字母字符之間的邏輯上的間隔)
String androidReg = "\\bandroid|Nexus\\b";
String iosReg = "ip(hone|od|ad)";
Pattern androidPat = Pattern.compile(androidReg, Pattern.CASE_INSENSITIVE);
Pattern iosPat = Pattern.compile(iosReg, Pattern.CASE_INSENSITIVE);
public boolean likeAndroid(String userAgent){
if(null == userAgent){
userAgent = "";
}
// 匹配
Matcher matcherAndroid = androidPat.matcher(userAgent);
if(matcherAndroid.find()){
return true;
} else {
return false;
}
}
public boolean likeIOS(String userAgent){
if(null == userAgent){
userAgent = "";
}
// 匹配
Matcher matcherIOS = iosPat.matcher(userAgent);
if(matcherIOS.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();
System.out.println("userAgent: "+userAgent);
if(null == userAgent){
userAgent = "";
}
if(likeAndroid(userAgent)){
System.out.println("likeAndroid: "+true);
response.sendRedirect("http://m.jb51.net/download.jsp?platform=android");
return;
//request.getRequestDispatcher("/download.html").forward(request,response);
} else if(likeIOS(userAgent)){
System.out.println("likeIOS: "+true);
response.sendRedirect("http://itunes.apple.com/us/app/id714751061");
return;
//request.getRequestDispatcher("/index.html").forward(request,response);
}
%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no">
<title>下載客戶端 - 永恒記憶</title>
<link href="css/style.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div class="p_down">
<div>
<a href="index.html">
<img src="images/p_logo.png" class="p_logo" />
</a>
</div>
<a href="itms-services://?action=download-manifest&url=http://m.jb51.net/upload/client/yhjyios.plist" class="apple download"><img src="images/p_down_apple.png" /></a>
<a class="download"><img src="images/p_down_and.png" /></a>
</div>
</body>
</html>
您可能感興趣的文章:
- JS如何實現(xiàn)網(wǎng)站中PC端和手機端自動識別并跳轉對應的代碼
- JS前端開發(fā)判斷是否是手機端并跳轉操作(小結)
- JS跳轉手機站url的若干注意事項
- js根據(jù)手機客戶端瀏覽器類型,判斷跳轉官網(wǎng)/手機網(wǎng)站多個實例代碼
- 基于JavaScript代碼實現(xiàn)pc與手機之間的跳轉
- js判斷手機訪問或者PC的幾個例子(常用于手機跳轉)
- 兩款JS腳本判斷手機瀏覽器類型跳轉WAP手機網(wǎng)站
- JS腳本根據(jù)手機瀏覽器類型跳轉WAP手機網(wǎng)站(兩種方式)
- 百度判斷手機終端并自動跳轉js代碼及使用實例
- 手機平板等移動端適配跳轉URL的js代碼
- JS自動跳轉手機移動網(wǎng)頁的實現(xiàn)方法
相關文章
淺談SpringMVC jsp前臺獲取參數(shù)的方式 EL表達式
下面小編就為大家分享一篇淺談SpringMVC jsp前臺獲取參數(shù)的方式 EL表達式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-03-03

