java代码实现由request请求消息获取远处发送请求的用户主机的内网IP地址和外网IP地址
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java代码实现由request请求消息获取远处发送请求的用户主机的内网IP地址和外网IP地址相关的知识,希望对你有一定的参考价值。
参考技术A 外网:public static String getWebIp()
try
String strUrl = "http://www.ip138.com/ip2city.asp";
URL url = new URL(strUrl);
BufferedReader br = new BufferedReader(new InputStreamReader(url
.openStream()));
String s = "";
StringBuffer sb = new StringBuffer("");
String webContent = "";
while ((s = br.readLine()) != null)
sb.append(s + "\r\n");
br.close();
webContent = sb.toString();
int start = webContent.indexOf("[") + 1;
int end = webContent.indexOf("]");
webContent = webContent.substring(start, end);
return webContent;
catch (Exception e)
e.printStackTrace();
return "error open url:" + null;
内网:request.getRemoteAddr()追问
我的神 你拷贝的代码我早研究过了 不过也谢谢你啊
追答这个是能实现的 大哥
参考技术B 获取客户端的IP地址的方法是:request.getRemoteAddr()内网好像获取不到吧。追问
首先谢谢您的回答。 这个不太清楚,有一点可以肯定的是不好获取,我都在网上溜了很长时间了。。。。
本回答被提问者采纳 参考技术C request.getRemoteAddr();追问这样子不行的
Redis实现简单消息队列
参考技术A 打开浏览器,输入地址,按下回车,打开了页面。于是一个 HTTP 请求( request )就由客户端发送到服务器,服务器处理请求,返回响应( response )内容。我们每天都在浏览网页,发送大大小小的请求给服务器。有时候,服务器接到了请求,会发现他也需要给另外的服务器发送请求,或者服务器也需要做另外一些事情,于是最初们发送的请求就被阻塞了,也就是要等待服务器完成其他的事情。
更多的时候,服务器做的额外事情,并不需要客户端等待,这时候就可以把这些额外的事情异步去做。从事异步任务的工具有很多。主要原理还是处理通知消息,针对通知消息通常采取是队列结构。生产和消费消息进行通信和业务实现。
上述异步任务的实现,可以抽象为生产者消费模型。如同一个餐馆,厨师在做饭,吃货在吃饭。如果厨师做了很多,暂时卖不完,厨师就会休息;如果客户很多,厨师马不停蹄的忙碌,客户则需要慢慢等待。实现生产者和消费者的方式用很多,下面使用 Python 标准库 Queue 写个小例子:
大概输出如下:
Python内置了一个好用的队列结构。我们也可以是用redis实现类似的操作。并做一个简单的异步任务。
Redis提供了两种方式来作消息队列。一个是使用 生产者消费模式 模式,另外一个方法就是 发布订阅者模式 。前者会让一个或者多个客户端监听消息队列,一旦消息到达,消费者马上消费,谁先抢到算谁的,如果队列里没有消息,则消费者继续监听。后者也是一个或多个客户端订阅消息频道,只要发布者发布消息,所有订阅者都能收到消息,订阅者都是平等的。
主要使用了redis提供的blpop获取队列数据,如果队列没有数据则阻塞等待,也就是监听。
使用redis的pubsub功能,订阅者订阅频道,发布者发布消息到频道了,频道就是一个消息队列。
我们分别实现了两种异步任务的后端服务,直接启动他们,就能监听redis队列或频道的消息了。简单的测试如下:
启动脚本,使用
可以分别在监听的脚本输入中看到异步消息。在异步的任务中,可以执行一些耗时间的操作,当然目前这些做法并不知道异步的执行结果,如果需要知道异步的执行结果,可以考虑设计协程任务或者使用一些工具如 RQ 或者 celery 等。
以上是关于java代码实现由request请求消息获取远处发送请求的用户主机的内网IP地址和外网IP地址的主要内容,如果未能解决你的问题,请参考以下文章