由于移动端和pc端还是稍微有些区别的,我觉得最好是在一个地儿统一判断,而且不要改动原先的代码,这样可以从一定程度上减少bug的数量。我的想法是首先应该判断当前请求是否为移动端,然后设一个标识到session中,然后就可以随便处理了。不管你是单独处理,还是统一处理,直接读取session就可以做相应的判断了。

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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
package com.tgb.util;
  
import java.util.regex.Matcher;
import java.util.regex.Pattern;
  
/**
 * 检测是否为移动端设备访问
 *
 * @author  :
 * @group  :
 * @Version  :
 * @Date  :
 */
public class CheckMobile {
   
 // \b 是单词边界(连着的两个(字母字符 与 非字母字符) 之间的逻辑上的间隔),
 // 字符串在编译时会被转码一次,所以是 "\\b"
 // \B 是单词内部逻辑间隔(连着的两个字母字符之间的逻辑上的间隔)
 static 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";
 static String tableReg = "\\b(ipad|tablet|(Nexus 7)|up.browser"
   +"|[1-4][0-9]{2}x[1-4][0-9]{2})\\b";
   
 //移动设备正则匹配:手机端、平板
 static Pattern phonePat = Pattern.compile(phoneReg, Pattern.CASE_INSENSITIVE);
 static Pattern tablePat = Pattern.compile(tableReg, Pattern.CASE_INSENSITIVE);
   
 /**
  * 检测是否是移动设备访问
  *
  * @Title: check
  * @Date :
  * @param userAgent 浏览器标识
  * @return true:移动设备接入,false:pc端接入
  */
 public static boolean check(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;
  }
 }
}

使用方式:

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

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

javaweb判断当前请求是否为移动设备访问的方法的更多相关文章

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

    http://blog.csdn.net/educast/article/details/71157932

  2. 判断http 请求来自于手机还是PC

    首先收集了部分客户端请求头部信息如下 iPhone微信: User-Agent: Mozilla/5.0 (iPhone; CPU iPhone OS 8_1_2 like Mac OS X) App ...

  3. 判断Http请求由手机端发起,还是有电脑端发起

    某些情形,我们需要判断Http请求是来自手机端还是电脑端,关键是取得User-Agent的信息,进行筛选判断即可. 核心类如下: public static boolean isMobileDevic ...

  4. 使用PHP判断是否为微信、支付宝等移动设备访问代码

    在开发过程中经常遇到根据不同的设备显示不同的数据或者在页面样式上做不同的布局,另外在做支付接口的时候也可能会判断当前是什么设备访问,例如判断如果是微信内置浏览器访问则只启用微信支付功能,如果是支付宝内 ...

  5. PHP判断设备访问来源

    /** * 判断用户请求设备是否是移动设备 * @return bool */ function isMobile() { //如果有HTTP_X_WAP_PROFILE则一定是移动设备 if (is ...

  6. [转]NGINX-检测客户端是通过电脑还是移动设备访问的,将请求重定向到适配的WEB站点

    原文地址:https://blog.51cto.com/10978134/2163757 检测客户端是通过电脑还是移动设备访问的,将请求重定向到适配的WEB站点 此配置方法由Detect Mobile ...

  7. 前端判断用户请求是PC还是移动端

    链接:https://www.zhihu.com/question/20004700/answer/13678113 第一步先在服务器端使用User Agent判断,先匹配出移动设备,这一步可以统计U ...

  8. MVC项目中如何判断用户是在用什么设备进行访问

    使用UAParser在C#MVC项目中如何判断用户是在用什么设备进行访问(手机,平板还是普通的电脑) 现在我们开发的很多web应用都要支持手机等移动设备.为了让手机用户能有更加好的用户体验,我们经常为 ...

  9. axios(封装使用、拦截特定请求、判断所有请求加载完毕)

    博客地址:https://ainyi.com/71 基于 Promise 的 HTTP 请求客户端,可同时在浏览器和 Node.js 中使用 vue2.0之后,就不再对 vue-resource 更新 ...

随机推荐

  1. Oracle RAC常用命令

    Oracle Clusterware的命令集可以分为以下4种,其中用的最多的是crsctl和srvctl:节点层:osnodes olsnodes -n -i -s olsnodes -l -p 网络 ...

  2. git 往远端Dev推送

  3. kafka-server.properties

    # Licensed to the Apache Software Foundation (ASF) under one or more # contributor license agreement ...

  4. paper 161:python的Json数据解析

    概念 序列化(Serialization):将对象的状态信息转换为可以存储或可以通过网络传输的过程,传输的格式可以是JSON.XML等.反序列化就是从存储区域(JSON,XML)读取反序列化对象的状态 ...

  5. 【c#技术】一篇文章搞掂:Newtonsoft.Json Json.Net

    一.介绍 Json.Net是一个.Net高性能框架. 特点和好处: 1.为.Net对象和JSON之间的转换提供灵活的Json序列化器: 2.为阅读和书写JSON提供LINQ to JSON: 3.高性 ...

  6. django中常见命令总结

    一,创建一个django项目: django-admin.py startproject mysite二,在mysite目录下创建blog应用: python manage.py startapp b ...

  7. SpringBoot 快速构建微服务体系 知识点总结

    可以通过http://start.spring.io/构建一个SpringBoot的脚手架项目 一.微服务 1.SpringBoot是一个可使用Java构建微服务的微框架. 2.微服务就是要倡导大家尽 ...

  8. MySQL的limit分页性能测试加优化

    日常我们分页时会用到MySQL的limit字段去处理,那么使用limit时,有什么需要优化的地方吗?我们来做一个试验来看看limit的效率问题:环境:CentOS 6 & MySQL 5.71 ...

  9. Visual Studio禁用IntelliSense

    通过Everything搜索feacp.dll,然后修改其名字或者直接删除之. 重启Visual Studio.

  10. python 装饰器 第四步:基本装饰器的实现

    #第四步:基本装饰器的实现 #用于扩展基本函数的函数 def kuozhan(func): #内部函数(扩展之后的eat函数) def neweat(): #以下三步就是扩展之后的功能,于是我们把这三 ...