淺談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);
}

到此這篇關於spring使用策略模式實現多種場景登錄方式的文章就介紹到這瞭,更多相關spring 策略模式登錄內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: