昨日は写真をアップロードしてリンクを返す機能を実装していました。プロジェクトが 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 カスタマー サービス チャット機能を実装します
1. 分離マーカーを追加します。 ip netns add fd 2. 指定されたネットワーク カ...
MySQL は、膨大なユーザーベースを持つ無料のリレーショナル データベースです。この記事では、My...
よく使われる4つのMySQLエンジンの紹介(1):MyISAMストレージエンジン:トランザクションや...
1. 仮想マシンバージョン15.5.1をダウンロードする公式サイトから直接最新バージョンをダウンロー...
コンピューターに Linux Ubuntu システムをインストールしました。初めてインストールしまし...
<br />Web テーブル フレームを作成するためのヒント。 ------------...
アナコンダのインストールAnaconda は、Python の使用を容易にするために作成されたソフト...
序文最近、小さなプログラムでリアルタイムにチャートを更新するという要件に遭遇しました。最初は wx-...
序文1. この記事で使用したツールは、https://github.com/gianlucabore...
すりガラス効果がうまく表現されていれば、ページが非常に鮮やかで立体的に見えるようになります。写真に直...
ktl ツールを使用して、mysql から mysql にデータを同期します。 1. 新しいジョブス...
setinterval を使用すると、ページを開いた直後に 1 秒の遅延後に実行されることがわかりま...
MySQL データベースでは、テーブルが互いに関連付けられた後は、それらを任意に削除することはできま...
1. タイプの導入1.1 ドメインベースの仮想ホスティングいわゆるドメイン名ベースの仮想ホストとは、...
目次簡単な紹介1. 現在のgccバージョンを確認する2. gccインストールパッケージ(バージョン1...