正如MangEngkus的回答所建议的那样,您可以实现自己的自定义 但是根据您的描述,我认为您不需要这样做。
您不需要在spring- security中实现自己的密码哈希机制。您只需要从spring本身定义BCryptPasswordEncoder。
可以通过以下两种方式使用默认方式:
<authentication-manager>
<authentication-provider>
<password-encoder hash="bcrypt" />
</authentication-provider>
</authentication-manager>
或创建自己的bean并将其提供给默认提供程序:
<authentication-manager>
<authentication-provider>
<password-encoder ref="encoder" />
</authentication-provider>
</authentication-manager>
<beans:bean id="encoder"
class="org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder">
<beans:constructor-arg name="strength" value="15" />
</beans:bean>
但是对您来说,这就是方法::)
<beans:bean id="daoAuthenticationProvider" class="org.springframework.security.authentication.dao.DaoAuthenticationProvider">
<beans:property name="userDetailsService" ref="userDetailsService"/>
<beans:property name="passwordEncoder" ref="encoder" />
</beans:bean>
<bean id="encoder" class="org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder"/>