基于netty的字节流传输文件

  1. 解决业务场景
    在微服务横行的当下,A服务与B服务之间进行数据传输在所难免。本次解决问题
    a.AB两个服务之间传输文件
    b.在传输完进行数据完整性判断
    c.基于当前连接通道传输报文(携带文件地址,以及其他业务必要参数),通知B服务对文件进行业务操作

  2. RandomAccessFile简单介绍
    RandomAccessFile是用来访问那些保存数据记录的文件的,你就可以用seek( )方法来访问记录,并进行读写了。这些记录的大小不必相同;但是其大小和位置必须是可知的。但是该类仅限于操作文件。

    RandomAccessFile不属于InputStream和OutputStream类系的。实际上,除了实现DataInput和DataOutput接口之外(DataInputStream和DataOutputStream也实现了这两个接口),它和这两个类系毫不相干,甚至不使用InputStream和OutputStream类中已经存在的任何功能;它是一个完全独立的类,所有方法(绝大多数都只属于它自己)都是从零开始写的。这可能是因为RandomAccessFile能在文件里面前后移动,所以它的行为与其它的I/O类有些根本性的不同。总而言之,它是一个直接继承Object的,独立的类。

    基本上,RandomAccessFile的工作方式是,把DataInputStream和DataOutputStream结合起来,再加上它自己的一些方法,比如定位用的getFilePointer( ),在文件里移动用的seek( ),以及判断文件大小的length( )、skipBytes()跳过多少字节数。此外,它的构造函数还要一个表示以只读方式(“r”),还是以读写方式(“rw”)打开文件的参数 (和C的fopen( )一模一样)。它不支持只写文件。
    只有RandomAccessFile才有seek搜寻方法,而这个方法也只适用于文件。

  3. 客户端主要代码

public class FileUploadClientHandler extends ChannelInboundHandlerAdapter {
   private int byteRead;
   private volatile int start = 0;
   private volatile int lastLength = 0;
   public RandomAccessFile randomAccessFile;
   private FileUploadFile fileUploadFile;//FileUploadFile对象中包含 :文件,文件名,开始位置,文件字节数组,结尾位置
   private final static Logger LOGGER = LoggerFactory.getLogger(FileUploadClientHandler.class);
   public FileUploadClientHandler(FileUploadFile ef) {
       if (ef.getFile().exists()) {
           if (!ef.getFile().isFile()) {
               System.out.println("Not a file :" + ef.getFile());
               return;
           }
       }
       this.fileUploadFile = ef;
   }

   @Override
   public vo
  • 0
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值