亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Spring Boot 1 數據庫多數據庫用戶

Spring Boot 1 數據庫多數據庫用戶

慕無忌1623718 2024-01-05 16:44:39
我目前正在構建一個訪問數據庫的restful API(使用Spring Boot)。該應用程序最終將托管在服務器上。我想做的事:配置數據庫有多用戶,并為不同的表分配不同的權限根據調用的端點,使用特定用戶在該函數中執行該查詢我該如何配置上述應用程序?到目前為止我找到的答案涉及配置多個數據源,但對于上述應用程序,只有一個數據源,但有多個用戶。我已閱讀以下鏈接,但仍在嘗試理解它https://kimrudolph.de/blog/spring-datasource-routing我是否使用相同的 URL(本例中為 jdbcURL)配置多個數據源,并為每個角色配置多組用戶名和密碼?謝謝你!
查看完整描述

1 回答

?
忽然笑

TA貢獻1806條經驗 獲得超5個贊

我的意思是,你已經找到了完成這項任務的最佳方法AbstractRoutingDataSource。如果您有固定數量的用戶,那么您可以使用以下方法的最簡單方法:


public final class RoutingDataSource extends AbstractRoutingDataSource {

    @Override

    protected Object determineCurrentLookupKey() {

        return UserContextHolder.getUserName() + "DataSource";

    }

}

以及配置:


@Bean

@Qualifier("user1DataSource")

public DataSource userOneDataSource() {

    return DataSourceBuilder.create()

            .username("user1")

            .password("pass")

             ...

             .build();

}


@Bean

@Qualifier("user2DataSource")

public DataSource userOneDataSource() {

    return DataSourceBuilder.create()

            .username("user2")

             ...

             .build();

}


@Bean

@Primary

public RoutingDataSource dataSource(Map<String, DataSource> datasources) {

    return new RoutingDataSource().dataSource(datasources);

 }

如果您需要在運行時添加用戶和數據源,您可以使用如下內容:


public final class RoutingDataSource extends AbstractRoutingDataSource {

    private final ConcurrentHashMap<String, DataSource> dynamicDataSources = new ConcurrentHashMap<>();


    @Override

    protected Object determineCurrentLookupKey() {

        return UserContextHolder.getUserName() + "_datasource";

    }


    @Override

    protected DataSource determineTargetDataSource() {

        String currentLookupKey = this.determineCurrentLookupKey().toString();

        String userName = UserContextHolder.getUserName();

        String password = UserContextHolder.getPassword();


        return this.dynamicDataSources.computeIfAbsent(currentLookupKey, (key) -> DataSourceBuilder.create()

                .driverClassName("your.driver.class")

                .url("jdbc:same:url/here")

                .username(userName)

                .password(password)

                .build());

    }

}


查看完整回答
反對 回復 2024-01-05
  • 1 回答
  • 0 關注
  • 159 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號