自定义oauth2返回异常信息
parent
1c06db8999
commit
6ee4efa284
|
@ -0,0 +1,20 @@
|
||||||
|
package com.ruoyi.auth.exception;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import org.springframework.security.oauth2.common.exceptions.OAuth2Exception;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* oauth2自定义异常
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
**/
|
||||||
|
@JsonSerialize(using = CustomOauthExceptionSerializer.class)
|
||||||
|
public class CustomOauthException extends OAuth2Exception
|
||||||
|
{
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
public CustomOauthException(String msg)
|
||||||
|
{
|
||||||
|
super(msg);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,48 @@
|
||||||
|
package com.ruoyi.auth.exception;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import com.ruoyi.common.core.constant.HttpStatus;
|
||||||
|
import com.ruoyi.common.core.utils.StringUtils;
|
||||||
|
import com.ruoyi.common.core.web.domain.AjaxResult;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 自定义异常返回
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
**/
|
||||||
|
public class CustomOauthExceptionSerializer extends StdSerializer<CustomOauthException>
|
||||||
|
{
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
private static final Logger log = LoggerFactory.getLogger(CustomOauthExceptionSerializer.class);
|
||||||
|
|
||||||
|
public static final String BAD_CREDENTIALS = "Bad credentials";
|
||||||
|
|
||||||
|
public CustomOauthExceptionSerializer()
|
||||||
|
{
|
||||||
|
super(CustomOauthException.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(CustomOauthException e, JsonGenerator jsonGenerator, SerializerProvider serializerProvider)
|
||||||
|
throws IOException
|
||||||
|
{
|
||||||
|
jsonGenerator.writeStartObject();
|
||||||
|
jsonGenerator.writeNumberField(AjaxResult.CODE_TAG, HttpStatus.ERROR);
|
||||||
|
if (StringUtils.equals(e.getMessage(), BAD_CREDENTIALS))
|
||||||
|
{
|
||||||
|
jsonGenerator.writeStringField(AjaxResult.MSG_TAG, "用户名或密码错误");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
log.warn("oauth2 认证异常 {} ", e);
|
||||||
|
jsonGenerator.writeStringField(AjaxResult.MSG_TAG, e.getMessage());
|
||||||
|
}
|
||||||
|
jsonGenerator.writeEndObject();
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,6 +1,6 @@
|
||||||
package com.ruoyi.auth.exception;
|
package com.ruoyi.auth.exception;
|
||||||
|
|
||||||
import javax.servlet.http.HttpServletResponse;
|
import org.springframework.http.HttpStatus;
|
||||||
import org.springframework.http.ResponseEntity;
|
import org.springframework.http.ResponseEntity;
|
||||||
import org.springframework.security.oauth2.common.exceptions.OAuth2Exception;
|
import org.springframework.security.oauth2.common.exceptions.OAuth2Exception;
|
||||||
import org.springframework.security.oauth2.provider.error.WebResponseExceptionTranslator;
|
import org.springframework.security.oauth2.provider.error.WebResponseExceptionTranslator;
|
||||||
|
@ -15,7 +15,6 @@ public class CustomWebResponseExceptionTranslator implements WebResponseExceptio
|
||||||
@Override
|
@Override
|
||||||
public ResponseEntity<OAuth2Exception> translate(Exception e)
|
public ResponseEntity<OAuth2Exception> translate(Exception e)
|
||||||
{
|
{
|
||||||
OAuth2Exception oAuth2Exception = (OAuth2Exception) e;
|
return ResponseEntity.status(HttpStatus.OK).body(new CustomOauthException(e.getMessage()));
|
||||||
return ResponseEntity.status(HttpServletResponse.SC_UNAUTHORIZED).body(oAuth2Exception);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -102,6 +102,10 @@ public class SysUserController extends BaseController
|
||||||
public R<UserInfo> info(@PathVariable("username") String username)
|
public R<UserInfo> info(@PathVariable("username") String username)
|
||||||
{
|
{
|
||||||
SysUser sysUser = userService.selectUserByUserName(username);
|
SysUser sysUser = userService.selectUserByUserName(username);
|
||||||
|
if (StringUtils.isNull(sysUser))
|
||||||
|
{
|
||||||
|
return R.failed("用户名或密码错误");
|
||||||
|
}
|
||||||
// 角色集合
|
// 角色集合
|
||||||
Set<String> roles = permissionService.getRolePermission(sysUser.getUserId());
|
Set<String> roles = permissionService.getRolePermission(sysUser.getUserId());
|
||||||
// 权限集合
|
// 权限集合
|
||||||
|
|
Loading…
Reference in New Issue