QuartzServer NET 可以解密配置文件中的连接字符串吗?

Can QuartzServer NET decrypts connection string in config file?

我正在使用 Quartz.Server.exe 2.X 作为作业执行器。 我正在使用 Quartz.Server.exe.config 来配置石英。

<quartz >
    <add key="quartz.scheduler.instanceName" value="AlyCE_LROScheduler" />
    <add key="quartz.jobStore.type" value="Quartz.Impl.AdoJobStore.JobStoreTX, Quartz" />
    <add key="quartz.jobStore.useProperties" value="true" />
    <add key="quartz.jobStore.driverDelegateType" value="Quartz.Impl.AdoJobStore.SqlServerDelegate, Quartz" />
    <add key="quartz.jobStore.tablePrefix" value="QUARTZ_" />
    <add key="quartz.jobStore.dataSource" value="defaultDS" />
    <add key="quartz.jobStore.lockHandler.type" value="Quartz.Impl.AdoJobStore.UpdateLockRowSemaphore, Quartz" />
    <add key="quartz.dataSource.defaultDS.provider" value="SqlServer-20" />
    <add key="quartz.dataSource.defaultDS.connectionString" value="my connection string to encrypt/decrypt" />
</quartz>

一切正常。出于安全原因,现在我想加密连接字符串。

有没有办法让Quartz.Server.exe理解加密的连接字符串?

谢谢

我解决了。 我删除了连接字符串 quartz 属性 并添加了 connectionProvider.type 属性,这让我可以覆盖标准 Quartz.Impl.AdoJobStore.Common.DbProvider.

所以我能够解密我的连接字符串。

所以我的配置如下所示:

<quartz >
    <!-- thread pool info -->
    <add key="quartz.threadPool.type" value="Quartz.Simpl.SimpleThreadPool, Quartz" />
    <!-- job store info -->
    <add key="quartz.jobStore.type" value="Quartz.Impl.AdoJobStore.JobStoreTX, Quartz" />
    <add key="quartz.jobStore.useProperties" value="true" />
    <add key="quartz.jobStore.driverDelegateType" value="Quartz.Impl.AdoJobStore.SqlServerDelegate, Quartz" />
    <add key="quartz.jobStore.tablePrefix" value="QUARTZ_" />
    <add key="quartz.jobStore.dataSource" value="defaultDS" />
    <add key="quartz.jobStore.lockHandler.type" value="Quartz.Impl.AdoJobStore.UpdateLockRowSemaphore, Quartz" />
    <add key="quartz.dataSource.defaultDS.connectionProvider.type" value="MyDll.MyDbProvider, MyDll" />
</quartz>
<connectionStrings>
    <add key="myConnString" connectionString="crypted"/>
</connectionStrings>

然后我创建新的 class 库项目,我在其中创建了这个 class:

public class MyDbProvider : DbProvider
{
    public MyDbProvider() : base("SqlServer-20", MyHelper.GetConnectionString()) { }
}

public static class MyHelper
{
    public static string GetConnectionString()
    {
        //here i decrypt my connection string from app.config file
    }
}

MyDll.dll 必须在 Quartz.Server.exe 的同一目录中。

希望这可以帮助到别人!