CustomOauthExceptionSerializer.java 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. package com.ruoyi.auth.exception;
  2. import java.io.IOException;
  3. import org.slf4j.Logger;
  4. import org.slf4j.LoggerFactory;
  5. import com.fasterxml.jackson.core.JsonGenerator;
  6. import com.fasterxml.jackson.databind.SerializerProvider;
  7. import com.fasterxml.jackson.databind.ser.std.StdSerializer;
  8. import com.ruoyi.common.core.constant.HttpStatus;
  9. import com.ruoyi.common.core.utils.StringUtils;
  10. import com.ruoyi.common.core.web.domain.AjaxResult;
  11. /**
  12. * 自定义异常返回
  13. *
  14. * @author ruoyi
  15. **/
  16. public class CustomOauthExceptionSerializer extends StdSerializer<CustomOauthException>
  17. {
  18. private static final long serialVersionUID = 1L;
  19. private static final Logger log = LoggerFactory.getLogger(CustomOauthExceptionSerializer.class);
  20. public static final String BAD_CREDENTIALS = "Bad credentials";
  21. public CustomOauthExceptionSerializer()
  22. {
  23. super(CustomOauthException.class);
  24. }
  25. @Override
  26. public void serialize(CustomOauthException e, JsonGenerator jsonGenerator, SerializerProvider serializerProvider)
  27. throws IOException
  28. {
  29. jsonGenerator.writeStartObject();
  30. jsonGenerator.writeNumberField(AjaxResult.CODE_TAG, HttpStatus.ERROR);
  31. if (StringUtils.equals(e.getMessage(), BAD_CREDENTIALS))
  32. {
  33. jsonGenerator.writeStringField(AjaxResult.MSG_TAG, "用户名或密码错误");
  34. }
  35. else
  36. {
  37. log.warn("oauth2 认证异常 {} ", e);
  38. jsonGenerator.writeStringField(AjaxResult.MSG_TAG, e.getMessage());
  39. }
  40. jsonGenerator.writeEndObject();
  41. }
  42. }