java的xml加errorpage_web.xml中 error-page的正确用法

最近在review别的team的代码,发现error-page没有被用的很好。

他们的web.xml中关于error-page的定义如下:

404

/WEB-INF/jsp/errors/error.jsp

500

/WEB-INF/jsp/errors/error.jsp

414

/WEB-INF/jsp/errors/error.jsp

505

/WEB-INF/jsp/errors/error.jsp

400

/WEB-INF/jsp/errors/error.jsp

看样子貌似几乎所有常见的服务器端的异常都被覆盖到了,出现这些异常的话页面会到error.jsp中。

但是这样就够了吗, 显然是不够的,仔细阅读他们代码,会发现他们有很多异常都有可能被抛出来而没有得到非常妥当的处理。

比如说他们的CheckoutAddress类的fromHomeAddress()方法如下:public static CheckOutAddress fromHomeAddress(HomeAddr homeAddr) {

CheckOutAddress address = new CheckOutAddress();

address.setAddressId(String.valueOf(homeAddr.getId()));

address.setCountryId(String.valueOf(homeAddr.getCountry().getId()));

address.setCountryName(homeAddr.getCountry().getRegionName());

address.setDetailAddress(homeAddr.getDetailAddress());

address.setFirstName(homeAddr.getFirstName());

address.setLastName(homeAddr.getLastName());

address.setIsDefaultAddress(String.valueOf(homeAddr.getIsDefault()));

address.setMobilePhone(homeAddr.getMobilePhone());

address.setCountryPhoneCode(homeAddr.getCountryPhoneCode());

address.setZipCode(homeAddr.getZipCode());

return address;

}

显然这个方法是没有正确处理异常的,因为传入的homeAddr入参可能为空,如果这样的话,那么所有点操作符都会抛NullPointerException,而这里显然没有对入参进行控制,而且代码中也没有对异常进行处理,我查看了下,所有调用这个方法的方法也都没有对异常进行处理。所以如果假设真正应用上线后遇到了一个homeAddr为空的地方,那么这段代码就会抛异常而不会继续走下去,没有好好处理的结果可能是灾难性的,前端用户会面对一大段异常文本而不知所措。

当然了,这段代码最好的方案还是对入参进行严格控制,并且在代码中吧异常直接处理掉,所谓“能自己处理就不要丢给上级” ,当然了,我们为了以防万一,还是必须在web.xml中定义一个 error-page选项,来把好最后一关,也就是就算真正出这个异常了,也会到出错页面,而不是一个无法控制的页面。

所以我们需要在web.xml中增加一个error-page 元素,如下:

java.lang.NullPointerException

/WEB-INF/jsp/errors/error.jsp

这样应用就更加robust了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值