Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]


Groups > comp.lang.java.programmer > #18130

How to digitally sign the message using digital certificate and BaseEnc

Path csiph.com!v102.xanadu-bbs.net!xanadu-bbs.net!news.glorb.com!news-out.readnews.com!transit3.readnews.com!news-out.news.tds.net!newsreading01.news.tds.net!53ab2750!not-for-mail
From "suresh123kiran" <suresh123kiran@1:261/38.remove-8mo-this>
Subject How to digitally sign the message using digital certificate and BaseEnc
Message-ID <5031396D.57066.calajapr@time.synchro.net> (permalink)
X-Comment-To All
Newsgroups comp.lang.java.programmer
X-FTN-AREA COMP.LANG.JAVA.PROGRAMMER
X-FTN-MSGID 1:261/38 6f380c32
Content-Type text/plain; charset=IBM437
Content-Transfer-Encoding 8bit
X-Gateway time.synchro.net [Synchronet 3.16a-Win32 NewsLink 1.98]
Lines 122
Date Sun, 19 Aug 2012 19:14:18 GMT
NNTP-Posting-Host 69.21.70.65
X-Complaints-To news@tds.net
X-Trace newsreading01.news.tds.net 1345403658 69.21.70.65 (Sun, 19 Aug 2012 14:14:18 CDT)
NNTP-Posting-Date Sun, 19 Aug 2012 14:14:18 CDT
Organization tds.net
Xref csiph.com comp.lang.java.programmer:18130

Show key headers only | View raw


From: "suresh123kiran" <suresh123kiran@1:261/38.remove-v8v-this>

From: "suresh123kiran" <suresh123kiran@1:261/38.remove-7rm-this>

From: "suresh123kiran" <suresh123kiran@1:261/38.remove-rj6-this>

From: "suresh123kiran" <suresh123kiran@1:261/38.remove-wnx-this>

From: suresh123kiran <ursyamunaprabu@gmail.com>

Hi All ... I am working on webservices.... I need to digitally sign a message 
in which AcknowledgementNo using digital Certificate with  X.509 certificate 
private key. I tried this code but it showing invalid signature Encoding. Can 
anyone pls us to digitally sign.
Here is the below Java code to sign the AcknowledgementNo,Pls help me. Thanks 
in advance.


public class DigiAckNo {
        static class PrivateKeyAndCertChain {
                public PrivateKey mPrivateKey;
        }

        private static KeyStore loadKeyStoreFromPFXFile(String aFileName,
                        String aKeyStorePasswd) throws
GeneralSecurityException,
                        IOException {
                String PKCS12_KEYSTORE_TYPE = "PKCS12";
                KeyStore keyStore = KeyStore.getInstance(PKCS12_KEYSTORE_TYPE);
                FileInputStream keyStoreStream = new
FileInputStream(aFileName);
                char[] password = aKeyStorePasswd.toCharArray();
                keyStore.load(keyStoreStream, password);
                return keyStore;
        }


private static PrivateKeyAndCertChain getPrivateKeyAndCertChain(
                        KeyStore aKeyStore, String aKeyPassword)
                        throws GeneralSecurityException {
                char[] password = aKeyPassword.toCharArray();
                Enumeration<String> aliasesEnum = aKeyStore.aliases();
                if (aliasesEnum.hasMoreElements()) {
                        String alias = (String) aliasesEnum.nextElement();
                        Certificate[] certificationChain = aKeyStore
                                        .getCertificateChain(alias);
                        Certificate certificate509 =
aKeyStore.getCertificate(alias);

                        PrivateKey privateKey = (PrivateKey)
aKeyStore.getKey(alias,
                                        password);
                        PrivateKeyAndCertChain result = new
PrivateKeyAndCertChain();
                        result.mPrivateKey = privateKey;
                        return result;
                } else {
                        throw new KeyStoreException("The keystore is empty!");
                }
        }

private static byte[] signAckno(PrivateKey aPrivateKey)
                        throws GeneralSecurityException, IOException {
                String DIGITAL_SIGNATURE_ALGORITHM_NAME = "SHA1withRSA";
                Signature signatureAlgorithm = Signature
                                .getInstance(DIGITAL_SIGNATURE_ALGORITHM_NAME);
                String strAckNo = "41516019";

                byte[] ba = strAckNo.getBytes();

                signatureAlgorithm.initSign(aPrivateKey);
                signatureAlgorithm.update(ba);
                byte[] digitalSignature = signatureAlgorithm.sign();
                // Display plain text and signature
        return digitalSignature;
        }

public static String encodeBase64(byte[] rawData2) {
                return Base64.encode(rawData2);
        }

public static void main(String args[]) throws GeneralSecurityException,
                        IOException, CertificateException {
                String File = "d:\\projects\\GANGADHARAN.pfx";
                String pwd = "1235";
                KeyStore keyStore = loadKeyStoreFromPFXFile(File, pwd);
                PrivateKeyAndCertChain PrivateKeyAndCertChain =
getPrivateKeyAndCertChain(
                                keyStore, pwd);
                PrivateKey aPrivateKey = PrivateKeyAndCertChain.mPrivateKey;
                byte[] bytestr = signDocument(aPrivateKey);
                String strDocumentBase64 = encodeBase64(bytestr);
                System.out.println("strDocumentBase64" + strDocumentBase64);

        }

}

-+- BBBS/Li6 v4.10 Dada-1
 + Origin: Prism bbs (1:261/38)
-+- Synchronet 3.16a-Win32 NewsLink 1.98
Time Warp of the Future BBS - telnet://time.synchro.net:24

-+- BBBS/Li6 v4.10 Dada-1
 + Origin: Prism bbs (1:261/38)
-+- Synchronet 3.16a-Win32 NewsLink 1.98
Time Warp of the Future BBS - telnet://time.synchro.net:24

-+- BBBS/Li6 v4.10 Dada-1
 + Origin: Prism bbs (1:261/38)
-+- Synchronet 3.16a-Win32 NewsLink 1.98
Time Warp of the Future BBS - telnet://time.synchro.net:24

-+- BBBS/Li6 v4.10 Dada-1
 + Origin: Prism bbs (1:261/38)
-+- Synchronet 3.16a-Win32 NewsLink 1.98
Time Warp of the Future BBS - telnet://time.synchro.net:24

--- BBBS/Li6 v4.10 Dada-1
 * Origin: Prism bbs (1:261/38)
--- Synchronet 3.16a-Win32 NewsLink 1.98
Time Warp of the Future BBS - telnet://time.synchro.net:24

Back to comp.lang.java.programmer | Previous | NextNext in thread | Find similar | Unroll thread


Thread

How to digitally sign the message using digital certificate and BaseEnc "suresh123kiran" <suresh123kiran@1:261/38.remove-8mo-this> - 2012-08-19 19:14 +0000
  Re: How to digitally sign the message using digital certificate and "Daniele Futtorovic" <daniele.futtorovic@1:261/38.remove-fzq-this> - 2012-08-20 18:58 +0000
  RE: How to digitally sign the message using digital certificate and Bas "suresh123kiran" <suresh123kiran@1:261/38.remove-fzq-this> - 2012-08-20 18:58 +0000

csiph-web