2

我们在 AIX 的 Websphere Application Server 上使用 Spring/Hibernate。在我的 Windows 机器上,该问题不会发生——仅在运行 AIX 时才会发生。当用户使用帐号登录时,如果他们在登录 ID 前加上“0”前缀,则应用程序会拒绝登录。在 DB2 表中,该列是数字类型,将 '090....' 转换为 '90...' 应该没有问题

还有其他人遇到过这样的问题吗?两台机器都有 Java v1.5。

更具体地说,流程是 FormView -> LoginValidator -> LoginController

在 LoginValidator 中,login 的值为 null 并带有前缀 0。没有 0,该值就是它应该是的值(但同样,这仅在 AIX 环境中——在 2 个 Windows 环境中它很好)。这是对象等于 null 的代码片段。

public class LoginValidator implements Validator  {

    public boolean supports(Class clazz) {
    return Login.class.equals(clazz);
    }

    @SuppressWarnings("all")
    public void validate(Object obj, Errors errors) {
        System.out.println("Inside LoginValidator");
        Login login = (Login) obj;
        //null value
        System.out.println("Before conversion in Validator, store id = " 
              + login.getStoreId()); 
    }
}

我还编写了这个简短的 Java 程序,用于从字符串构造一个 Long,并使用与 WebSphere 一起打包的 java 二进制文件

public class String2Long {
    public static void main(String[] args){
        String a = "09012179";
        String b = "9012179";

        Long _a = new Long(a);
        Long _b = new Long(b);

        System.out.println(a + " => " + _a); //09012179 => 9012179
        System.out.println(b + " => " + _b); //9012179 => 9012179
        System.out.println("_a.equals(_b) " + _a.equals(_b)); //_a.equals(_b) true
    }
}

解决方案

4

4 回答 4

3

好吧,那里发生了很多事情。您确实需要尝试隔离问题 - 找出发送到数据库的内容,Java 看到的内容等。

尝试将其固定在一个简短但完整的程序中,该程序显示问题 - 然后您将处于一个更强大的位置来提交错误或修复您的代码。

于 2008-11-14T20:26:49.300 回答
3

解决方案

一位同事对 Spring 更新做了一些研究,显然这个错误在 v. 2.5.3 中是正确的:

CustomNumberEditor 将带有前导零的数字视为十进制(删除了不需要的八进制支持,同时保留了十六进制)

我们使用的是 Spring 2.0.5。我们只是用 Spring 2.5.4 替换了 jars,它就可以正常工作了!

感谢大家的帮助/帮助。我们将来会使用单元测试,但这只是一个 Spring 错误。

于 2008-11-15T16:09:47.790 回答
2

沿着字符串的路径跟踪程序一直到数据库,并对该路径上的每个方法进行单元测试。并且不要只在这里采取最短的路线,使用不同的输入和预期输出进行多个单元测试,以真正了解可能出了什么问题。假设您没有发现任何错误,请在另一台计算机上运行相同的单元测试,您应该能够查明错误。从我的脑海中,我认为这可能与区分大小写有关,但实际上无法确定。

下一次,使用 TDD。

于 2008-11-14T20:33:52.377 回答
0

我对 Java 不太了解,但由于前导“0”,字符串可能会被解释为八进制字符串。

您可以使用 Long.parseLong(a, 10) 来解决这个问题。

于 2008-11-14T22:03:57.890 回答