java 获取请求方浏览器信息

首先要加入 请求头参数分析包

       <!-- 请求头参数分析包 -->
<!--       <dependency> -->
<!--          <groupId>eu.bitwalker</groupId> -->
<!--          <artifactId>UserAgentUtils</artifactId> -->
<!--          <version>1.21</version> -->
<!--       </dependency> -->

然后根据以下方式获取即可;

重点是:获取到UserAgent对象 ,有了UserAgent 就可以获取浏览器信息了。

/**
	 * 未知IP
	 */
	private static final String UNKNOWN = "unknown";

	/**
	 * 获取浏览器名字
	 *
	 * @param request 请求
	 * @return {@link String}
	 */
	public static String getBrowserName(HttpServletRequest request) {
		String uaStr = request.getHeader("User-Agent");
		UserAgent userAgent = UserAgent.parseUserAgentString(uaStr);
		return userAgent.getBrowser().getName();
	}

	/**
	 * 获取浏览器版本
	 *
	 * @param request 请求
	 * @return {@link String}
	 */
	public static String getBrowserVersion(HttpServletRequest request) {
		String uaStr = request.getHeader("User-Agent");
		UserAgent userAgent = UserAgent.parseUserAgentString(uaStr);
		return userAgent.getBrowserVersion().getVersion();
	}

	/**
	 * 获取操作系统名称
	 *
	 * @param request 请求
	 * @return {@link String}
	 */
	public static String getOsName(HttpServletRequest request) {
		String uaStr = request.getHeader("User-Agent");
		UserAgent userAgent = UserAgent.parseUserAgentString(uaStr);
		return userAgent.getOperatingSystem().getName();
	}

	/**
	 * 得到ip addr
	 *
	 * @param request 请求
	 * @return {@link String}
	 */
	public static String getIpAddr(HttpServletRequest request) {
		if (request == null) {
			return "unknown";
		} else {
			String ip = request.getHeader("x-forwarded-for");
			if (ip == null || ip.length() == 0 || UNKNOWN.equalsIgnoreCase(ip)) {
				ip = request.getHeader("X-Real-IP");
			}
			if (ip == null || ip.length() == 0 || UNKNOWN.equalsIgnoreCase(ip)) {
				ip = request.getHeader("http_client_ip");
			}
			if (ip == null || ip.length() == 0 || UNKNOWN.equalsIgnoreCase(ip)) {
				ip = request.getRemoteAddr();
			}
			if (ip == null || ip.length() == 0 || UNKNOWN.equalsIgnoreCase(ip)) {
				ip = request.getHeader("Proxy-Client-IP");
			}
			if (ip == null || ip.length() == 0 || UNKNOWN.equalsIgnoreCase(ip)) {
				ip = request.getHeader("WL-Proxy-Client-IP");
			}
			if (ip == null || ip.length() == 0 || UNKNOWN.equalsIgnoreCase(ip)) {
				ip = request.getHeader("HTTP_X_FORWARDED_FOR");
			}

			// 如果是多级代理,那么取第一个ip为客户ip
			if (ip != null && ip.indexOf(",") != -1) {
				ip = ip.substring(ip.lastIndexOf(",") + 1, ip.length()).trim();
			}
			return ip;
		}
	}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java中可以使用HttpServletRequest的getHeader("User-Agent")法来获取请求的User-Agent头信息,根据该信息来判断请求浏览器发送的还是黑客发送的。 然而,并不是所有黑客都会改变User-Agent头信息,黑客也可以伪装成浏览器发送请求。因此单纯根据User-Agent头信息来判断请求是否是黑客发送的并不能保证100%的准确性。 需要使用其他的技术来确保请求的安全性,如验证码、限制IP等。 ### 回答2: 要判断请求是由浏览器发送还是黑客发送,可以使用一些技术和法进行识别和验证。 首先,可以通过检查请求中的HTTP头部信息来判断。浏览器发送的请求通常会包含一些特定的HTTP头部,例如User-Agent,Referer,Accept等。这些头部信息可以帮助我们判断请求的来源。而黑客发送的请求可能不会包含或者伪造这些头部信息,或者可能包含一些异常值。 其次,可以通过IP地址来判断请求的来源。通过比对请求的IP地址和已知的可信IP地址列表,我们可以判断是否是浏览器发送的请求。黑客通常会通过代理或者伪装IP地址来隐藏自己的真实身份。 另外,可以通过验证请求中的其他信息,例如Cookie、Session等来判断请求的合法性。浏览器发送的请求通常会包含Cookie或者Session信息,而黑客发送的请求可能没有这些验证信息。 此外,还可以采用一些安全防护机制来检测和防止黑客攻击,例如使用验证码验证、限制请求频率、过滤恶意的请求参数等。 综上所述,判断请求是由浏览器发送还是黑客发送是一项复杂的任务,需要结合多种技术和法进行综合分析。虽然无法百分之百地确定请求的来源,但通过以上的一些策略和措施,可以增强对请求的验证和判断,提高系统的安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值