質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Spring

Spring Framework は、Javaプラットフォーム向けのオープンソースアプリケーションフレームワークです。 Java Platform上に、 Web ベースのアプリケーションを設計するための拡張機能が数多く用意されています。

Q&A

解決済

2回答

3506閲覧

サーバー再度で生成したExcelがファイル名なしになってしまう

teramasa

総合スコア76

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Spring

Spring Framework は、Javaプラットフォーム向けのオープンソースアプリケーションフレームワークです。 Java Platform上に、 Web ベースのアプリケーションを設計するための拡張機能が数多く用意されています。

0グッド

0クリップ

投稿2016/07/26 23:15

編集2016/07/26 23:16

###前提・実現したいこと
サーバー内で出力したExcelがあり、これは正常なファイルなのですが、
クライアントからダウンロードしようとすると拡張子が無く、おかしなファイル名になってしまいます。

###発生している問題・エラーメッセージ

サーバーサイドで生成したxlsx:4847638508958207320.xlsx ダウンロード時のファイル:2(←拡張子がなくファイル名もおかしい)

###該当のソースコード

java

1//一部抜粋 2 response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"); 3 response.addHeader("Content-Disposition:","attachment;filename=\"sample.xlsx\""); 4 Files.copy(file.toPath(), response.getOutputStream());

java

1//メソッドのパラメーター 2@RequestMapping(method=RequestMethod.GET, produces = {"application/pdf", "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"}) 3@ResponseBody 4public void getData(HttpServletResponse response) throws IOException {

###試したこと
ContentTypeとproducesをapplication/vnd.ms-excelに変えてみたが変化なし

###補足情報(言語/FW/ツール等のバージョンなど)
Java8
SpringBoot
Chrome, Firefox, IE

手詰まりのためみなさまのお知恵を拝借できますと幸いです。よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

その後調べていたらこの方法でいけました!
response.setHeader("Content-Disposition", String.format(Locale.JAPAN, "attachment; filename*=utf-8'jp'%s", URLEncoder.encode(fileName, "utf-8")));

投稿2016/07/27 01:12

teramasa

総合スコア76

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

コロンいらないんじゃ?

response.addHeader("Content-Disposition","attachment;filename=\"sample.xlsx\"");

投稿2016/07/26 23:36

takasima20

総合スコア7458

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

teramasa

2016/07/27 01:10

takashima20さま ご回答ありがとうございます。Javaの場合はセミコロンがいるようです・・。
takasima20

2016/07/27 01:39

「セミコロン」じゃなくて「コロン」ですね。 で、解決したってやつにもコロンついてないスね。 (Content-Dispositionの後ろのやつ) っていうか、解決したってやつですが、日本語ファイル名 じゃないんで余計な処理だと思う。
teramasa

2016/07/27 02:18

takasima20さま すみません、attachmentの後ろと勘違いしておりました・・。なるほどContent-Dispositionの後ろにいつのまにか不要なコロンがついていました。ご指摘ありがとうございます。これが原因ですね・・
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問