提交 acc30e87 编写于 作者: sq3536's avatar sq3536

uaa整改

上级 3ccec3a6
...@@ -21,4 +21,8 @@ public class IBZUAAFallback implements IBZUAAFeignClient { ...@@ -21,4 +21,8 @@ public class IBZUAAFallback implements IBZUAAFeignClient {
return null; return null;
} }
@Override
public AuthenticationUser loginByUsername(String username) {
return null;
}
} }
...@@ -29,4 +29,7 @@ public interface IBZUAAFeignClient ...@@ -29,4 +29,7 @@ public interface IBZUAAFeignClient
@PostMapping(value = "/uaa/login") @PostMapping(value = "/uaa/login")
AuthenticationUser login(@RequestBody AuthorizationLogin authorizationLogin); AuthenticationUser login(@RequestBody AuthorizationLogin authorizationLogin);
@PostMapping(value = "/uaa/loginbyusername")
AuthenticationUser loginByUsername(@RequestBody String username);
} }
...@@ -39,7 +39,7 @@ public class AuthenticationController ...@@ -39,7 +39,7 @@ public class AuthenticationController
@PostMapping(value = ${r'"${ibiz.auth.path:v7/login}"'}) @PostMapping(value = ${r'"${ibiz.auth.path:v7/login}"'})
public ResponseEntity<AuthenticationInfo> login(@Validated @RequestBody AuthorizationLogin authorizationLogin){ public ResponseEntity<AuthenticationInfo> login(@Validated @RequestBody AuthorizationLogin authorizationLogin){
userDetailsService.resetByUsername(authorizationLogin.getUsername()); userDetailsService.resetByUsername(authorizationLogin.getUsername());
final AuthenticationUser authuserdetail = userDetailsService.loadUserByLogin(authorizationLogin.getDomain(),authorizationLogin.getLoginname(),authorizationLogin.getPassword()); final AuthenticationUser authuserdetail = userDetailsService.loadUserByLogin(authorizationLogin.getUsername(),authorizationLogin.getPassword());
// 生成令牌 // 生成令牌
final String token = jwtTokenUtil.generateToken(authuserdetail); final String token = jwtTokenUtil.generateToken(authuserdetail);
// 返回 token // 返回 token
......
...@@ -16,16 +16,19 @@ import org.springframework.stereotype.Service; ...@@ -16,16 +16,19 @@ import org.springframework.stereotype.Service;
public interface AuthenticationUserService extends UserDetailsService { public interface AuthenticationUserService extends UserDetailsService {
<#if sys.getPSSystemSetting()?? && sys.getPSSystemSetting().getDataAccCtrlArch()?? && sys.getPSSystemSetting().getDataAccCtrlArch()==1>
<#assign cachename="ibzuaa_users">
<#else >
<#assign cachename=pub.getCodeName()?lower_case+"_users">
</#if>
@Override @Override
@Cacheable( value="ibzdict_users",key = "'getByUsername:'+#p0") @Cacheable( value="${cachename}",key = "'getByUsername:'+#p0")
AuthenticationUser loadUserByUsername(String username); AuthenticationUser loadUserByUsername(String username);
@Cacheable( value="ibzdict_users",key = "'getByUsername:'+#p0") @Cacheable( value="${cachename}",key = "'getByUsername:'+#p0")
AuthenticationUser loadUserByLogin(String username,String password); AuthenticationUser loadUserByLogin(String username,String password);
@Cacheable( value="ibzdict_users",key = "'getByUsername:'+#p1") @CacheEvict( value="${cachename}",key = "'getByUsername:'+#p0")
AuthenticationUser loadUserByLogin(String domain,String username,String password);
@CacheEvict( value="ibzdict_users",key = "'getByUsername:'+#p0")
void resetByUsername(String username); void resetByUsername(String username);
} }
...@@ -5,6 +5,7 @@ package ${pub.getPKGCodeName()}.util.service; ...@@ -5,6 +5,7 @@ package ${pub.getPKGCodeName()}.util.service;
import com.alibaba.fastjson.JSONObject; import com.alibaba.fastjson.JSONObject;
import ${pub.getPKGCodeName()}.util.client.IBZOUFeignClient; import ${pub.getPKGCodeName()}.util.client.IBZOUFeignClient;
import ${pub.getPKGCodeName()}.util.errors.BadRequestAlertException;
import ${pub.getPKGCodeName()}.util.client.IBZUAAFeignClient; import ${pub.getPKGCodeName()}.util.client.IBZUAAFeignClient;
import ${pub.getPKGCodeName()}.util.security.AuthenticationUser; import ${pub.getPKGCodeName()}.util.security.AuthenticationUser;
import ${pub.getPKGCodeName()}.util.security.AuthorizationLogin; import ${pub.getPKGCodeName()}.util.security.AuthorizationLogin;
...@@ -18,7 +19,6 @@ import org.springframework.util.StringUtils; ...@@ -18,7 +19,6 @@ import org.springframework.util.StringUtils;
/** /**
* 实体[IBZUSER] 服务对象接口实现 * 实体[IBZUSER] 服务对象接口实现
*/ */
//@Primary
@Service("IBZUAAUserService") @Service("IBZUAAUserService")
public class IBZUAAUserService implements AuthenticationUserService{ public class IBZUAAUserService implements AuthenticationUserService{
...@@ -28,39 +28,32 @@ public class IBZUAAUserService implements AuthenticationUserService{ ...@@ -28,39 +28,32 @@ public class IBZUAAUserService implements AuthenticationUserService{
@Override @Override
public AuthenticationUser loadUserByUsername(String username) { public AuthenticationUser loadUserByUsername(String username) {
AuthenticationUser user=uaaFeignClient.loginByUsername(username);
if(user==null)
throw new BadRequestAlertException("登录失败","IBZUAAUser",username);
return user;
}
@Override
public AuthenticationUser loadUserByLogin(String username, String password) {
String[] data=username.split("[|]"); String[] data=username.split("[|]");
String loginname=username; String loginname=username;
String domains=""; String domains="";
String password="";
if(data.length==3) { if(data.length==2) {
loginname=data[0].trim(); loginname=data[0].trim();
domains=data[1].trim(); domains=data[1].trim();
password=data[2].trim();
}
else if(data.length==2) {
loginname=data[0].trim();
password=data[1].trim();
} }
AuthorizationLogin user = new AuthorizationLogin(); AuthorizationLogin logininfo = new AuthorizationLogin();
user.setDomain(domains); logininfo.setDomain(domains);
user.setLoginname(loginname); logininfo.setLoginname(loginname);
user.setPassword(password); logininfo.setPassword(password);
return uaaFeignClient.login(user); AuthenticationUser user=uaaFeignClient.login(logininfo);
if(user==null)
throw new BadRequestAlertException("登录失败","IBZUAAUser",username);
return user;
} }
@Override
public AuthenticationUser loadUserByLogin(String username, String password) {
AuthenticationUser authuserdetail = loadUserByUsername(username+"|"+password);
return authuserdetail;
}
@Override
public AuthenticationUser loadUserByLogin(String domain, String username, String password) {
if(!StringUtils.isEmpty(domain))
username = username+"|"+domain;
return loadUserByLogin(username,password);
}
@Override @Override
public void resetByUsername(String username) { public void resetByUsername(String username) {
......
...@@ -65,12 +65,6 @@ public class IBZUSERServiceImpl extends ServiceImpl<IBZUSERMapper, IBZUSER> impl ...@@ -65,12 +65,6 @@ public class IBZUSERServiceImpl extends ServiceImpl<IBZUSERMapper, IBZUSER> impl
return authuserdetail; return authuserdetail;
} }
@Override
public AuthenticationUser loadUserByLogin(String domain, String username, String password) {
if(!StringUtils.isEmpty(domain))
username = username+"|"+domain;
return loadUserByLogin(username,password);
}
public void resetByUsername(String username) { public void resetByUsername(String username) {
......
...@@ -27,12 +27,6 @@ import org.springframework.beans.factory.annotation.Value; ...@@ -27,12 +27,6 @@ import org.springframework.beans.factory.annotation.Value;
@Service("SimpleUserService") @Service("SimpleUserService")
public class SimpleUserService implements AuthenticationUserService{ public class SimpleUserService implements AuthenticationUserService{
@Value("${r'${ibiz.enablePermissionValid:false}'}")
boolean enablePermissionValid; //是否开启权限校验
@Value("${r'$'}{ibiz.systemid:${sid}}")
private String systemid;
@Override @Override
public AuthenticationUser loadUserByUsername(String username) { public AuthenticationUser loadUserByUsername(String username) {
AuthenticationUser user = new AuthenticationUser(); AuthenticationUser user = new AuthenticationUser();
...@@ -41,17 +35,12 @@ public class SimpleUserService implements AuthenticationUserService{ ...@@ -41,17 +35,12 @@ public class SimpleUserService implements AuthenticationUserService{
String domains=""; String domains="";
String password=""; String password="";
if(data.length==3) { if(data.length==2) {
loginname=data[0].trim(); loginname=data[0].trim();
domains=data[1].trim(); domains=data[1].trim();
password=data[2].trim();
}
else if(data.length==2) {
loginname=data[0].trim();
password=data[1].trim();
} }
user.setUserid(DigestUtils.md5DigestAsHex(username.getBytes())); user.setUserid(username);
user.setUsercode(loginname); user.setUsercode(loginname);
user.setUsername(username); user.setUsername(username);
user.setLoginname(loginname); user.setLoginname(loginname);
...@@ -67,17 +56,11 @@ public class SimpleUserService implements AuthenticationUserService{ ...@@ -67,17 +56,11 @@ public class SimpleUserService implements AuthenticationUserService{
@Override @Override
public AuthenticationUser loadUserByLogin(String username, String password) { public AuthenticationUser loadUserByLogin(String username, String password) {
password = DigestUtils.md5DigestAsHex(String.format("%1$s||%2$s", username, password).getBytes()); AuthenticationUser authuserdetail = loadUserByUsername(username);
AuthenticationUser authuserdetail = loadUserByUsername(username+"|"+password);
return authuserdetail; return authuserdetail;
} }
@Override
public AuthenticationUser loadUserByLogin(String domain, String username, String password) {
if(!StringUtils.isEmpty(domain))
username = username+"|"+domain;
return loadUserByLogin(username,password);
}
@Override @Override
public void resetByUsername(String username) { public void resetByUsername(String username) {
......
Markdown 格式
0% or
您添加了 0 到此讨论。请谨慎行事。
先完成此消息的编辑!
想要评论请 注册