1. 程式人生 > 其它 >spring使用策略模式,實現多種場景登入方式(策略模式)

spring使用策略模式,實現多種場景登入方式(策略模式)

技術標籤:Springspring

spring使用策略模式,實現多種場景登入方式

@Autowired註解可以幫我們自動注入我們想要的 Bean。

如果只是簡單使用@Autowired會遇到spring IOC容器中一個介面有多個實現的情況,spring無法識別具體的實現類,如果不是策略模式,我們可以進行具體的指定@Qualifier和@primary來避免bean衝突的情況。但在策略模式中是不行的。

而除了這個基本功能之外, @Autowired 還有更加強大的功能,還可以注入指定型別的陣列,List/Set 集合,甚至還可以是 Map 物件。

模擬多種場景下登入例子(適合策略模式都行:多種支付方式等)

為每個具體的實現類添加了一個編號,方便識別,具體可以根據場景選擇,這裡只是模擬。

登入service

@Service
public class LoginService {

    @Autowired
    Set<Login> loginSet;//使用了Set 

    Map<Integer,Login> loginMap;

    public User login(User userLogin) {
        Login login=loginMap.get(userLogin.getChannelNo());
        return login.login(userLogin);
    }

    @PostConstruct
    public void init() {
        loginMap = new HashMap<>();
        for (Login login : loginSet) {
            loginMap.put(login.channel(), login);
        }

    }
}

原始碼策略介面

@Component
public interface Login {
    User login(User userLogin);
    Integer channel();
}

具體實現類—使用者密碼登入

@Component
public class PasswordLogin implements Login {
    @Autowired
    LoginDao loginDao;

    @Override
    public User login(User userLogin) {

        return loginDao.PasswordLogin(userLogin.getUsername(),userLogin.getPassword());
    }

    @Override
    public Integer channel() {
        return 2;
    }
}

具體實現類—郵箱登入


@Component
public class EmailLogin implements Login {
    @Autowired
    LoginDao loginDao;

    @Override
    public User login(User userLogin) {
        return loginDao.EmailLogin(userLogin.getEmail(),userLogin.getPassword());
    }

    @Override
    public Integer channel() {
        return 3;
    }
}

具體實現類—郵箱登入

@Component
public class PhoneLogin implements Login {
    @Autowired
    LoginDao loginDao;

    @Override
    public User login(User userLogin) {
        return loginDao.PhoneLogin(userLogin.getPhone(),userLogin.getPassword());
    }

    @Override
    public Integer channel() {
        return 1;
    }
}

簡單模擬登入SQL

@Mapper
@Repository
public interface LoginDao {

    @Select("select * from user where phone=#{phone} and password=#{password}")
    User PhoneLogin(String phone,String password);

    @Select("select * from user where username=#{username} and password=#{password}")
    User PasswordLogin(String username,String password);

    @Select("select * from user where email=#{email} and password=#{password}")
    User EmailLogin(String email,String password);

}