Spring Securityで、jdbc認証マネージャーを定義しました。
<security:authentication-manager>
<security:authentication-provider>
<security:jdbc-user-service data-source-ref="securityDataSource"/>
</security:authentication-provider>
</security:authentication-manager>
<bean id="securityDataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="org.postgresql.Driver"/>
<property name="url" value="jdbc:postgresql://127.0.0.1:5432/mydb"/>
... user and password props ...
</bean>
この時点で、JakartaCommonsDBCPが必要であることがわかりました。commons-dbcp-1.4を追加しましたが、次の例外が発生します。
...java.lang.NoClassDefFoundError: org/apache/commons/pool/KeyedObjectPoolFactory
このパスは、実際にはcommonsdbcp1.4には含まれていません。
私はまた何が欠けていますか?
編集
OK、共通プールに依存関係を追加しました。正しいクレデンシャルを使用すると、「不正なクレデンシャル」ページが表示されなくなるため、機能します。しかし、HTTPステータス403が表示されます-アクセスが拒否されました。
私のユーザーは認証されているようですが、許可されていません。
何か案が...?:-)
私のhttp要素は:
<security:http auto-config="true" >
<security:intercept-url pattern="/**" access="ROLE_USER"/>
</security:http>
そして、「authorities」テーブルの「USER」ロールにバインドされている「test」ユーザーがいます。
ありがとう