Spring MVC 4.1 No. 022 CSVファイルのダウンロード1
今回はCSVダウンロードです。ダウンロードにはいくつか方法があるのですが、今回はSpringにあまり依存しない方法を紹介します。
具体的なソースは以下のなります。csvInitでアンカーの書かれた画面を開き、csvDownが実際のダウンロードになります。ダウンロードの際には戻り値はvoidとして、HttpServletResponse#getWirter()メソッドでダウンロードするデータを書き出します。
package com.example.spring.controller.c022; import java.io.IOException; import java.io.PrintWriter; import javax.servlet.http.HttpServletResponse; import org.springframework.stereotype.Controller; import org.springframework.util.MimeTypeUtils; import org.springframework.web.bind.annotation.RequestMapping; @Controller public class C022Controller { @RequestMapping("/c022/csvInit") public String csvInit() { return "c022/csvInit"; } @RequestMapping("/c022/csvDown") public void csvDown(HttpServletResponse response) { response.setContentType(MimeTypeUtils.APPLICATION_OCTET_STREAM_VALUE + ";charset=utf-8"); response.setHeader("Content-Disposition", "attachment; filename=\"test.csv\""); try (PrintWriter pw = response.getWriter()) { pw.print("山田 太郎,33\r\n"); pw.print("田中 花子,29\r\n"); } catch (IOException e) { e.printStackTrace(); } } }
アンカーを表示する画面です。単純なアンカーのみです。
<%@page contentType="text/html; charset=utf-8" %><%-- --%><!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>サンプル</title> </head> <body> <a href="csvDown">csvDown</a> </body> </html>
確認用のテストケースは次のとおりです。
package com.example.spring.controller.c022; import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.*; import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.*; import static org.springframework.test.web.servlet.setup.MockMvcBuilders.*; import org.junit.Before; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; import org.springframework.test.context.web.WebAppConfiguration; import org.springframework.test.web.servlet.MockMvc; import org.springframework.web.context.WebApplicationContext; @RunWith(SpringJUnit4ClassRunner.class) @WebAppConfiguration @ContextConfiguration(locations = { "file:src/main/webapp/WEB-INF/spring/spring-context.xml" }) public class C022ControllerTest { @Autowired private WebApplicationContext wac; private MockMvc mockMvc; @Before public void setup() { mockMvc = webAppContextSetup(wac).build(); } @Test public void csvInitのGET() throws Exception { mockMvc.perform(get("/c022/csvInit")).andExpect(status().isOk()) .andExpect(view().name("c022/csvInit")); } @Test public void csvDownのGET() throws Exception { StringBuilder sb = new StringBuilder(); sb.append("山田 太郎,33\r\n"); sb.append("田中 花子,29\r\n"); mockMvc.perform(get("/c022/csvDown")) .andExpect(status().isOk()) .andExpect( content().contentType( "application/octet-stream;charset=utf-8")) .andExpect(content().string(sb.toString())); } }
ソースは https://github.com/kuwalab/spring-mvc41 にあります。タグ022が今回のサンプルです。
まとめ http://kuwalab.hatenablog.jp/entry/spring
最初 http://kuwalab.hatenablog.jp/entry/spring_mvc41/001
前回 http://kuwalab.hatenablog.jp/entry/spring_mvc41/021
次回 http://kuwalab.hatenablog.jp/entry/spring_mvc41/023