Ошибка в безопасной загрузке источника данных.Произошла ошибка при расшифровке данных - PullRequest
0 голосов
/ 18 ноября 2018

Я знаю, подобный вопрос уже задавался здесь , но, поскольку данный ответ мне не помогает, и моя проблема несколько иная, я задаю новый вопрос.

Я создаю источники данных через admin panel -> Configure -> Datasources, и все работает нормально. Но если я перезапущу сервер, все созданные источники данных пропадут из списка источников данных.

Когда я запускаю сервер ESB , в журналах я вижу, что эти источники данных не могут быть загружены должным образом, так как сервер ESB не может расшифровать конфиденциальные данные, которые он зашифровал ранее:

Ошибка DataSourceRepository при обновлении источника данных [удалить: false] по пути '/repository/components/org.wso2.carbon.ndatasource/myDatasource

Ошибка при обновлении источника данных «myDatasource» из реестра [удалить: false]: ошибка в безопасной загрузке источника данных

метаинформация: при расшифровке данных произошла ошибка

Хотя myDatasource отсутствует в списке источников данных, я все еще могу увидеть его в реестре через admin panel -> Registry -> /_system/config/repository/components/org.wso2.carbon.ndatasource/myDatasource

1 Ответ

0 голосов
/ 18 декабря 2018

У меня та же проблема.Кажется, это какая-то ошибка, внесенная в 6.4.0.
6.3.0 не демонстрирует такого поведения.

В качестве обходного пути, если вы определите источники данных в / conf / datasources / master-datasources.xml , тогда источники данных будут загружаться правильно при запуске сервера.Однако это не идеальное решение, так как их нельзя редактировать через веб-консоль.

В качестве альтернативы вы можете загрузить запись в реестре, отредактировать элемент пароля, удалив «Encrypted = true», и изменить пароль для незашифрованного.Затем загрузите отредактированный файл как новую запись в реестре вместе со старым.

Оба эти метода неосуществимы для производства, хотя они оставляют пароли незашифрованными.

Из-за интереса вы запускаете это наОкна?Я также обнаружил на EI 6.4.0, что утилита Ciphertool не будет работать из-за неправильного пути.Я подозреваю, что это может быть связано, но я не могу найти, откуда исходит неправильный путь, он, кажется, повторяет элемент {carbon.home} внутри пути:

    C:\Program Files\WSO2\Enterprise Integrator\6.4.0\bin>ciphertool
Using CARBON_HOME:   C:\Program Files\WSO2\Enterprise Integrator\6.4.0
Using JAVA_HOME:    C:\WSO2\Enterprise Integrator\6.3.0\jdk\jdk1.8.0_192
Exception in thread "main" java.nio.file.InvalidPathException: Illegal char <:> at index 51: C:\Program Files\WSO2\Enterprise Integrator\6.4.0\C:\Program Files\WSO2\Enterprise Integrator\6.4.0\/repository/resources/security/wso2carbon.jks
        at sun.nio.fs.WindowsPathParser.normalize(WindowsPathParser.java:182)
        at sun.nio.fs.WindowsPathParser.parse(WindowsPathParser.java:153)
        at sun.nio.fs.WindowsPathParser.parse(WindowsPathParser.java:77)
        at sun.nio.fs.WindowsPath.parse(WindowsPath.java:94)
        at sun.nio.fs.WindowsFileSystem.getPath(WindowsFileSystem.java:255)
        at java.nio.file.Paths.get(Paths.java:84)
        at org.wso2.ciphertool.utils.Utils.getConfigFilePath(Utils.java:98)
        at org.wso2.ciphertool.utils.Utils.setSystemProperties(Utils.java:289)
        at org.wso2.ciphertool.CipherTool.initialize(CipherTool.java:93)
        at org.wso2.ciphertool.CipherTool.main(CipherTool.java:52)
...