在 Wildfly 中配置无密码 Azure SQL

问题描述 投票:0回答:1

我正在尝试配置部署到 Wildfly 23 的应用程序以使用托管身份连接到 Azure SQL,但很难想象它的工作原理。 互联网上有大量关于如何使用无密码连接连接到 Azure 托管数据库的文章和操作方法。其中大多数需要将 azure-identity.jar 包含到类路径中,并在 jdbc 连接字符串中使用 authentication=ActiveDirectoryMSI 选项。 但是,我的应用程序使用疯狂配置的连接池,因此将 azure-identity.jar 添加到我的应用程序将无济于事。根据我的理解,我需要使 azure-identity.jar 可用于 wildfly,但我不知道该怎么做。一个想法是将其注册为模块,我还没有尝试过,因为我需要以某种方式管理 jar 的依赖关系。

到目前为止,我更改了独立文件以包含数据源

<datasource jndi-name="java:/jdbc/passwordless" pool-name="pwls-ds" enabled="true">
                    <connection-url>jdbc:sqlserver://xxxxx.database.windows.net:1433;database=aaa;encrypt=true;trustServerCertificate=false;hostNameInCertificate=*.database.windows.net;authentication=ActiveDirectoryMSI</connection-url>
                    <driver-class>com.microsoft.sqlserver.jdbc.SQLServerDriver</driver-class>
                    <driver>mssql-jdbc-12.4.1.jre11.jar</driver>
                    <transaction-isolation>TRANSACTION_READ_COMMITTED</transaction-isolation>
                    <pool>
                        <min-pool-size>2</min-pool-size>
                        <initial-pool-size>5</initial-pool-size>
                        <max-pool-size>20</max-pool-size>
                    </pool>
                </datasource>

尝试测试连接时,出现以下异常

com.microsoft.sqlserver.jdbc.SQLServerException:无法加载用于执行 ActiveDirectoryManagedIdentity 身份验证的 MSAL4J Java 库

任何提示/帮助表示赞赏。

java sql-server azure wildfly password-less
1个回答
0
投票

添加MSAL4J,包括类路径上的所有依赖项

© www.soinside.com 2019 - 2024. All rights reserved.