实战 - 从request请求头中获取远程客户端真实的IP

如果使用了反向代理软件,经过代理以后,由于在客户端和服务之间增加了中间层,因此服务器无法直接拿到客户端的IP,服务器端应用也无法直接通过转发请求的地址返回给客户端。但是在转发请求的HTTP头信息中,增加了X-FORWARDED-FOR信息用以跟踪原有的客户端IP地址和原来客户端请求的服务器地址。

@Slf4j
public class ClientUtils {
 
    private static final String UNKNOWN = "unknown";
    private static final String LOCALHOST = "127.0.0.1";
    private static final Pattern IP_PATTERN = Pattern.compile("((2(5[0-5]|[0-4]\\d))|[0-1]?\\d{1,2})(\\.((2(5[0-5]|[0-4]\\d))|[0-1]?\\d{1,2})){3}");
 
    /**
     *
     * 获取远程客户端ip
     */
    public static String getClientIp(HttpServletRequest request) {
 
        String ipAddress;
        try {
            ipAddress = request.getHeader("y-forwarded-for");
            if (ipAddress == null 
                || ipAddress.length() == 0 
                || UNKNOWN.equalsIgnoreCase(ipAddress) 
                || !IP_PATTERN.matcher(ipAddress).matches()) {
                ipAddress = request.getRemoteAddr();
                if (LOCALHOST.equals(ipAddress)) {
                    InetAddress inet = InetAddress.getLocalHost();
                    ipAddress = inet.getHostAddress();
                }
            }
        } catch (UnknownHostException e) {
            ipAddress = "";
        }
        return ipAddress;
    }
    
    /**
     * 获取用户名
     *
     */
    public static String getClientAccount(HttpServletRequest request) {
        Principal userPrincipal = request.getUserPrincipal();
        if (Objects.nonNull(userPrincipal)) {
            OAuth2Authentication oAuth2Authentication = (OAuth2Authentication) userPrincipal;
            JSONObject jsonObject = JSONUtil.parseObj(oAuth2Authentication.getUserAuthentication().getPrincipal());
            JSONObject userObject = (JSONObject) jsonObject.get(ClientConstans.USER_INFO_KEY);
            String username = String.valueOf(userObject.get(ClientConstans.USER_NAME_KEY));
            return username;
        }
        return null;
    }
 
    /**
     * 获取用户ID
     */
    public static String getClientUserId(HttpServletRequest request) {
        Principal userPrincipal = request.getUserPrincipal();
        if (Objects.nonNull(userPrincipal)) {
            return userPrincipal.getName();
        }
        return null;
    }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我一直在流浪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值