X-Git-Url: https://code.wpia.club/?a=blobdiff_plain;ds=sidebyside;f=src%2Forg%2Fcacert%2Fgigi%2Fcrypto%2FSMIME.java;h=de39f5a190793e267e16828f027d9cbcba86e220;hb=2b238f215190e6d24fa928a657fa0fb30059abb7;hp=9b6573409892a42a38d23fc46e7cfda727cf3191;hpb=fb38a9c8b9d86289213a36bd3d2afddc58ec7d3f;p=gigi.git diff --git a/src/org/cacert/gigi/crypto/SMIME.java b/src/org/cacert/gigi/crypto/SMIME.java index 9b657340..de39f5a1 100644 --- a/src/org/cacert/gigi/crypto/SMIME.java +++ b/src/org/cacert/gigi/crypto/SMIME.java @@ -8,9 +8,10 @@ import java.security.GeneralSecurityException; import java.security.PrivateKey; import java.security.Signature; import java.security.cert.X509Certificate; -import java.util.Base64; import java.util.Random; +import org.cacert.gigi.util.PEM; + import sun.security.pkcs.ContentInfo; import sun.security.pkcs.PKCS7; import sun.security.pkcs.SignerInfo; @@ -44,6 +45,7 @@ public class SMIME { } public static void smime(String contents, PrivateKey pKey, X509Certificate c, PrintWriter to) throws IOException, GeneralSecurityException { + contents = normalizeNewlinesToCRLF(contents); Signature signature = Signature.getInstance("SHA1WithRSA"); signature.initSign(pKey); @@ -61,38 +63,42 @@ public class SMIME { // Create PKCS7 Signed data PKCS7 p7 = new PKCS7(new AlgorithmId[] { - new AlgorithmId(AlgorithmId.SHA_oid) + new AlgorithmId(AlgorithmId.SHA_oid) }, cInfo, new java.security.cert.X509Certificate[] { - c + c }, new SignerInfo[] { - sInfo + sInfo }); ByteArrayOutputStream bOut = new DerOutputStream(); p7.encodeSignedData(bOut); - mimeEncode(contents, Base64.getEncoder().encodeToString(bOut.toByteArray()).replaceAll("(.{64})(?=.)", "$1\n"), to); + mimeEncode(contents, PEM.formatBase64(bOut.toByteArray()), to); + } + + private static String normalizeNewlinesToCRLF(String contents) { + return contents.replace("\r\n", "\r").replace("\r", "\n").replace("\n", "\r\n"); } private static Random r = new Random(); private static void mimeEncode(String contents, String signature, PrintWriter to) { String boundary = generateBoundary(contents, null); - to.println("MIME-Version: 1.0"); - to.println("Content-Type: multipart/signed; protocol=\"application/x-pkcs7-signature\"; micalg=\"sha1\"; boundary=\"" + boundary + "\""); - to.println(""); - to.println("This is an S/MIME signed message"); - to.println(""); - to.println("--" + boundary); - to.println(contents); - to.println("--" + boundary); - to.println("Content-Type: application/x-pkcs7-signature; name=\"smime.p7s\""); - to.println("Content-Transfer-Encoding: base64"); - to.println("Content-Disposition: attachment; filename=\"smime.p7s\""); - to.println(""); - to.println(signature); - to.println(); - to.println("--" + boundary + "--"); + to.print("MIME-Version: 1.0\r\n"); + to.print("Content-Type: multipart/signed; protocol=\"application/x-pkcs7-signature\"; micalg=\"sha1\"; boundary=\"" + boundary + "\"\r\n"); + to.print("\r\n"); + to.print("This is an S/MIME signed message\r\n"); + to.print("\r\n"); + to.print("--" + boundary + "\r\n"); + to.print(contents + "\r\n"); + to.print("--" + boundary + "\r\n"); + to.print("Content-Type: application/x-pkcs7-signature; name=\"smime.p7s\"\r\n"); + to.print("Content-Transfer-Encoding: base64\r\n"); + to.print("Content-Disposition: attachment; filename=\"smime.p7s\"\r\n"); + to.print("\r\n"); + to.print(signature + "\r\n"); + to.print("\r\n"); + to.print("--" + boundary + "--\r\n"); } private static String generateBoundary(String contents, String contents2) {