2017-05-25 2 views
1

in sequenceの内部に基本認証ヘッダーを送信するようにWSO2 APIマネージャーを構成したいと考えています。資格情報を保管するために安全な保管庫を設定するまで、すべてがうまくいっていました。wso2:vault-lookup()が動作しない

私はrepository/conf/security/cipher-text.propertiesファイルに新しいVaultエントリを追加しようとしましたAPIマネージャ(https://github.com/wso2/docker-apim/tree/v2.1.0/docker-compose/pattern-2

のdockerizedバージョンを使用していますが、sh bin/ciphertool.sh -Dconfigureを実行した後、私は例外受け取っ:

Exception in thread "main" org.wso2.ciphertool.exception.CipherToolException: XPath value for secret alias 'ApiManager.BasicAuth.password' cannot be found. 
at org.wso2.ciphertool.CipherTool.loadXpathValuesAndPasswordDetails(CipherTool.java:174) 
at org.wso2.ciphertool.CipherTool.main(CipherTool.java:56) 

それがどういう意味を私はそれを使用したいシーケンスファイルにxPathを指定する必要がありますか?私がしようとすると

<property name="X-SomeHeader" expression="wso2:vault-lookup('UserManager.AdminUser.Password')" scope="transport" type="STRING" description="" /> 

:さておき、私は値を使用しましたので、ボールトファイルの内部に配置されている既存のパスワード(repository/conf/security/cipher-text.properties)のいずれかが私の順序で使用することができるかどうかを確認したかったことから、

このシーケンスでAPIを実行するには、この例外が発生します。

api-manager_1 | [2017-05-25 10:12:04,949] ERROR - SynapseXPath Evaluation of the XPath expression wso2:vault-lookup('UserManager.AdminUser.Password') resulted in an error 
api-manager_1 | org.jaxen.FunctionCallException 
api-manager_1 | at org.wso2.carbon.mediation.security.vault.xpath.VaultLookupFunction.call(VaultLookupFunction.java:85) 
api-manager_1 | at org.jaxen.expr.DefaultFunctionCallExpr.evaluate(DefaultFunctionCallExpr.java:181) 
api-manager_1 | at org.jaxen.expr.DefaultXPathExpr.asList(DefaultXPathExpr.java:102) 
api-manager_1 | at org.jaxen.BaseXPath.selectNodesForContext(BaseXPath.java:677) 
api-manager_1 | at org.jaxen.BaseXPath.selectNodes(BaseXPath.java:216) 
api-manager_1 | at org.jaxen.BaseXPath.evaluate(BaseXPath.java:175) 
api-manager_1 | at org.apache.synapse.util.xpath.SynapseXPath.stringValueOf(SynapseXPath.java:297) 
api-manager_1 | at org.apache.synapse.mediators.builtin.PropertyMediator.getResultValue(PropertyMediator.java:346) 
api-manager_1 | at org.apache.synapse.mediators.builtin.PropertyMediator.mediate(PropertyMediator.java:108) 
api-manager_1 | at org.apache.synapse.mediators.AbstractListMediator.mediate(AbstractListMediator.java:97) 
api-manager_1 | at org.apache.synapse.mediators.AbstractListMediator.mediate(AbstractListMediator.java:59) 
api-manager_1 | at org.apache.synapse.mediators.base.SequenceMediator.mediate(SequenceMediator.java:158) 
api-manager_1 | at org.wso2.carbon.apimgt.gateway.handlers.ext.APIManagerExtensionHandler.mediate(APIManagerExtensionHandler.java:67) 
api-manager_1 | at org.wso2.carbon.apimgt.gateway.handlers.ext.APIManagerExtensionHandler.handleRequest(APIManagerExtensionHandler.java:78) 
api-manager_1 | at org.apache.synapse.rest.API.process(API.java:325) 
api-manager_1 | at org.apache.synapse.rest.RESTRequestHandler.dispatchToAPI(RESTRequestHandler.java:90) 
api-manager_1 | at org.apache.synapse.rest.RESTRequestHandler.process(RESTRequestHandler.java:69) 
api-manager_1 | at org.apache.synapse.core.axis2.Axis2SynapseEnvironment.injectMessage(Axis2SynapseEnvironment.java:304) 
api-manager_1 | at org.apache.synapse.core.axis2.SynapseMessageReceiver.receive(SynapseMessageReceiver.java:78) 
api-manager_1 | at org.apache.axis2.engine.AxisEngine.receive(AxisEngine.java:180) 
api-manager_1 | at org.apache.synapse.transport.passthru.ServerWorker.processNonEntityEnclosingRESTHandler(ServerWorker.java:325) 
api-manager_1 | at org.apache.synapse.transport.passthru.ServerWorker.run(ServerWorker.java:158) 
api-manager_1 | at org.apache.axis2.transport.base.threads.NativeWorkerPool$1.run(NativeWorkerPool.java:172) 
api-manager_1 | at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) 
api-manager_1 | at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) 
api-manager_1 | at java.lang.Thread.run(Thread.java:745) 
api-manager_1 | Caused by: java.lang.NullPointerException 
api-manager_1 | at org.wso2.carbon.mediation.security.vault.SecureVaultLookupHandlerImpl.vaultLookup(SecureVaultLookupHandlerImpl.java:166) 
api-manager_1 | at org.wso2.carbon.mediation.security.vault.SecureVaultLookupHandlerImpl.evaluate(SecureVaultLookupHandlerImpl.java:153) 
api-manager_1 | at org.wso2.carbon.mediation.security.vault.xpath.VaultLookupFunction.call(VaultLookupFunction.java:82) 
api-manager_1 | ... 25 more 

私が間違っていることを教えてくれる人はいますか?前もって感謝します。

答えて

0
Exception in thread "main" org.wso2.ciphertool.exception.CipherToolException: XPath value for secret alias 'ApiManager.BasicAuth.password' cannot be found. 
at org.wso2.ciphertool.CipherTool.loadXpathValuesAndPasswordDetails(CipherTool.java:174) 
at org.wso2.ciphertool.CipherTool.main(CipherTool.java:56) 

は、cipher-tool.propertiesファイルに、指定したファイル内のxpathと一致しないxpathが含まれていることを示しています。

それはこのようにする必要があり:あなたは以下を取るので、もし、{別名} = {パス} {}のxpath:

SalesforcePasswords.SalesforceApi.ClientId=tmp/app-config/SalesforcePasswords.xml//SalesforceApi/ClientId 
  • {別名は} SalesforcePasswords.SalesforceApi.ClientId
  • です{パス}はTMP /アプリ-configです/ SalesforcePasswords.xml
  • {}のXPathである// SalesforceApi/ClientIdをご秒exceptioを引き起こしているのかわから

ありませんn

関連する問題