goas 2017-03-03 06:31 采纳率: 60%
浏览 1659
已结题

Servlet request.getLocalName返回为空是什么问题?

Spring webSocket 中自带有这样一行代码:

  public InetSocketAddress getLocalAddress() {
        return new InetSocketAddress(this.servletRequest.getLocalName(), this.servletRequest.getLocalPort());
    }

报的异常是这样的:

 Caused by: java.lang.IllegalArgumentException: hostname can't be null
    at java.net.InetSocketAddress.checkHost(InetSocketAddress.java:149)
    at java.net.InetSocketAddress.<init>(InetSocketAddress.java:216)
    at org.springframework.http.server.ServletServerHttpRequest.getLocalAddress(ServletServerHttpRequest.java:162)
    at org.springframework.web.socket.server.standard.AbstractStandardUpgradeStrategy.upgrade(AbstractStandardUpgradeStrategy.java:108)
    at org.springframework.web.socket.server.support.AbstractHandshakeHandler.doHandshake(AbstractHandshakeHandler.java:279)
    at org.springframework.web.socket.server.support.WebSocketHttpRe

questHandler.handleRequest(WebSocketHttpRequestHandler.java:166)
也就是说 request.getLocalName返回为空了,由于是spring中的代码,改不了,
所以只能从环境配置修复了.
我的代码在自己的开发机和测试机上没有问题

1,试过添加hosts 无效
2,试过添加hostname环境变量无效
3,还有tomcat能正常访问,正常部署,只在访问其中一个接口时出这个异常
4,换一个tomcat也不行
经过测试和在线调试,以下代码确实返回空的
request.getRemoteHost();也是空的
request.getRemoteAddr();也是空的

     public void getMessage(@PathVariable("serverName") String serverName, HttpServletResponse response, HttpServletRequest request){
        ga.push();
        coreService.doMock(request,response,serverName);
        if(request.getLocalName()==null){
            System.err.println("DEBUG:request.getLocalName() is null");
        }
    }

求大神

  • 写回答

3条回答 默认 最新

  • _1_1_7_ 2017-03-03 07:17
    关注

    tomcat换个版本,有可能是bug

    评论

报告相同问题?

悬赏问题

  • ¥15 矩阵加法的规则是两个矩阵中对应位置的数的绝对值进行加和
  • ¥15 活动选择题。最多可以参加几个项目?
  • ¥15 飞机曲面部件如机翼,壁板等具体的孔位模型
  • ¥15 vs2019中数据导出问题
  • ¥20 云服务Linux系统TCP-MSS值修改?
  • ¥20 关于#单片机#的问题:项目:使用模拟iic与ov2640通讯环境:F407问题:读取的ID号总是0xff,自己调了调发现在读从机数据时,SDA线上并未有信号变化(语言-c语言)
  • ¥20 怎么在stm32门禁成品上增加查询记录功能
  • ¥15 Source insight编写代码后使用CCS5.2版本import之后,代码跳到注释行里面
  • ¥50 NT4.0系统 STOP:0X0000007B
  • ¥15 想问一下stata17中这段代码哪里有问题呀