问题来源
下载现场部署的代码的源代码,虽然只有 .class
文件,但是也能够通过反编译获得一些信息,果不其然,其中第一次查询的固定的某个 id 与现在项目中对应的 id 值不一致,然后在部署现场执行 sql 语句发现没有数据,定位到原因在此。
解决办法
现在我这里的源代码已经被改得面目全非,要改回去是不可能的了。由于是在项目中写的一个固定数字,那么通过分析现场获取过来的项目的 .class
文件,就能够定位到,然后通过二进制查看器,对其进行二进制级别的修改,就能够达到修复这个 BUG 的目的。
解决过程:
1、获取 AServiceImp.class
文件,通过反编译查看器得到需要修改的代码如下:
public PageDataModel queryCount(String startTime, String endTime) {
List resultList = new ArrayList();
List aList = this.ADao.queryA(1, 356);
....
Double timeTotal = Double