1,编码
之前做支付验证的时候,sdk的平台token串有的就是会有空格,折腾了很久,前后端对调好多次都没发现这个问题.结果有的平台验证通过,有的通不过.
仔细调试后发现不通过的url中参数串都是带有'+'字符的,然后request.getparameter("xxx"), 字符串中'+'都被转成' '于是md5校验不通过.request.getparameter("xxx")
最后使用req.getQueryString() +自己写了个简单的获取策略获取参数.
2,IDE带来的bug
app工程使用struts2框架,旧的action class文件混进action java文件中,在工程上没显示,发布时又被传到了tomcat中,引发classNotFoundException,启发不能盲目信任IDE.
3,Maven web deploy to tomcat 发现工程没有发布上去.可能是Maven build修改了deployment assembly,Maven Dependencies is removed.
-->Project的属性Deployment Assembly-->add--->java build path entries -->select maven dependencies. or edit project .classpath.
4,Linux大小写敏感.项目使用freemaker框架,在windows下跑得好好,部署后,发现有的url总是循环请求,以至于stackoverflow.
仔细对比linux下与window下的log,发现报错的请求init dispatchResolver 没有使用我们定义的freemaker的而是spring mvc default的.后来一想是不是路径找不到,然后想到linux大小写敏感.
出现问题的ftl资源文件夹是"PlatMaterial",
代码注解是
@Controller
@RequestMapping(value = "platMaterial")
启发:莫名的bug常常与基本环境有关.
5,不经意的溢出,计算玩家登录的间隔得到的奖励,接口args 是 int 型,使用了连个时间的的date.getTime()相减后转int,发现有的玩家登录间隔奖励对不上.
结果一查,发现是int越界,修改为int sep = time>Integer.maxValue()?Integer.maxValue():Integer.valueOf(time)//time long type;
启发:不经意的类型转化很可能发生越界.