本文整理匯總了Java中eu.europa.esig.dss.InMemoryDocument類的典型用法代碼示例。如果您正苦於以下問題:Java InMemoryDocument類的具體用法?Java InMemoryDocument怎麽用?Java InMemoryDocument使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
InMemoryDocument類屬於eu.europa.esig.dss包,在下文中一共展示了InMemoryDocument類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: downloadSignedFile
import eu.europa.esig.dss.InMemoryDocument; //導入依賴的package包/類
@RequestMapping(value = "/download", method = RequestMethod.GET)
public String downloadSignedFile(@ModelAttribute("signedDocument") InMemoryDocument signedDocument, HttpServletResponse response) {
try {
MimeType mimeType = signedDocument.getMimeType();
if (mimeType != null) {
response.setContentType(mimeType.getMimeTypeString());
}
response.setHeader("Content-Transfer-Encoding", "binary");
response.setHeader("Content-Disposition", "attachment; filename=\"" + signedDocument.getName() + "\"");
Utils.copy(new ByteArrayInputStream(signedDocument.getBytes()), response.getOutputStream());
} catch (Exception e) {
logger.error("An error occured while pushing file in response : " + e.getMessage(), e);
}
return null;
}
示例2: testSigningAndExtensionMultiDocuments
import eu.europa.esig.dss.InMemoryDocument; //導入依賴的package包/類
@Test
public void testSigningAndExtensionMultiDocuments() throws Exception {
CertificateService certificateService = new CertificateService();
MockPrivateKeyEntry entry = certificateService.generateCertificateChain(SignatureAlgorithm.RSA_SHA256);
RemoteSignatureParameters parameters = new RemoteSignatureParameters();
parameters.setAsicContainerType(ASiCContainerType.ASiC_E);
parameters.setSignatureLevel(SignatureLevel.XAdES_BASELINE_B);
parameters.setSigningCertificate(new RemoteCertificate(entry.getCertificate().getCertificate().getEncoded()));
parameters.setDigestAlgorithm(DigestAlgorithm.SHA256);
FileDocument fileToSign = new FileDocument(new File("src/test/resources/sample.xml"));
RemoteDocument toSignDocument = new RemoteDocument(Utils.toByteArray(fileToSign.openStream()), fileToSign.getMimeType(), fileToSign.getName(),
fileToSign.getAbsolutePath());
RemoteDocument toSignDoc2 = new RemoteDocument("Hello world!".getBytes("UTF-8"), MimeType.BINARY, "test.bin");
List<RemoteDocument> toSignDocuments = new ArrayList<RemoteDocument>();
toSignDocuments.add(toSignDocument);
toSignDocuments.add(toSignDoc2);
ToBeSigned dataToSign = restMultiDocsClient.getDataToSign(new DataToSignMultipleDocumentsDTO(toSignDocuments, parameters));
assertNotNull(dataToSign);
SignatureValue signatureValue = TestUtils.sign(SignatureAlgorithm.RSA_SHA256, entry, dataToSign);
SignMultipleDocumentDTO signDocument = new SignMultipleDocumentDTO(toSignDocuments, parameters, signatureValue);
RemoteDocument signedDocument = restMultiDocsClient.signDocument(signDocument);
assertNotNull(signedDocument);
parameters = new RemoteSignatureParameters();
parameters.setAsicContainerType(ASiCContainerType.ASiC_E);
parameters.setSignatureLevel(SignatureLevel.XAdES_BASELINE_T);
RemoteDocument extendedDocument = restMultiDocsClient.extendDocument(new ExtendDocumentDTO(signedDocument, parameters));
assertNotNull(extendedDocument);
InMemoryDocument iMD = new InMemoryDocument(extendedDocument.getBytes());
iMD.save("target/test.asice");
}
示例3: transformReference
import eu.europa.esig.dss.InMemoryDocument; //導入依賴的package包/類
/**
* Preconditions:
* - The reference data is XML
* - The last transformation is canonicalization.
*
* @param reference
* {@code DSSReference} to be transformed
* @return {@code DSSDocument} containing transformed reference's data
*/
@Override
protected DSSDocument transformReference(final DSSReference reference) {
DSSDocument dssDocument = reference.getContents();
final List<DSSTransform> transforms = reference.getTransforms();
if (Utils.isCollectionEmpty(transforms)) {
return dssDocument;
}
// In the case of ENVELOPED signature the document to sign is an XML. However one of the references can point to
// another document this test case is not taken into account!
Node nodeToTransform = null;
final String uri = reference.getUri();
// Check if the reference is related to the whole document
if (Utils.isStringNotBlank(uri) && uri.startsWith("#") && !isXPointer(uri)) {
final Document document = DomUtils.buildDOM(dssDocument);
DSSXMLUtils.recursiveIdBrowse(document.getDocumentElement());
final String uri_id = uri.substring(1);
nodeToTransform = document.getElementById(uri_id);
}
byte[] transformedReferenceBytes = applyTransformations(dssDocument, transforms, nodeToTransform);
return new InMemoryDocument(transformedReferenceBytes);
}
示例4: signDocument
import eu.europa.esig.dss.InMemoryDocument; //導入依賴的package包/類
/**
* Adds signature value to the signature and returns XML signature (InMemoryDocument)
*
* @param signatureValue
* @return
* @throws DSSException
*/
@Override
public DSSDocument signDocument(final byte[] signatureValue) throws DSSException {
if (!built) {
build();
}
final EncryptionAlgorithm encryptionAlgorithm = params.getEncryptionAlgorithm();
final byte[] signatureValueBytes = DSSSignatureUtils.convertToXmlDSig(encryptionAlgorithm, signatureValue);
final String signatureValueBase64Encoded = Utils.toBase64(signatureValueBytes);
final Text signatureValueNode = documentDom.createTextNode(signatureValueBase64Encoded);
signatureValueDom.appendChild(signatureValueNode);
byte[] documentBytes = DSSXMLUtils.serializeNode(documentDom);
final InMemoryDocument inMemoryDocument = new InMemoryDocument(documentBytes);
inMemoryDocument.setMimeType(MimeType.XML);
return inMemoryDocument;
}
示例5: init
import eu.europa.esig.dss.InMemoryDocument; //導入依賴的package包/類
@Before
public void init() throws Exception {
documentToSign = new InMemoryDocument("Hello World !".getBytes(), "test.text");
signatureParameters = new ASiCWithXAdESSignatureParameters();
signatureParameters.bLevel().setSigningDate(new Date());
signatureParameters.setSigningCertificate(getSigningCert());
signatureParameters.setCertificateChain(getCertificateChain());
signatureParameters.setSignatureLevel(SignatureLevel.XAdES_BASELINE_B);
signatureParameters.aSiC().setContainerType(ASiCContainerType.ASiC_E);
Policy policy = new Policy();
policy.setId("urn:oid:1.3.6.1.4.1.10015.1000.3.2.1");
policy.setQualifier("OIDAsURN");
policy.setDigestAlgorithm(DigestAlgorithm.SHA1);
policy.setDigestValue(Utils.fromBase64("gIHiaetEE94gbkCRygQ9WspxUdw="));
policy.setSpuri("https://www.sk.ee/repository/bdoc-spec21.pdf");
signatureParameters.bLevel().setSignaturePolicy(policy);
service = new ASiCWithXAdESService(getCompleteCertificateVerifier());
}
示例6: getOriginalDocuments
import eu.europa.esig.dss.InMemoryDocument; //導入依賴的package包/類
@Override
public List<DSSDocument> getOriginalDocuments(final String signatureId) throws DSSException {
if (Utils.isStringBlank(signatureId)) {
throw new NullPointerException("signatureId");
}
List<DSSDocument> results = new ArrayList<DSSDocument>();
for (final Object signerInformationObject : cmsSignedData.getSignerInfos().getSigners()) {
final SignerInformation signerInformation = (SignerInformation) signerInformationObject;
final CAdESSignature cadesSignature = new CAdESSignature(cmsSignedData, signerInformation, validationCertPool);
cadesSignature.setSignatureFilename(document.getName());
cadesSignature.setDetachedContents(detachedContents);
cadesSignature.setProvidedSigningCertificateToken(providedSigningCertificateToken);
if (Utils.areStringsEqual(cadesSignature.getId(), signatureId)) {
results.add(new InMemoryDocument(cadesSignature.getOriginalDocumentStream()));
}
}
return results;
}
示例7: getCurrentDocument
import eu.europa.esig.dss.InMemoryDocument; //導入依賴的package包/類
private DSSDocument getCurrentDocument(String filepath, ZipInputStream zis) throws IOException {
try (ByteArrayOutputStream baos = new ByteArrayOutputStream()) {
Utils.copy(zis, baos);
baos.flush();
return new InMemoryDocument(baos.toByteArray(), filepath);
}
}
示例8: getOriginalDocumentFromDetachedSignature
import eu.europa.esig.dss.InMemoryDocument; //導入依賴的package包/類
@Test(expected = DSSException.class)
public final void getOriginalDocumentFromDetachedSignature() throws Exception {
DSSDocument document = new InMemoryDocument(HELLO_WORLD.getBytes());
CAdESSignatureParameters signatureParameters = new CAdESSignatureParameters();
signatureParameters.bLevel().setSigningDate(new Date());
signatureParameters.setSigningCertificate(getSigningCert());
signatureParameters.setCertificateChain(getCertificateChain());
signatureParameters.setSignaturePackaging(SignaturePackaging.DETACHED);
signatureParameters.setSignatureLevel(SignatureLevel.CAdES_BASELINE_B);
CAdESService service = new CAdESService(getCompleteCertificateVerifier());
ToBeSigned dataToSign = service.getDataToSign(document, signatureParameters);
SignatureValue signatureValue = getToken().sign(dataToSign, signatureParameters.getDigestAlgorithm(), getPrivateKeyEntry());
final DSSDocument signedDocument = service.signDocument(document, signatureParameters, signatureValue);
SignedDocumentValidator validator = SignedDocumentValidator.fromDocument(signedDocument);
validator.setCertificateVerifier(getCompleteCertificateVerifier());
Reports reports = validator.validateDocument();
validator.getOriginalDocuments(reports.getDiagnosticData().getFirstSignatureId());
}
示例9: getSignedDocument
import eu.europa.esig.dss.InMemoryDocument; //導入依賴的package包/類
@Override
protected DSSDocument getSignedDocument() throws Exception {
DSSDocument documentToSign = new InMemoryDocument("Hello world".getBytes());
CAdESSignatureParameters signatureParameters = new CAdESSignatureParameters();
signatureParameters.setSigningCertificate(getSigningCert());
signatureParameters.setCertificateChain(getCertificateChain());
signatureParameters.setSignaturePackaging(SignaturePackaging.ENVELOPING);
signatureParameters.setSignatureLevel(SignatureLevel.CAdES_BASELINE_LT);
CAdESService service = new CAdESService(getCompleteCertificateVerifier());
service.setTspSource(getGoodTsa());
ToBeSigned dataToSign = service.getDataToSign(documentToSign, signatureParameters);
SignatureValue signatureValue = getToken().sign(dataToSign, signatureParameters.getDigestAlgorithm(), getPrivateKeyEntry());
return service.signDocument(documentToSign, signatureParameters, signatureValue);
}
示例10: getSignedDocument
import eu.europa.esig.dss.InMemoryDocument; //導入依賴的package包/類
@Override
protected DSSDocument getSignedDocument() throws Exception {
DSSDocument documentToSign = new InMemoryDocument("Hello world".getBytes());
CAdESSignatureParameters signatureParameters = new CAdESSignatureParameters();
signatureParameters.setSigningCertificate(getSigningCert());
signatureParameters.setCertificateChain(getCertificateChain());
signatureParameters.setSignaturePackaging(SignaturePackaging.ENVELOPING);
signatureParameters.setSignatureLevel(SignatureLevel.CAdES_BASELINE_T);
CAdESService service = new CAdESService(getCompleteCertificateVerifier());
service.setTspSource(getGoodTsa());
ToBeSigned dataToSign = service.getDataToSign(documentToSign, signatureParameters);
SignatureValue signatureValue = getToken().sign(dataToSign, signatureParameters.getDigestAlgorithm(), getPrivateKeyEntry());
return service.signDocument(documentToSign, signatureParameters, signatureValue);
}
示例11: getSignedDocument
import eu.europa.esig.dss.InMemoryDocument; //導入依賴的package包/類
@Override
protected DSSDocument getSignedDocument() throws Exception {
DSSDocument documentToSign = new InMemoryDocument("Hello world".getBytes());
CAdESSignatureParameters signatureParameters = new CAdESSignatureParameters();
signatureParameters.setSigningCertificate(getSigningCert());
signatureParameters.setCertificateChain(getCertificateChain());
signatureParameters.setSignaturePackaging(SignaturePackaging.ENVELOPING);
signatureParameters.setSignatureLevel(SignatureLevel.CAdES_BASELINE_B);
CAdESService service = new CAdESService(getCompleteCertificateVerifier());
ToBeSigned dataToSign = service.getDataToSign(documentToSign, signatureParameters);
SignatureValue signatureValue = getToken().sign(dataToSign, signatureParameters.getDigestAlgorithm(), getPrivateKeyEntry());
return service.signDocument(documentToSign, signatureParameters, signatureValue);
}
示例12: init
import eu.europa.esig.dss.InMemoryDocument; //導入依賴的package包/類
@Before
public void init() throws Exception {
documentToSign = new InMemoryDocument("Hello World".getBytes());
OnlineTSPSource tspSource = getGoodTsa();
TimeStampToken timeStampResponse = tspSource.getTimeStampResponse(DigestAlgorithm.SHA256,
DSSUtils.digest(DigestAlgorithm.SHA256, DSSUtils.toByteArray(documentToSign)));
TimestampToken contentTimestamp = new TimestampToken(timeStampResponse, TimestampType.CONTENT_TIMESTAMP, new CertificatePool());
signatureParameters = new CAdESSignatureParameters();
signatureParameters.bLevel().setSigningDate(new Date());
signatureParameters.setSigningCertificate(getSigningCert());
signatureParameters.setCertificateChain(getCertificateChain());
signatureParameters.setSignaturePackaging(SignaturePackaging.DETACHED);
signatureParameters.setSignatureLevel(SignatureLevel.CAdES_BASELINE_B);
signatureParameters.setContentTimestamps(Arrays.asList(contentTimestamp));
service = new CAdESService(getCompleteCertificateVerifier());
}
示例13: getValidationReport
import eu.europa.esig.dss.InMemoryDocument; //導入依賴的package包/類
@Override
protected Reports getValidationReport(final DSSDocument signedDocument) {
SignedDocumentValidator validator = SignedDocumentValidator.fromDocument(signedDocument);
validator.setCertificateVerifier(getCompleteCertificateVerifier());
InMemoryDocument inMemoryDocument = new InMemoryDocument("Hello World !".getBytes(), "test.text");
byte[] bytes;
try {
bytes = Utils.toByteArray(inMemoryDocument.openStream());
} catch (Exception e) {
throw new DSSException(e);
}
DigestDocument digestDocument = new DigestDocument();
digestDocument.addDigest(DigestAlgorithm.SHA256, Utils.toBase64(DSSUtils.digest(DigestAlgorithm.SHA256, bytes)));
List<DSSDocument> detachedContents = new ArrayList<DSSDocument>();
detachedContents.add(digestDocument);
validator.setDetachedContents(detachedContents);
return validator.validateDocument();
}
示例14: init
import eu.europa.esig.dss.InMemoryDocument; //導入依賴的package包/類
@Before
public void init() throws Exception {
documentToSign = new InMemoryDocument("Hello World".getBytes());
OnlineTSPSource tspSource = getGoodTsa();
TimeStampToken timeStampResponse1 = tspSource.getTimeStampResponse(DigestAlgorithm.SHA256,
DSSUtils.digest(DigestAlgorithm.SHA256, DSSUtils.toByteArray(documentToSign)));
TimestampToken contentTimestamp1 = new TimestampToken(timeStampResponse1, TimestampType.CONTENT_TIMESTAMP, new CertificatePool());
TimeStampToken timeStampResponse2 = tspSource.getTimeStampResponse(DigestAlgorithm.SHA1,
DSSUtils.digest(DigestAlgorithm.SHA1, DSSUtils.toByteArray(documentToSign)));
TimestampToken contentTimestamp2 = new TimestampToken(timeStampResponse2, TimestampType.CONTENT_TIMESTAMP, new CertificatePool());
signatureParameters = new CAdESSignatureParameters();
signatureParameters.bLevel().setSigningDate(new Date());
signatureParameters.setSigningCertificate(getSigningCert());
signatureParameters.setCertificateChain(getSigningCert());
signatureParameters.setSignaturePackaging(SignaturePackaging.ENVELOPING);
signatureParameters.setSignatureLevel(SignatureLevel.CAdES_BASELINE_B);
signatureParameters.setContentTimestamps(Arrays.asList(contentTimestamp1, contentTimestamp2));
service = new CAdESService(getCompleteCertificateVerifier());
}
示例15: createPackageZip
import eu.europa.esig.dss.InMemoryDocument; //導入依賴的package包/類
protected DSSDocument createPackageZip(List<DSSDocument> documents, Date signingDate) {
try (ByteArrayOutputStream baos = new ByteArrayOutputStream(); ZipOutputStream zos = new ZipOutputStream(baos)) {
for (DSSDocument document : documents) {
final String documentName = document.getName();
final String name = documentName != null ? documentName : ZIP_ENTRY_DETACHED_FILE;
final ZipEntry entryDocument = new ZipEntry(name);
entryDocument.setTime(signingDate.getTime());
entryDocument.setMethod(ZipEntry.STORED);
byte[] byteArray = DSSUtils.toByteArray(document);
entryDocument.setSize(byteArray.length);
entryDocument.setCompressedSize(byteArray.length);
final CRC32 crc = new CRC32();
crc.update(byteArray);
entryDocument.setCrc(crc.getValue());
zos.putNextEntry(entryDocument);
Utils.write(byteArray, zos);
}
zos.finish();
return new InMemoryDocument(baos.toByteArray(), "package.zip");
} catch (IOException e) {
throw new DSSException("Unable to create package.zip file", e);
}
}