需要帮助创建有效的随机数

时间:2015-09-04 14:43:17

标签: java web-services soap digest wsse

我正在尝试使用使用密码摘要模式的Web服务,我在Java应用程序中使用这些函数来生成随机的随机数,创建日期和密码摘要。我无法通过身份验证失败错误,并且文档对于他们是否需要SHA-1或MD5并不过分清楚,因为它在传递中提到了两者。我尝试过MD5而不是SHA-1,我得到了相同的结果。我设法通过SoapUI上的测试获得工作请求,但我不知道该应用程序是如何生成摘要/ nonce的。任何帮助表示赞赏。

这是我用来生成nonce和密码摘要的代码:

    private static SOAPMessage createSOAPRequest() throws Exception 
    {
        String password = "FakePassword";

        String nonce = generateNonce(); 
        System.out.println("Nonce = " + nonce);

        DateFormat dateFormatter = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSS'Z'");
        dateFormatter.setTimeZone(TimeZone.getTimeZone("UTC"));
        Date today = Calendar.getInstance().getTime();
        String created = dateFormatter.format(today);
        System.out.println("Created = " + created);

        String passwordDigest = buildPasswordDigest(nonce, created, password);
        System.out.println("Password Digest = " + passwordDigest);
    }

    private static String buildPasswordDigest(String nonce, String created, String password) throws NoSuchAlgorithmException, UnsupportedEncodingException
    {
        MessageDigest sha1;
        String passwordDigest = null;

        try
        {
            sha1 = MessageDigest.getInstance("SHA-1");
            sha1.update(Base64.decodeBase64(nonce));
            sha1.update(created.getBytes("UTF-8"));
            passwordDigest = new String(Base64.encodeBase64(sha1.digest(password.getBytes("UTF-8"))));
            sha1.reset();
        }
        catch (NoSuchAlgorithmException e) 
        {
            e.printStackTrace();
        }

        return passwordDigest;
    }

    private static String generateNonce() throws NoSuchAlgorithmException, NoSuchProviderException, UnsupportedEncodingException
    {
        String dateTimeString = Long.toString(new Date().getTime());
        byte[] nonceByte = dateTimeString.getBytes();
        return Base64.encodeBase64String(nonceByte);
    }

1 个答案:

答案 0 :(得分:2)

解决方案是用sha1.update(nonce.getBytes("UTF-8"));

替换行sha1.update(Base64.decodeBase64(nonce));