• javaweb:判断当前请求是否为移动设备访问


           判断当前请求是否为移动端,然后设一个标识到session中,然后就可以随便处理了。不管你是单独处理,还是统一处理,直接读取session就可以做相应的判断了。

           我封装成了一个类,现在分享:

    [java] view plain copy
     print?在CODE上查看代码片派生到我的代码片
    1. package com.tgb.util;  
    2.   
    3. import java.util.regex.Matcher;  
    4. import java.util.regex.Pattern;  
    5.   
    6. /** 
    7.  * 检测是否为移动端设备访问 
    8.  *  
    9.  * @author      :  
    10.  * @group       : 
    11.  * @Version     :  
    12.  * @Date        :  
    13.  */  
    14. public class CheckMobile {  
    15.       
    16.     //  是单词边界(连着的两个(字母字符 与 非字母字符) 之间的逻辑上的间隔),    
    17.     // 字符串在编译时会被转码一次,所以是 "\b"    
    18.     // B 是单词内部逻辑间隔(连着的两个字母字符之间的逻辑上的间隔)    
    19.     static String phoneReg = "\b(ip(hone|od)|android|opera m(ob|in)i"    
    20.             +"|windows (phone|ce)|blackberry"    
    21.             +"|s(ymbian|eries60|amsung)|p(laybook|alm|rofile/midp"    
    22.             +"|laystation portable)|nokia|fennec|htc[-_]"    
    23.             +"|mobile|up.browser|[1-4][0-9]{2}x[1-4][0-9]{2})\b";    
    24.     static String tableReg = "\b(ipad|tablet|(Nexus 7)|up.browser"    
    25.             +"|[1-4][0-9]{2}x[1-4][0-9]{2})\b";    
    26.       
    27.     //移动设备正则匹配:手机端、平板  
    28.     static Pattern phonePat = Pattern.compile(phoneReg, Pattern.CASE_INSENSITIVE);    
    29.     static Pattern tablePat = Pattern.compile(tableReg, Pattern.CASE_INSENSITIVE);    
    30.         
    31.     /** 
    32.      * 检测是否是移动设备访问 
    33.      *  
    34.      * @Title: check 
    35.      * @Date : 
    36.      * @param userAgent 浏览器标识 
    37.      * @return true:移动设备接入,false:pc端接入 
    38.      */  
    39.     public static boolean check(String userAgent){    
    40.         if(null == userAgent){    
    41.             userAgent = "";    
    42.         }    
    43.         // 匹配    
    44.         Matcher matcherPhone = phonePat.matcher(userAgent);    
    45.         Matcher matcherTable = tablePat.matcher(userAgent);    
    46.         if(matcherPhone.find() || matcherTable.find()){    
    47.             return true;    
    48.         } else {    
    49.             return false;    
    50.         }    
    51.     }  
    52. }  

           使用方式:

    [java] view plain copy
     print?在CODE上查看代码片派生到我的代码片
    1. /** 
    2.  * 检查访问方式是否为移动端 
    3.  *  
    4.  * @Title: check 
    5.  * @Date : 
    6.  * @param request 
    7.  * @throws IOException  
    8.  */  
    9. public boolean check(HttpServletRequest request,HttpServletResponse response) throws IOException{  
    10.     boolean isFromMobile=false;  
    11.       
    12.     HttpSession session= request.getSession();  
    13.    //检查是否已经记录访问方式(移动端或pc端)  
    14.     if(null==session.getAttribute("ua")){  
    15.         try{  
    16.             //获取ua,用来判断是否为移动端访问  
    17.             String userAgent = request.getHeader( "USER-AGENT" ).toLowerCase();    
    18.             if(null == userAgent){    
    19.                 userAgent = "";    
    20.             }  
    21.             isFromMobile=CheckMobile.check(userAgent);  
    22.             //判断是否为移动端访问  
    23.             if(isFromMobile){  
    24.                 System.out.println("移动端访问");  
    25.                 session.setAttribute("ua","mobile");  
    26.             } else {  
    27.                 System.out.println("pc端访问");  
    28.                 session.setAttribute("ua","pc");  
    29.             }  
    30.         }catch(Exception e){}  
    31.     }else{  
    32.         isFromMobile=session.getAttribute("ua").equals("mobile");  
    33.     }  
    34.       
    35.     return isFromMobile;  
    36. }  

           在登录的时候,或者在action的execute中调用这个方法,不用改动原先的业务逻辑,即可判断请求的是否为移动端,然后再根据结果去做相应处理,应该就简单多了。

           其实我在做的过程中,还是遇到了一个比较头疼的问题。经理说移动端的应用要求使用json格式,所以我想统一做一个处理,如果是从移动端访问,那么就把request和session中设置的Attribute全部读取到map或者list中,然后再转化为json格式输出。想法的美好的,结果有点小残酷。就拿登录来说,登录以后要跳转到list.jsp页,结果现在直接输出list中的数据了,但是页面没有跳转。页面跳转和返回json是冲突的。输出json的话,输出流就会关闭,不让再跳转,否则会提示错误。不知道大家有没有好的解决方案,如果不行的话,只能每个请求单独处理了。

  • 相关阅读:
    自己感受,如何解读别人的好的PHP代码
    34. RunAs Authentication Replacement运行身份验证替换
    32.3.3 Authenticating to a Stateless Service with CAS(使用CAS向无状态服务进行身份验证)
    33.2 Adding X.509 Authentication to Your Web Application
    35.2 Encryptors加密器
    32.3.2 Single Logout(单点退出)
    33. X.509 Authentication
    34.2 Configuration
    32.3.4 Proxy Ticket Authentication代理票证认证
    35.3 Key Generators密钥生成器
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13317751.html
Copyright © 2020-2023  润新知