解决:Springboot视频接口报大量的ClientAbortException找不到原因

浏览器有自己的缓冲策略,比如视频接口吐出了100MB的视频数据,浏览器可不会全部拿走,而是按需去拿,

举个例子,浏览器拿的视频数据够看半分钟的,就停止读取数据了,但是http连接并未断开,因为这半分钟看完还要再去读取数据。

springboot视频接口向响应流写入100MB数据,并不是直接写入了http响应体中返回,而是写入了一个缓冲区,缓冲区再一点点输出。如下就是缓冲区的那个类:

org.apache.catalina.connector.OutputBuffer

调用了里面这个方法,先检测连接没断开,然后检测缓冲区还有数据,最后响应输出数据。

解决:Springboot视频接口报大量的ClientAbortException找不到原因_第1张图片

浏览器停止接收时,springboot发现输出不了数据,主动抛出了这个异常。 

这样做可能是希望让上层应用自己拦截处理,但目前这个视频播放场景,因为有了缓冲区,所以该异常不会导致视频数据丢失,不影响视频播放,不需要关注这个异常,因此建立全局的异常拦截器屏蔽就好了。


@RestControllerAdvice
@Slf4j
public class GlobalExceptionHandler {

    @ExceptionHandler(ClientAbortException.class)
    public void handleClientAbortException(ClientAbortException e){}

}

你可能感兴趣的:(Java,spring,boot,音视频)