昨日は写真をアップロードしてリンクを返す機能を実装していました。プロジェクトが Tomcat に再デプロイされると、以前にアップロードされた画像やその他のリソースの一部が自動的に削除されました。 理由は、画像をターゲット ディレクトリに保存したためです。その下に置くだけで、Web リンクを通じて簡単に画像を取得できるためです。 ただし、プロジェクトが再デプロイされると、ターゲットが再構築され、ターゲット内のリソースは削除されます。 最終的に、同じイメージを 2 つのパスに保存する方法を考えました。1 つのパスはターゲットの下にあり、もう 1 つのパスは開発したプロジェクトの下にあります。このようにすると、再デプロイすると、自分のプロジェクト内のファイルがターゲット ファイルを上書きし、ターゲットに再ロードされます。 以下は私の実装コードです // ローカル IDEA プロジェクト内のパスへ String localDirString = "E:/zideapro/onlineschool/src/main/webapp/upload/images"; //Tomcat サーバーにデプロイされたプロジェクト パス String root_String = request.getSession().getServletContext().getRealPath("/upload/images"); ファイル localDirPath = new File(localDirString); ファイル root_Path = new File(root_String); // ローカル IDEA にディレクトリが存在しない場合は、作成する必要があります if (!localDirPath.exists()) { ローカルディレクトリパス。 } // サーバーTomcatにディレクトリが存在しない場合は作成します。if (!root_Path.exists()) { root_Path.mkdirs(); } //ローカル ファイル パスFile localFilePath = new File(localDirPath + File.separator + attachment.getOriginalFilename());//ファイル ディレクトリ + ファイル名//サーバー内のファイルのパスFile root_FilePath = new File(root_Path + File.separator + attachment.getOriginalFilename());//プロジェクト デプロイメント ディレクトリ + ファイル名//イメージをローカルに保存attach.transferTo(localFilePath); // ローカル パスから Tomcat サーバーにファイルをコピーします // 再デプロイメント中にイメージ リソースが失われないようにします Files.copy(localFilePath.toPath(), root_FilePath.toPath()); System.out.println("editormd は画像をローカル ストレージ パスにアップロードします: " + localFilePath); System.out.println("editormd はイメージをデプロイメント プロジェクト パスにアップロードします: " + root_FilePath); 出力セクション: editormd がローカルに保存するために写真をアップロードするパスは次のとおりです: E:\zideapro\onlineschool\src\main\webapp\upload\images\timg2.jpg editormd がデプロイメント プロジェクトにイメージをアップロードするパス: E:\zideapro\onlineschool\target\ssm\upload\images\timg2.jpg このように、画像リソースは 2 つのパスにアップロードされます。プロジェクトを再デプロイすると、失われたファイルがローカル ファイルで上書きされるため、画像などのリソースが失われることはありません。 Tomcat の再デプロイ後に画像やその他のリソースが自動的に削除される問題を解決する方法についての記事はこれで終わりです。Tomcat の再デプロイとリソースが自動的に削除される詳細については、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: HTML フォームを送信するいくつかの方法_PowerNode Java Academy
>>: Vue は Websocket カスタマー サービス チャット機能を実装します
この記事では、画像切り替え機能を実装するためのVue.jsの具体的なコードを参考までに共有します。具...
目次現象:ポートの使用:ファイルにスペルミスがあります:現象: Tomcat がインストールされ、W...
方法1: npm経由でプラグインをインストールする1. npm install vue-print-...
この記事は、IDEA で Web プロジェクトを作成し、Tomcat を構成する方法についての統合記...
1. mysqlbinlog: [エラー] 不明な変数 'default-character...
Js での 2 次元配列の作成:まず、JavaScript は 1 次元配列のみをサポートしています...
目次序文電話使用法成し遂げるシンプルな実装バージョン:アップグレード版:適用する使用法成し遂げるバイ...
Code Cloud を使用して Git コード ストレージ ウェアハウスを構築するhttps://...
矢印関数は ES6 の新機能です。独自の this はありません。その this ポイントは外部のコ...
問題の説明: mysqladmin.exe を使用してコマンドを実行すると、次のエラー メッセージが...
1. インラインスタイル仮想DOMにインラインスタイルを追加するには、式を使用してスタイルオブジェク...
目次序文文章1. JavaScriptコードの実行プロセスに関連する概念2. 実行コンテキストと実行...
1. Concat関数。よく使用される接続文字列: concat 関数。たとえば、SQLクエリ条件...
冒頭にこう書かれています:アブソリュートは言った。「親戚よ、私はあなたを私の人生で見たくない!」なぜ...
解凍したフォルダ C:\web\mysql-8.0.11 を開き、フォルダ内に my.ini 構成フ...