3

BouncyCastle を使用してhttp://timestamping.edelweb.fr/service/tspに接続し、タイムスタンプ (RFC 3161) を要求しようとしています。サーバーから TimestampResponse が返されますが、実際の日付がないようです。

これはコードです:

public static void main(String[] args) {
    String ocspUrl = "http://timestamping.edelweb.fr/service/tsp";
    byte[] digest = "hello".getBytes();
    OutputStream out = null;

    try {
        TimeStampRequestGenerator reqgen = new TimeStampRequestGenerator();
        TimeStampRequest req = reqgen.generate(TSPAlgorithms.SHA1, digest);
        byte request[] = req.getEncoded();

        URL url = new URL(ocspUrl);
        HttpURLConnection con = (HttpURLConnection) url.openConnection();

        con.setDoOutput(true);
        con.setDoInput(true);
        con.setRequestMethod("POST");
        con.setRequestProperty("Content-type", "application/timestamp-query");

        con.setRequestProperty("Content-length", String.valueOf(request.length));
        out = con.getOutputStream();
        out.write(request);
        out.flush();

        if (con.getResponseCode() != HttpURLConnection.HTTP_OK) {
            throw new IOException("Received HTTP error: " + con.getResponseCode() + " - " + con.getResponseMessage());
        }
        InputStream in = con.getInputStream();
        TimeStampResp resp = TimeStampResp.getInstance(new ASN1InputStream(in).readObject());
        TimeStampResponse response = new TimeStampResponse(resp);
        response.validate(req);
        System.out.println(response.getTimeStampToken().getTimeStampInfo().getGenTime());
    } catch (IOException e) {
        e.printStackTrace();
    } catch (Exception e) {
        e.printStackTrace();
    }
}

質問は次のとおりです: タイムスタンプに Bouncycastle のライブラリを使用していて、たまたまさまざまなステータス コードとその意味を知っている人はいますか? または、一般的に、これが機能しないように見える理由。

日付が表示されると予想されるこの行は、NullPointer をスローするだけです。

System.out.println(response.getTimeStampToken().getTimeStampInfo().getGenTime());

無料の RFC 3161 準拠のタイムスタンプ サーバーを他に知っている人はいますか?

コードを実行するには、ここからダウンロードできる bouncycastle jar が必要です。必要なもの: プロバイダー、メール、tsp。

ありがとう

4

3 に答える 3

3

Wireshark との通信を分析すると、この例では "bad message digest" エラーが表示されます。私のために働くダイジェストコードは次のとおりです。

    MessageDigest messageDigest = MessageDigest.getInstance("SHA-1");
    messageDigest.update("messageImprint".getBytes());
    byte[] digest = messageDigest.digest();
于 2011-03-31T19:08:34.990 に答える
1

問題は、コンテンツの形式/長さが間違っていることです。

TimeStampRequest req = reqgen.generate(TSPAlgorithms.SHA1, digest);

しかし、私が送信したのは次のとおりです。

"hello".getBytes();

「hello」から適切な SHA1Digest を作成すると、問題なく動作します。

static public byte[] calculateMessageDigest()
        throws NoSuchAlgorithmException, IOException {
    SHA1Digest md = new SHA1Digest();

    byte[] dataBytes = "helloooooooooooooo".getBytes();
    int nread = dataBytes.length;
    md.update(dataBytes, 0, nread);
    byte[] result = new byte[32];
    md.doFinal(result, 0);
    return result;

また、要件である http 認証をサポートしているため、TSA としてDigistampを使用することになりました。

于 2009-05-28T14:28:47.070 に答える
0

タイムスタンプのかなり良いリソースであるこのサイトを見つけました。サーバーのリストもあり、少なくともいくつかはまだ稼働しているようです.

于 2009-05-27T14:42:05.403 に答える