Cómo firmar pdf en Java usando pdfbox

Estoy intentando firmar pdf usando las bibliotecas de pdfbox. Me he quedado atrapado ahora y realmente necesito una ayuda.

Este es mi código:

private static void signPdf(PDDocument document) throws Exception 
{
    PDSignature sig = new PDSignature();
    sig.setFilter(COSName.ADOBE_PPKLITE);
    sig.setSubFilter(COSName.ADBE_PKCS7_DETACHED);
    sig.setByteRange(new int[] {'a','a','a','a'});
    sig.setContents(new byte[]{(byte) 23, (byte) 23, (byte) 23, (byte) 23});

    SignatureOptions options = new SignatureOptions();

    document.addSignature(sig, new SignatureInterface() {
        public byte[] sign(InputStream content)
                throws SignatureException, IOException       {        
             //this should be made MD5 checksum?           
            return new byte[]{(byte) 'a', (byte) 'a', (byte) 'a', (byte) 'a'};
        }
    }, options);
}

Luego estoy guardando mi pdf, pero: 1) Me he dado cuenta de que el método de señalización nunca se llama 2) ¿Dónde debo adjuntar el certificado? en metodo de signo?

pdf:

/Type /Sig
/Filter /Adobe.PPKLite
/SubFilter /adbe.pkcs7.sha1
/Contents <0000000000. a lot of zeros..000>
/ByteRange [0 1000000000 1000000000 1000000000]

Creo que me olvido de algo, pero la documentación no dice nada sobre cómo firmar un archivo.

Tahnks por adelantado JC.

@Ed

Así es como guardo mi pdf:

public static void saveFile(COSDocument doc, String out)
        throws IOException, COSVisitorException {  
    java.io.OutputStream os = null;  
    COSWriter writer = null;  
    try {
        os = new java.io.FileOutputStream(out);
        writer = new COSWriter(os);
        writer.write(doc);
    } finally {
        if (os != null) {
            os.close();
        }
        if (writer != null) {
            writer.close();
        }
    }
}

Respuestas a la pregunta(1)

Su respuesta a la pregunta