判断客户端手机类型,并跳转到相应的app下载页面
2014-08-20 23:13
597 查看
实现的原理,是检测浏览器的 USER-AGENT 这个header,然后根据正则表达式来确定客户端类型。
如果都不匹配,Fallback回退策略是显示对应的页面,让用户自己选择。
适合采用二维码扫描方式下载APP:
JSP版本的代码如下所示:其他服务端版本请百度搜索。
原帖地址: [您也可以访问向上交流论坛查看更多行业,开源,招聘信息]
如果都不匹配,Fallback回退策略是显示对应的页面,让用户自己选择。
适合采用二维码扫描方式下载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.iyhjy.com/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.iyhjy.com/upload/client/yhjyios.plist" class="apple download"><img src="images/p_down_apple.png" /></a> <a href="http://m.iyhjy.com/download.jsp?platform=android" class="download"><img src="images/p_down_and.png" /></a> </div> </body> </html>
相关文章推荐
- JSP中实现判断客户端手机类型并跳转到app下载页面
- 根据USER-AGENT判断手机类型并跳转到相应的app下载页面
- JSP中实现判断客户端手机类型并跳转到app下载页面
- 在线安装ipa ,跨过app-store / JSP中实现判断客户端手机类型并跳转到app下载页面
- 推断client手机类型,并跳转到对应的app下载页面
- h5判断移动设备是否安装了某app,有跳转,无则跳至下载页面
- js根据客户端浏览器类型,判断跳转官网/手机网站
- js根据手机客户端浏览器类型,判断跳转官网/手机网站多个实例代码
- 网页判断判断是否安装APP并启动,没有安装就跳转到下载页面
- JS判断设备类型跳转至PC端或移动端相应页面
- HTML中判断手机是否安装某APP,跳转或下载该应用
- ASP检测手机客户端并跳转到相应页面
- 通过手机浏览器打开APP或者跳转到下载页面.md
- 微信公众号H5页面跳转至app的某个页面,如果手机内没有app,则进入下载页面
- 【JS】点击页面判断是否安装app并打开,否则跳转下载的方法
- 通过手机浏览器打开APP或者跳转到下载页面.md
- JS判断客户端是否是iOS或者Android,js判断是不是qq,js判断是否是移动端,跳转到相应的页面
- js根据手机客户端浏览器类型,判断跳转官网/手机网站多个实例代码
- HTML中判断手机是否安装某APP,跳转或下载该应用
- PHP实现根据设备类型自动跳转相应页面的方法