mirror of
				https://github.com/dromara/RuoYi-Vue-Plus.git
				synced 2025-11-04 16:23:42 +08:00 
			
		
		
		
	!442 update 优化登录策略代码
Merge pull request !442 from David Wei/update/login_strategy-dev
This commit is contained in:
		@@ -20,18 +20,17 @@ public interface IAuthStrategy {
 | 
			
		||||
     */
 | 
			
		||||
    static LoginVo login(String body, SysClient client, String grantType) {
 | 
			
		||||
        // 授权类型和客户端id
 | 
			
		||||
        String clientId = client.getClientId();
 | 
			
		||||
        String beanName = grantType + BASE_NAME;
 | 
			
		||||
        if (!SpringUtils.containsBean(beanName)) {
 | 
			
		||||
            throw new ServiceException("授权类型不正确!");
 | 
			
		||||
        }
 | 
			
		||||
        IAuthStrategy instance = SpringUtils.getBean(beanName);
 | 
			
		||||
        return instance.login(clientId, body, client);
 | 
			
		||||
        return instance.login(body, client);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * 登录
 | 
			
		||||
     */
 | 
			
		||||
    LoginVo login(String clientId, String body, SysClient client);
 | 
			
		||||
    LoginVo login(String body, SysClient client);
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -44,7 +44,7 @@ public class EmailAuthStrategy implements IAuthStrategy {
 | 
			
		||||
    private final SysUserMapper userMapper;
 | 
			
		||||
 | 
			
		||||
    @Override
 | 
			
		||||
    public LoginVo login(String clientId, String body, SysClient client) {
 | 
			
		||||
    public LoginVo login(String body, SysClient client) {
 | 
			
		||||
        EmailLoginBody loginBody = JsonUtils.parseObject(body, EmailLoginBody.class);
 | 
			
		||||
        ValidatorUtils.validate(loginBody);
 | 
			
		||||
        String tenantId = loginBody.getTenantId();
 | 
			
		||||
@@ -65,7 +65,7 @@ public class EmailAuthStrategy implements IAuthStrategy {
 | 
			
		||||
        // 例如: 后台用户30分钟过期 app用户1天过期
 | 
			
		||||
        model.setTimeout(client.getTimeout());
 | 
			
		||||
        model.setActiveTimeout(client.getActiveTimeout());
 | 
			
		||||
        model.setExtra(LoginHelper.CLIENT_KEY, clientId);
 | 
			
		||||
        model.setExtra(LoginHelper.CLIENT_KEY, client.getClientId());
 | 
			
		||||
        // 生成token
 | 
			
		||||
        LoginHelper.login(loginUser, model);
 | 
			
		||||
 | 
			
		||||
@@ -75,7 +75,7 @@ public class EmailAuthStrategy implements IAuthStrategy {
 | 
			
		||||
        LoginVo loginVo = new LoginVo();
 | 
			
		||||
        loginVo.setAccessToken(StpUtil.getTokenValue());
 | 
			
		||||
        loginVo.setExpireIn(StpUtil.getTokenTimeout());
 | 
			
		||||
        loginVo.setClientId(clientId);
 | 
			
		||||
        loginVo.setClientId(client.getClientId());
 | 
			
		||||
        return loginVo;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -48,7 +48,7 @@ public class PasswordAuthStrategy implements IAuthStrategy {
 | 
			
		||||
    private final SysUserMapper userMapper;
 | 
			
		||||
 | 
			
		||||
    @Override
 | 
			
		||||
    public LoginVo login(String clientId, String body, SysClient client) {
 | 
			
		||||
    public LoginVo login(String body, SysClient client) {
 | 
			
		||||
        PasswordLoginBody loginBody = JsonUtils.parseObject(body, PasswordLoginBody.class);
 | 
			
		||||
        ValidatorUtils.validate(loginBody);
 | 
			
		||||
        String tenantId = loginBody.getTenantId();
 | 
			
		||||
@@ -75,7 +75,7 @@ public class PasswordAuthStrategy implements IAuthStrategy {
 | 
			
		||||
        // 例如: 后台用户30分钟过期 app用户1天过期
 | 
			
		||||
        model.setTimeout(client.getTimeout());
 | 
			
		||||
        model.setActiveTimeout(client.getActiveTimeout());
 | 
			
		||||
        model.setExtra(LoginHelper.CLIENT_KEY, clientId);
 | 
			
		||||
        model.setExtra(LoginHelper.CLIENT_KEY, client.getClientId());
 | 
			
		||||
        // 生成token
 | 
			
		||||
        LoginHelper.login(loginUser, model);
 | 
			
		||||
 | 
			
		||||
@@ -85,7 +85,7 @@ public class PasswordAuthStrategy implements IAuthStrategy {
 | 
			
		||||
        LoginVo loginVo = new LoginVo();
 | 
			
		||||
        loginVo.setAccessToken(StpUtil.getTokenValue());
 | 
			
		||||
        loginVo.setExpireIn(StpUtil.getTokenTimeout());
 | 
			
		||||
        loginVo.setClientId(clientId);
 | 
			
		||||
        loginVo.setClientId(client.getClientId());
 | 
			
		||||
        return loginVo;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -44,7 +44,7 @@ public class SmsAuthStrategy implements IAuthStrategy {
 | 
			
		||||
    private final SysUserMapper userMapper;
 | 
			
		||||
 | 
			
		||||
    @Override
 | 
			
		||||
    public LoginVo login(String clientId, String body, SysClient client) {
 | 
			
		||||
    public LoginVo login(String body, SysClient client) {
 | 
			
		||||
        SmsLoginBody loginBody = JsonUtils.parseObject(body, SmsLoginBody.class);
 | 
			
		||||
        ValidatorUtils.validate(loginBody);
 | 
			
		||||
        String tenantId = loginBody.getTenantId();
 | 
			
		||||
@@ -65,7 +65,7 @@ public class SmsAuthStrategy implements IAuthStrategy {
 | 
			
		||||
        // 例如: 后台用户30分钟过期 app用户1天过期
 | 
			
		||||
        model.setTimeout(client.getTimeout());
 | 
			
		||||
        model.setActiveTimeout(client.getActiveTimeout());
 | 
			
		||||
        model.setExtra(LoginHelper.CLIENT_KEY, clientId);
 | 
			
		||||
        model.setExtra(LoginHelper.CLIENT_KEY, client.getClientId());
 | 
			
		||||
        // 生成token
 | 
			
		||||
        LoginHelper.login(loginUser, model);
 | 
			
		||||
 | 
			
		||||
@@ -75,7 +75,7 @@ public class SmsAuthStrategy implements IAuthStrategy {
 | 
			
		||||
        LoginVo loginVo = new LoginVo();
 | 
			
		||||
        loginVo.setAccessToken(StpUtil.getTokenValue());
 | 
			
		||||
        loginVo.setExpireIn(StpUtil.getTokenTimeout());
 | 
			
		||||
        loginVo.setClientId(clientId);
 | 
			
		||||
        loginVo.setClientId(client.getClientId());
 | 
			
		||||
        return loginVo;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -54,12 +54,11 @@ public class SocialAuthStrategy implements IAuthStrategy {
 | 
			
		||||
    /**
 | 
			
		||||
     * 登录-第三方授权登录
 | 
			
		||||
     *
 | 
			
		||||
     * @param clientId 客户端id
 | 
			
		||||
     * @param body     登录信息
 | 
			
		||||
     * @param client   客户端信息
 | 
			
		||||
     */
 | 
			
		||||
    @Override
 | 
			
		||||
    public LoginVo login(String clientId, String body, SysClient client) {
 | 
			
		||||
    public LoginVo login(String body, SysClient client) {
 | 
			
		||||
        SocialLoginBody loginBody = JsonUtils.parseObject(body, SocialLoginBody.class);
 | 
			
		||||
        ValidatorUtils.validate(loginBody);
 | 
			
		||||
        AuthResponse<AuthUser> response = SocialUtils.loginAuth(
 | 
			
		||||
@@ -103,7 +102,7 @@ public class SocialAuthStrategy implements IAuthStrategy {
 | 
			
		||||
        // 例如: 后台用户30分钟过期 app用户1天过期
 | 
			
		||||
        model.setTimeout(client.getTimeout());
 | 
			
		||||
        model.setActiveTimeout(client.getActiveTimeout());
 | 
			
		||||
        model.setExtra(LoginHelper.CLIENT_KEY, clientId);
 | 
			
		||||
        model.setExtra(LoginHelper.CLIENT_KEY, client.getClientId());
 | 
			
		||||
        // 生成token
 | 
			
		||||
        LoginHelper.login(loginUser, model);
 | 
			
		||||
 | 
			
		||||
@@ -113,7 +112,7 @@ public class SocialAuthStrategy implements IAuthStrategy {
 | 
			
		||||
        LoginVo loginVo = new LoginVo();
 | 
			
		||||
        loginVo.setAccessToken(StpUtil.getTokenValue());
 | 
			
		||||
        loginVo.setExpireIn(StpUtil.getTokenTimeout());
 | 
			
		||||
        loginVo.setClientId(clientId);
 | 
			
		||||
        loginVo.setClientId(client.getClientId());
 | 
			
		||||
        return loginVo;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -33,7 +33,7 @@ public class XcxAuthStrategy implements IAuthStrategy {
 | 
			
		||||
    private final SysLoginService loginService;
 | 
			
		||||
 | 
			
		||||
    @Override
 | 
			
		||||
    public LoginVo login(String clientId, String body, SysClient client) {
 | 
			
		||||
    public LoginVo login(String body, SysClient client) {
 | 
			
		||||
        XcxLoginBody loginBody = JsonUtils.parseObject(body, XcxLoginBody.class);
 | 
			
		||||
        ValidatorUtils.validate(loginBody);
 | 
			
		||||
        // xcxCode 为 小程序调用 wx.login 授权后获取
 | 
			
		||||
@@ -64,7 +64,7 @@ public class XcxAuthStrategy implements IAuthStrategy {
 | 
			
		||||
        // 例如: 后台用户30分钟过期 app用户1天过期
 | 
			
		||||
        model.setTimeout(client.getTimeout());
 | 
			
		||||
        model.setActiveTimeout(client.getActiveTimeout());
 | 
			
		||||
        model.setExtra(LoginHelper.CLIENT_KEY, clientId);
 | 
			
		||||
        model.setExtra(LoginHelper.CLIENT_KEY, client.getClientId());
 | 
			
		||||
        // 生成token
 | 
			
		||||
        LoginHelper.login(loginUser, model);
 | 
			
		||||
 | 
			
		||||
@@ -74,7 +74,7 @@ public class XcxAuthStrategy implements IAuthStrategy {
 | 
			
		||||
        LoginVo loginVo = new LoginVo();
 | 
			
		||||
        loginVo.setAccessToken(StpUtil.getTokenValue());
 | 
			
		||||
        loginVo.setExpireIn(StpUtil.getTokenTimeout());
 | 
			
		||||
        loginVo.setClientId(clientId);
 | 
			
		||||
        loginVo.setClientId(client.getClientId());
 | 
			
		||||
        loginVo.setOpenid(openid);
 | 
			
		||||
        return loginVo;
 | 
			
		||||
    }
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user