记一次bug
问题描述:首次用onlyoffice打开文档是完好的,但是编辑保存之后再次打开显示上图的问题。
解决思路:最先开始是怀疑onlyoffice对文档的处理产生了问题,甚至怀疑是浏览器的编码问题。所以在onlyoffice的回调中获取流下载到本地发现文件是完好的,因为对获取到的文件流做了一个上传minio的操作,到minio中把上传的文件又下载下来看了下,发现在这一步已经是损坏文件了。onlyoffice打开文件的路径每次都是给的一个minio的下载地址。所以已经可以定位到是minio上传这一步骤出的错。最后发现是由于在往minio中上传文件时,往其中long size传的值为inputstream.available()而导致的。
putObject(String bucketName, String objectName, InputStream stream, long size, String contentType)
详细说明:这个inputstream是直接从url中获取的
URL url = new URL(fileUrl);
HttpURLConnection connection = (HttpURLConnection)url.openConnection();
InputStream inputstream= connection.getInputStream();
然后调用inputstream.available()的话,打断点进去会发现获取到的数值是小于文档本身的。这是由于available()获取流长度如果是从本地文件读取的话是能够正确的读取到整个文件长度的,但是如果是通过网络传输获取长度的话