一些场景中,我们要对websocket客户端的ip进行校验,如果是黑名单,或者不被允许的则不应该让他访问业务系统。
笔者本地使用了两个Websocket技术原型,一个基于Netty封装的Websocket框架:
另外一个是基于JSR-356 Java Api for websocket实现的框架,实现的客户端很多,比如tomcat,spring也有对应的支持。
表达式获得方法
因为使用Ognl解析对象时,会把对象数据放入一棵树,在任意调试窗口监控可以查看到类及属性的层次关系。
比如查询Ip地址,我们这里选择的树路径是
#root->channel->remoteAddress
他返回的对象时InetSocketAddress的实例,得到这个对象后,你可以调用
.getAddress().getHostAddress()
方法获得最终的ip真实地址,当然你也可以使用其他表达式来获得
#root.channel.remoteAddress.holder.addr.holder.hostName
#root.channel.remoteAddress.holder.addr.hostName
这些表达式需要你自己去评估计算。
netty-websocket-spring-boot-starter
封装代码如下: