java.security.InvalidAlgorithmParameterException, в то время как jClouds MS Azure Blob помещает операцию

У меня проблема с API-интерфейсом jClouds AzureBlob с операцией пут

context = new BlobStoreContextFactory().createContext(
                    this.storageType,
                    this.storageAccount, 
                    this.primaryAccessKey);

    BlobStore blobStore = context.getBlobStore();
                Blob blob = blobStore.blobBuilder(fileName).payload(content).build(); //$NON-NLS-1$
                blobStore.putBlob(this.containerName, blob);

Я устанавливаю первичный ключ доступа из ключа управления доступом -> Первичный ключ доступа для моей учетной записи хранения.

Это дает мне следующую ошибку

org.jclouds.http.HttpResponseException: java.lang.RuntimeException: Unexpected error: java.security.InvalidAlgorithmParameterException: the trustAnchors parameter must be non-empty connecting to PUT https://mypackages.blob.core.windows.net/mycontainer/ERROR/error_20130717022518962.xml HTTP/1.1
    at org.jclouds.http.internal.BaseHttpCommandExecutorService$HttpResponseCallable.call(BaseHttpCommandExecutorService.java:173)
    at org.jclouds.http.internal.BaseHttpCommandExecutorService$HttpResponseCallable.call(BaseHttpCommandExecutorService.java:130)
    at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303)[:1.6.0_43]
    at java.util.concurrent.FutureTask.run(FutureTask.java:138)[:1.6.0_43]
    at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:895)[:1.6.0_43]
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:918)[:1.6.0_43]
    at java.lang.Thread.run(Thread.java:662)[:1.6.0_43]
    at org.jclouds.concurrent.config.ExecutorServiceModule$DescribingExecutorService.submit(ExecutorServiceModule.java:184)
    at org.jclouds.http.internal.BaseHttpCommandExecutorService.submit(BaseHttpCommandExecutorService.java:127)
    at org.jclouds.http.TransformingHttpCommandExecutorServiceImpl.submit(TransformingHttpCommandExecutorServiceImpl.java:54)
    at org.jclouds.http.TransformingHttpCommandImpl.execute(TransformingHttpCommandImpl.java:73)
    at org.jclouds.rest.internal.AsyncRestClientProxy.createListenableFutureForHttpRequestMappedToMethodAndArgs(AsyncRestClientProxy.java:198)
    at org.jclouds.rest.internal.AsyncRestClientProxy.invoke(AsyncRestClientProxy.java:134)
    at com.sun.proxy.$Proxy295.putBlob(Unknown Source)
    at sun.reflect.GeneratedMethodAccessor107.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)[:1.6.0_43]
    at java.lang.reflect.Method.invoke(Method.java:597)[:1.6.0_43]
    at org.jclouds.concurrent.internal.SyncProxy.invoke(SyncProxy.java:137)
    at com.sun.proxy.$Proxy296.putBlob(Unknown Source)
    at org.jclouds.azureblob.blobstore.AzureBlobStore.putBlob(AzureBlobStore.java:194)
    at sun.reflect.GeneratedMethodAccessor105.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)[:1.6.0_43]
    at java.lang.reflect.Method.invoke(Method.java:597)[:1.6.0_43]
    at com.google.inject.internal.DelegatingInvocationHandler.invoke(DelegatingInvocationHandler.java:37)
    at com.sun.proxy.$Proxy287.putBlob(Unknown Source)

В приведенной выше трассировке стека "ОШИБКА /error_20130717022518962.xml " - это файл, который я пытаюсь поместить в хранилище BLOB-объектов.

Любая подсказка, как решить эту проблему?

1 ответ

Решение

Эта проблема была решена, фактически код, который вызывает ReST PUT для хранения BLOB-объектов Azure. как-то не удалось загрузить стандартное хранилище java по умолчанию.

Добавив строку ниже, чтобы загрузить Cacert по умолчанию

System.setProperty("javax.net.ssl.trustStore",PATH_TO_CACERT);
System.setProperty("javax.net.ssl.trustStorePassword",PASSWORD);
Другие вопросы по тегам