`

Logger和Exception

 
阅读更多
public class PayException extends Exception {
	/**
	 * 
	 */
	private static final long serialVersionUID = 2373806520202646197L;

	/**
	 * 异常消息号
	 */
	private int msgId;

	/**
	 * 一般性错误,依赖消息
	 */
	public static final int NORMAL_ERROR = -1;

	/**
	 * 登陆账号异常
	 */
	public static final int YIXIN_ACCOUNTID_ERROR = -2;

	/**
	 * 生成签名失败
	 */
	public static final int GENERATE_SIGNATURE_FAIL = -3;

	/**
	 * 验证签名失败
	 */
	public static final int VERIFY_SIGNATURE_FAIL = -4;

	/**
	 * 商品不存在
	 */
	public static final int GOODS_NOT_EXIST = -5;

	/**
	 * 订单不存在
	 */
	public static final int TRADE_NOT_EXIST = -6;

	/**
	 * 支付方式错误
	 */
	public static final int PAYMETHOD_ERROR = -7;

	/**
	 * 参数非法
	 */
	public static final int PARAMETER_ILLEGAL = -8;

	/**
	 * 超时
	 */
	public static final int TIMEOUT_ERROR = -9;
	
	
	/**
	 * 更新PayToolType失败
	 */
	public static final int UPDATE_PAYTOOLTYPE_FAIL = -10;

	/**
	 * 第三方订单号重复
	 */
	public static final int THIRDPART_ORDERID_DUPLICATED = -31;

	/**
	 * 支付工具通知的支付状态非法
	 */
	public static final int PAYTOOL_PAY_STATUS_ERROR = -51;

	/**
	 * 数据库异常
	 */
	public static final int DDB_EXCEPTION = -101;
	
	/**
	 * 代金券状态异常
	 */
	public static final int VOUCHER_STATUS_EXCEPTION = -2001;
	
	/**
	 * 支付停用
	 */
	public static final int PAY_STOP = -1001;

	public static final Map<Integer, String> TIPS = new HashMap<Integer, String>();

	static {
		TIPS.put(NORMAL_ERROR, "支付请求失败,请重试");
		TIPS.put(YIXIN_ACCOUNTID_ERROR, "账号登录失败,请重试");
		TIPS.put(GENERATE_SIGNATURE_FAIL, "生成签名失败,请重试");
		TIPS.put(VERIFY_SIGNATURE_FAIL, "验证签名失败,请重试");
		TIPS.put(GOODS_NOT_EXIST, "商品不存在,请重试");
		TIPS.put(TRADE_NOT_EXIST, "订单不存在,请重试");
		TIPS.put(PAYMETHOD_ERROR, "支付方式错误,请重试");
		TIPS.put(PARAMETER_ILLEGAL, "参数非法");
		TIPS.put(TIMEOUT_ERROR, "支付超时,请重新支付");
		TIPS.put(THIRDPART_ORDERID_DUPLICATED, "订单重复");
		TIPS.put(PAYTOOL_PAY_STATUS_ERROR, "无效订单");
		TIPS.put(DDB_EXCEPTION, "支付数据请求失败,请重试");
		TIPS.put(UPDATE_PAYTOOLTYPE_FAIL, "更新PayToolType失败");
		TIPS.put(VOUCHER_STATUS_EXCEPTION, "您的代金券状态异常,请联系客服解决");
	}

	/**
	 * 构造函数
	 * 
	 * @param msg
	 *            消息ID
	 */
	public PayException(int msg) {
		super();
		this.msgId = msg;
	}

	/**
	 * 构造函数
	 * 
	 * @param msg
	 *            消息ID
	 * @param cause
	 *            父异常对象
	 */
	public PayException(int msg, Throwable cause) {
		super(cause);
		this.msgId = msg;
	}

	/**
	 * 构造函数
	 * 
	 * @param msg
	 *            消息ID
	 * @param content
	 *            消息内容
	 */
	public PayException(int msg, String content) {
		super(content);
		this.msgId = msg;
	}

	/**
	 * 构造函数
	 * 
	 * @param msg
	 *            消息ID
	 * @param content
	 *            消息内容
	 */
	public PayException(int msg, String content, Throwable cause) {
		super(content, cause);
		this.msgId = msg;
	}

	public int getMsgId() {
		return msgId;
	}

	public void setMsgId(int msgId) {
		this.msgId = msgId;
	}

}

 以上是自己写Exception代码,如果我们写Logger的话,我们直接

private static final Logger logger = Logger.getLogger(PayController.class);

private static final Logger payLogger = Logger.getLogger("PayLog");

 

logger.error("accessToken=" + accessToken);
payLogger.error("accessToken=" + accessToken);

 

分享到:
评论

相关推荐

    Laravel开发-laravel-exception-logger

    "Laravel开发-laravel-exception-logger"项目旨在提供一个跨Laravel应用程序的统一异常日志记录系统,使得开发者可以更有效地追踪、管理和分析应用中的错误。 1. **异常处理**: - Laravel中的异常处理机制遵循PSR...

    Python库 | Camper_Logger_Exception-0.1.3-py3-none-any.whl

    资源分类:Python库 所属语言:Python 资源全名:Camper_Logger_Exception-0.1.3-py3-none-any.whl 资源来源:官方 安装方法:https://lanzao.blog.csdn.net/article/details/101784059

    打印日志等异常处理,使用Log4j的配置

    private static final Logger logger = Logger.getLogger(Example.class); public static void main(String[] args) { // 设置日志级别 logger.setLevel(Level.ERROR); logger.debug("Debug message"); ...

    tomcat4.0源码

    Tomcat的错误处理和日志系统是通过定制的Logger和Exception Handler实现的,允许开发者自定义日志输出格式和错误处理方式。 10. **扩展性** Tomcat的插件机制使其具备良好的扩展性,可以通过编写Valve组件插入到...

    container-exception-logger-1.0.2-3.el8.aarch64.rpm

    官方离线安装包,亲测可用

    container-exception-logger-1.0.2-3.el8.x86_64.rpm

    官方离线安装包,亲测可用

    开源日志库Logger使用Demo

    开源日志库Logger提供了一种更为高效、灵活且功能丰富的日志记录解决方案,相比于Android自带的`Log`类,它具有更多的定制化选项和更好的可读性。下面我们将详细探讨Logger库的使用及其优势。 Logger库通常通过...

    logger.zip

    "logger.zip"文件很可能包含了一个或多个示例,展示了如何在C++中使用日志系统,特别是使用了"logger_-&gt;info","logger_-&gt;error"和"logger_-&gt;warn"这样的接口来记录不同级别的日志信息。这些方法通常与一个日志库相...

    log4j日志记录对于exception的记录问题

    对于Exception的记录,Log4j提供了方便的方法,如`logger.error("Message", e)`,这里`e`是Exception对象。这样不仅会打印出错误消息,还会将堆栈跟踪信息一并记录,这对于调试非常有用。 总的来说,理解和熟练使用...

    Python logging设置和logger解析

    在本文中,我们将深入理解logging模块的设置和logger解析。 首先,我们要了解logging.basicConfig()函数。这个函数用于初始化日志的基本配置,包括日志级别、输出目标和格式。level参数设定日志记录的最低阈值,...

    laravel:Laravel Logger

    Laravel Logger是Laravel框架中的一个关键组件,用于记录应用程序运行过程中的各种事件、错误和日志信息,为开发者提供了调试和问题追踪的重要工具。 在Laravel中,日志系统是通过Monolog库实现的,Monolog是一个...

    Java将Exception信息转为String字符串的方法

    Java将Exception信息转为String字符串的方法 在 Java 编程中,异常机制是一种非常有用的... Java 将 Exception 信息转换为 String 字符串的方法可以帮助我们更好地处理和记录异常信息,从而提高程序的可靠性和维护性。

    Logger.error打印错误异常的详细堆栈信息

    Logger.error可以打印出错误异常的详细堆栈信息,但是如果使用不当,可能只能打印出异常类型,无法打印出详细的堆栈信息,导致问题定位变得困难和不方便。 知识点一:Logger.error的多个重载方法 Logger.error类...

    logger GO语言的服务器日志系统

    这是一个基于GO语言的服务器日志...支持控制台不同日志不同颜色显示,DEBUG和INFO日志默认输出白色,WARN输出黄色,ERROR输出红色 4.支持捕获异常操作,并将异常信息及出错时运行堆栈保存在exception目录中,按时间存放

    Laravel开发-laravel-logger-chatwork

    在本文中,我们将深入探讨如何在Laravel框架中使用`laravel-logger-chatwork`来实现日志系统与Chatwork的集成,以便在开发过程中实时监控应用状态,并通过Chatwork发送报警通知。Laravel是一个优雅的PHP框架,而...

    Logger:Logger是一个日志记录工具,可以帮助统一发布日志和调试日志,并具有一些高级用法

    直接记录EXCEPTION / ARRAY / MAP / COLLECTION / OBJECT。 如何 记录仪易于使用。 public class SampleApplication extends Application { @Override public void onCreate () { super . onCreate(); if ( ...

    java中Exception的细节

    Exception类是Java中异常处理的核心,它位于`java.lang`包中,是所有检查型异常(checked exceptions)和非检查型异常(unchecked exceptions)的基类。本文将深入探讨Java中的Exception细节。 首先,异常分为两种...

    container-exception-logger-1.0.2-3.el8.ppc64le.rpm

    官方离线安装包,亲测可用

Global site tag (gtag.js) - Google Analytics