Java代碼讀取文件緩存問(wèn)題解決
最近遇到了一個(gè)Java文件讀取的緩存問(wèn)題,打遠(yuǎn)程斷點(diǎn)出現(xiàn)的也是原來(lái)的老代碼參數(shù),好在晚上十點(diǎn)突然找到了解決方案,豁然開(kāi)朗,現(xiàn)整理分享思路,希望對(duì)遇到同樣文件讀取緩存問(wèn)題的你有幫助
我更新幾次插件包后,服務(wù)器也緩存也清理了
我本地用postman調(diào)用測(cè)試,下載的文件是新文件,但是上線(xiàn)后發(fā)現(xiàn)下載下來(lái)的文件是老文件
下載下來(lái)的文件還是原來(lái)的文件,文件大小28.5K,我動(dòng)態(tài)寫(xiě)入部分?jǐn)?shù)據(jù),按道理下載下來(lái)的文件大小應(yīng)該比這個(gè)大
業(yè)務(wù)場(chǎng)景: 我現(xiàn)在需要獲取一個(gè)Java項(xiàng)目resource目錄下的Excel文件,然后往此Excel文件的第二個(gè)sheet頁(yè)動(dòng)態(tài)插入部分?jǐn)?shù)據(jù)
實(shí)踐情況:我在如何獲取此文件的相對(duì)路徑情況下花費(fèi)了很多的時(shí)間,原來(lái)定義了一個(gè)參數(shù)String path和String realpath打完包驗(yàn)證發(fā)現(xiàn)線(xiàn)下是好的,服務(wù)器不行,我將對(duì)應(yīng)代碼移除
更新后的方法:我使用新的方法動(dòng)態(tài)獲取當(dāng)前文件,將此文件轉(zhuǎn)換為流傳入對(duì)應(yīng)的對(duì)象;
問(wèn)題: 本地測(cè)試可以動(dòng)態(tài)的導(dǎo)出Excel文件,但是代碼上線(xiàn),下載下來(lái)的模板是老項(xiàng)目,遠(yuǎn)程斷點(diǎn)出現(xiàn)原來(lái)老的定義的參數(shù)
來(lái)看看我遠(yuǎn)程斷點(diǎn)的相關(guān)情況
我是讀取一個(gè)文件轉(zhuǎn)行成文件流然后放入指定的Workbook中(即讀取一個(gè)已有Excel文件)
在這個(gè)讀取的過(guò)程中我發(fā)現(xiàn)了如下這些屬性:path,upload
還有realpath以及返回為空的wb
這些屬性我是我上午測(cè)試的時(shí)候定義的,但是此時(shí)已經(jīng)不使用拼接路徑的方式去構(gòu)建workbook文件了,是將流放入workbook對(duì)象中構(gòu)建文件
原來(lái)的解決思路: 我本地沒(méi)問(wèn)題,我就覺(jué)得是緩存的原因:1、清理卸載插件重新安裝2、清理瀏覽器緩存,清理Tomcat緩存,重啟Tomcat3、都試過(guò)后還不行就重啟reboot服務(wù)器
但是不管我怎么操作,服務(wù)器依然走老代碼,下載下來(lái)老的模板
二、解決方案如何解決問(wèn)題?
自己創(chuàng)建一個(gè)新的文件夾,將自己的文件xlsx文件放入其中,讀取文件路徑的地方更新成讀取新的文件路徑
如原來(lái)是
InputStream inputstream = this.getClass().getClassLoader().getResourceAsStream('hello/Test.xlsx');
現(xiàn)在創(chuàng)建一個(gè)新的文件夾,放入原文件如 word/Test.xlsx ,然后讀取新的路徑
InputStream inputstream = this.getClass().getClassLoader().getResourceAsStream('word/Test.xlsx');
打包再上線(xiàn)測(cè)試
反思:具體問(wèn)題原因肯定是打包的時(shí)候文件被緩存到哪里了,沒(méi)清理干凈,更新一下新路徑,走新的讀取方式問(wèn)題就解決了
總結(jié):創(chuàng)建新的路徑,走新的讀取方式
三、文件讀取項(xiàng)目之前是靜態(tài)下載模板的即前端靜態(tài)的下載
window.location.href = url
此業(yè)務(wù)是先讀取,再下載,如何讀取自己Java項(xiàng)目中對(duì)應(yīng)相對(duì)位置的文件呢 ?
InputStream inputstream = this.getClass().getClassLoader().getResourceAsStream('hello/Test.xlsx');
來(lái)我們驗(yàn)證一下我們是否讀取了
如果換一個(gè)不存在的路徑或者文件名,效果如下
如上即我們成功讀取到了此文件
自測(cè)代碼如下
public class TestPath { InputStream getFileStream(){InputStream inputstream = this.getClass().getClassLoader().getResourceAsStream('helloWord/Test.xlsx');return inputstream; } public static void main(String[] args) {TestPath stream = new TestPath();System.out.println( stream.getFileStream()); }}
接下來(lái)也會(huì)整理一下Java讀取文件以及導(dǎo)入導(dǎo)出Excel表格相關(guān)問(wèn)題,歡迎同步溝通學(xué)習(xí)交流!
到此這篇關(guān)于Java代碼讀取文件緩存問(wèn)題解決的文章就介紹到這了,更多相關(guān)Java 讀取文件緩存內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. ThinkPHP6使用JWT+中間件實(shí)現(xiàn)Token驗(yàn)證實(shí)例詳解2. 不使用XMLHttpRequest對(duì)象實(shí)現(xiàn)Ajax效果的方法小結(jié)3. ASP.NET MVC限制同一個(gè)IP地址單位時(shí)間間隔內(nèi)的請(qǐng)求次數(shù)4. JSP出現(xiàn)中文亂碼問(wèn)題解決方法詳解5. ASP基礎(chǔ)入門(mén)第二篇(ASP基礎(chǔ)知識(shí))6. jsp實(shí)現(xiàn)簡(jiǎn)單用戶(hù)7天內(nèi)免登錄7. vue的路由動(dòng)畫(huà)切換頁(yè)面無(wú)法讀取meta值的bug記錄8. 怎樣打開(kāi)XML文件?xml文件如何打開(kāi)?9. PHP中為什么使用file_get_contents("php://input")接收微信通知10. ASP.NET MVC實(shí)現(xiàn)登錄后跳轉(zhuǎn)到原界面
