QException是项目业务异常基类 按模块划分子类异常,方便定位那块出错

有个来源码属性code作用定位某个功能处理出错逻辑,数字类型节省内存空间,同时减少创建子类的子类

QSocketException 是通信层出错 凡是来自QSocketException 统一认为非法请求,强制关闭socket连接

QJsonException 是json编解码出错 json很流行种数据格式,跨平台特点,经常处理

QEnhanceException 是Javassist动态生成java class技术,用于替换jdk 动态代理

 public class QException extends RuntimeException {

     private static final long serialVersionUID = -3110633035340065406L;

     private short code;

     public short getCode() {
return code;
} public QException(short code, String message, Throwable cause) {
super(message, cause);
this.code = code;
} public QException(short code) {
super();
this.code = code;
} public QException(short code, String message) {
super(message);
this.code = code;
} }

QException

接下来应用异常

首先要找到所有业务调用的主入口,由于用的是netty通信框架,对于服务端来讲要找到接收数据的方法

ChannelDuplexHandler 是netty提供的业务实现的类,其中channelRead是接收数据的方法

 @Sharable
public class QMessageHandler extends ChannelDuplexHandler { private QDispenseHandler dispenseHandler; public QMessageHandler(QDispenseHandler dispenseHandler) {
this.dispenseHandler = dispenseHandler;
} @Override
public void channelActive(ChannelHandlerContext ctx) throws Exception {
dispenseHandler.doConnect(ctx);
super.channelActive(ctx);
} @Override
public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {
dispenseHandler.doReceive(msg, ctx);
super.channelRead(ctx, msg);
} @Override
public void channelInactive(ChannelHandlerContext ctx) throws Exception {
dispenseHandler.doClose(ctx);
super.channelInactive(ctx);
}
}

QDispenseHandler.class

当业务处理失败时,响应三种策略

1.优先处理来自QSocketException强制关闭socket连接

2.业务边界QException

3.未知错误Exception

第一种情况不用返回响应码

第二三种情况是否返回根据客户端请求状态决定 boolean response = packet.hasStatus(QPacket.MASK_RESPONSE)

  public void doReceive(Object msg, ChannelHandlerContext ctx) {
if (msg instanceof QPacket) {
pool.execute(() -> {
doReceive0((QPacket) msg, ctx);
});
}
} private void doReceive0(QPacket packet, ChannelHandlerContext ctx) { boolean response = packet.hasStatus(QPacket.MASK_RESPONSE);
try {
//doReceive ... 处理省略细节 } catch (QSocketException e) {
// socket异常 关闭连接
packet.responseCode(e.getCode());
LOGGER.error("QSocketException msg {} error : {}", QCodeUtil.getDes( e.getCode()), e);
if (response) {
ChannelFuture future = ctx.channel().writeAndFlush(packet);
future.addListener(new GenericFutureListener<Future<? super Void>>() {
@Override
public void operationComplete(Future<? super Void> future) throws Exception {
NettyUtil.closeChannel(CLOSE_SOURCE.SOCKET_ERROR, false, ctx.channel());
}
});
} else {
NettyUtil.closeChannel(CLOSE_SOURCE.SOCKET_ERROR, false, ctx.channel());
}
return;
} catch (QException e) {
// 业务异常 响应失败
packet.responseCode(e.getCode());
LOGGER.error("QException msg {} error : {}",QCodeUtil.getDes( e.getCode()), e);
} catch (Exception e) {
// 未知异常 响应失败
packet.responseCode(QCode.ERROR_UNKNOWN);
LOGGER.error("UNKNOWNException error : {}", e);
}
if (response) {
ctx.channel().writeAndFlush(packet);
}
}

[编织消息框架][JAVA核心技术]异常应用的更多相关文章

  1. [编织消息框架][JAVA核心技术]异常基础

    Java异常体系结构 Thorwable类所有异常和错误的超类,有两个子类Error和Exception,分别表示错误和异常. 其中异常类Exception又分为运行时异常(RuntimeExcept ...

  2. [编织消息框架][JAVA核心技术]动态代理应用4

    基础部份: 接下来讲编译JAVA时,生成自定义class 我们用 javax.annotation.processing.AbstractProcessor 来处理 public abstract c ...

  3. [编织消息框架][JAVA核心技术]annotation基础

    应用动态代理技术要先掌握annotation技术 注解是JDK1.5之后才有的新特性,JDK1.5之后内部提供的三个注解 @Deprecated 意思是“废弃的,过时的” @Override 意思是“ ...

  4. [编织消息框架][JAVA核心技术]动态代理应用12-总结

    动态代理这篇比较长,是框架组成的重要基础 回顾下学到的应用技术 1.异常应用 2.annotation技术 3.数值与逻辑分享 4.jdk.cglib.javassist等动态代理技术 5.懒处理.预 ...

  5. [编织消息框架][JAVA核心技术]数值与逻辑分离

    为什么要分离? 业务需求是不停地变,如果把条件写进代码里,当用户需求变时要改代码发版本更新才能生效,这过程无疑是漫长的 就算是在开发期,不停的变开发者精力耗光在沟通,小修改上,无法专注逻辑部分 分离的 ...

  6. [编织消息框架][JAVA核心技术]动态代理应用4-annotationProcessor

    基础部份: 接下来讲编译JAVA时,生成自定义class 我们用 javax.annotation.processing.AbstractProcessor 来处理 public abstract c ...

  7. [编织消息框架][JAVA核心技术]jdk动态代理

    需要用到的工具  jdk : javac javap class 反编译 :JD-GUI http://jd.benow.ca/ import java.lang.reflect.Invocation ...

  8. [编织消息框架][JAVA核心技术]动态代理应用2

    接下来如何实现 第一步:先把服务类,调用方法转换成数字,方便传输 第二步:提取元信息,提取又有三种方式,三种各有优点,最优方式是第一种 1.编译java时处理 2.程序启动时处理,预处理 3.调用时处 ...

  9. [编织消息框架][JAVA核心技术]动态代理应用5-javassist

    基础部份: 修改class我们用到javassist,在pom.xml添加 <properties> <javassist.version>3.18.2-GA</java ...

随机推荐

  1. c专家编程摘录

    C专家编程摘录 c操作符的优先级 有时一些c操作符有时并不会像你想象的那样工作. 下方表格将说明这个问题: 优先级问题 表达式 期望的情况 实际情况 . 优先级高于* *p.f (*p).f *(p. ...

  2. Java学习之计算机基础(二)

    今天主要介绍原码.反码与补码的知识.了解原码.反码与补码的知识,可以帮助我们更好地理解在计算机内部是如何进行运算的,同时对于后面更好地学习和理解Java基本数据类型及其范围打下基础. 背景知识: 在计 ...

  3. C# 在RichTextBox中滚动鼠标时滚动的是父窗口的滚动条

    1. RichTextBox u2 = new RichTextBox(); 2. 先记住日RichTextBox没有显示滚动条时的总宽度和显示宽度 u2.Width - u2.ClientSize. ...

  4. 给dalao们递dalao们的博客

    hqh使用0 1敲完AC代码 FNXF FNXF tfx .io结尾的都是dalao! ssttkkl 复读:.io结尾的都是dalao! ThetaS Pirote YanQuijote 昵称不能为 ...

  5. WPF水珠效果按钮组

    效果图 相关知识 这部分基本就是废话,网上都能找到,我只不过是整理了以下.建议先不看,用到的时候可以回来看看 贝塞尔曲线 先来看两组图,有助于理解什么是贝塞尔曲线(图片取自维基百科,参考链接1) 二次 ...

  6. Jarvis OJ - [XMAN]level3 - Writeup——ret2libc尝试

    这次除了elf程序还附带一个动态链接库 先看一下,很一般的保护 思路分析 在ida中查看,可以确定通过read函数输入buf进行溢出,但是并没有看到合适的目标函数 但是用ida打开附带的链接库,可以看 ...

  7. 【Java入门提高篇】Day9 Java内部类——静态内部类

    今天来说说Java中的最后一种内部类--静态内部类 所谓的静态内部类,自然就是用static修饰的内部类,那用static修饰过后的内部类,跟一般的内部类相比有什么特别的地方呢? 首先,它是静态的,这 ...

  8. 在CentOS上为Docker开启SELinux

    a { color: #4183C4; text-decoration: none } a:hover { text-decoration: underline } ul,ol { padding-l ...

  9. 程序员的自我救赎---3.2:SSO及应用案例

    <前言> (一) Winner2.0 框架基础分析 (二)PLSQL报表系统 (三)SSO单点登录 (四) 短信中心与消息中心 (五)钱包系统 (六)GPU支付中心 (七)权限系统 (八) ...

  10. 更便捷的css处理方式-postcss

    更便捷的css处理方式-PostCSS 一般来说介绍一个东西都是要从是什么,怎么用的顺序来讲.我感觉这样很容易让大家失去兴趣,先看一下postcss能做点什么,有兴趣的话再往下看,否则可能没有耐心看下 ...