亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? abstractexcelview.java

?? spring framework 2.5.4源代碼
?? JAVA
字號:
/*
 * Copyright 2002-2008 the original author or authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.springframework.web.servlet.view.document;

import java.util.Locale;
import java.util.Map;

import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;

import org.springframework.core.io.Resource;
import org.springframework.core.io.support.LocalizedResourceHelper;
import org.springframework.web.servlet.support.RequestContextUtils;
import org.springframework.web.servlet.view.AbstractView;

/**
 * Convenient superclass for Excel document views.
 *
 * <p>Properties:
 * <ul>
 * <li>url (optional): The url of an existing Excel document to pick as a starting point.
 * It is done without localization part nor the ".xls" extension.
 * </ul>
 *
 * <p>The file will be searched with locations in the following order:
 * <ul>
 * <li>[url]_[language]_[country].xls
 * <li>[url]_[language].xls
 * <li>[url].xls
 * </ul>
 *
 * <p>For working with the workbook in the subclass, see
 * <a href="http://jakarta.apache.org/poi/index.html">Jakarta's POI site</a>
 *
 * <p>As an example, you can try this snippet:
 *
 * <pre>
 * protected void buildExcelDocument(
 *     Map model, HSSFWorkbook workbook,
 *     HttpServletRequest request, HttpServletResponse response) {
 *
 *   // Go to the first sheet.
 *   // getSheetAt: only if workbook is created from an existing document
 * 	 // HSSFSheet sheet = workbook.getSheetAt(0);
 * 	 HSSFSheet sheet = workbook.createSheet("Spring");
 * 	 sheet.setDefaultColumnWidth(12);
 *
 *   // Write a text at A1.
 *   HSSFCell cell = getCell(sheet, 0, 0);
 *   setText(cell, "Spring POI test");
 *
 *   // Write the current date at A2.
 *   HSSFCellStyle dateStyle = workbook.createCellStyle();
 *   dateStyle.setDataFormat(HSSFDataFormat.getBuiltinFormat("m/d/yy"));
 *   cell = getCell(sheet, 1, 0);
 *   cell.setCellValue(new Date());
 *   cell.setCellStyle(dateStyle);
 *
 *   // Write a number at A3
 *   getCell(sheet, 2, 0).setCellValue(458);
 *
 *   // Write a range of numbers.
 *   HSSFRow sheetRow = sheet.createRow(3);
 *   for (short i = 0; i < 10; i++) {
 *     sheetRow.createCell(i).setCellValue(i * 10);
 *   }
 * }</pre>
 *
 * This class is similar to the AbstractPdfView class in usage style.
 *
 * @author Jean-Pierre Pawlak
 * @author Juergen Hoeller
 * @see AbstractPdfView
 */
public abstract class AbstractExcelView extends AbstractView {

	/** The content type for an Excel response */
	private static final String CONTENT_TYPE = "application/vnd.ms-excel";

	/** The extension to look for existing templates */
	private static final String EXTENSION = ".xls";


	private String url;


	/**
	 * Default Constructor.
	 * Sets the content type of the view to "application/vnd.ms-excel".
	 */
	public AbstractExcelView() {
		setContentType(CONTENT_TYPE);
	}

	/**
	 * Set the URL of the Excel workbook source, without localization part nor extension.
	 */
	public void setUrl(String url) {
		this.url = url;
	}


	protected boolean generatesDownloadContent() {
		return true;
	}

	/**
	 * Renders the Excel view, given the specified model.
	 */
	protected final void renderMergedOutputModel(
			Map model, HttpServletRequest request, HttpServletResponse response) throws Exception {

		HSSFWorkbook workbook;
		if (this.url != null) {
			workbook = getTemplateSource(this.url, request);
		}
		else {
			workbook = new HSSFWorkbook();
			logger.debug("Created Excel Workbook from scratch");
		}

		buildExcelDocument(model, workbook, request, response);

		// Set the content type.
		response.setContentType(getContentType());

		// Should we set the content length here?
		// response.setContentLength(workbook.getBytes().length);

		// Flush byte array to servlet output stream.
		ServletOutputStream out = response.getOutputStream();
		workbook.write(out);
		out.flush();
	}

	/**
	 * Creates the workbook from an existing XLS document.
	 * @param url the URL of the Excel template without localization part nor extension
	 * @param request current HTTP request
	 * @return the HSSFWorkbook
	 * @throws Exception in case of failure
	 */
	protected HSSFWorkbook getTemplateSource(String url, HttpServletRequest request) throws Exception {
		LocalizedResourceHelper helper = new LocalizedResourceHelper(getApplicationContext());
		Locale userLocale = RequestContextUtils.getLocale(request);
		Resource inputFile = helper.findLocalizedResource(url, EXTENSION, userLocale);

		// Create the Excel document from the source.
		if (logger.isDebugEnabled()) {
			logger.debug("Loading Excel workbook from " + inputFile);
		}
		POIFSFileSystem fs = new POIFSFileSystem(inputFile.getInputStream());
		return new HSSFWorkbook(fs);
	}

	/**
	 * Subclasses must implement this method to create an Excel HSSFWorkbook document,
	 * given the model.
	 * @param model the model Map
	 * @param workbook the Excel workbook to complete
	 * @param request in case we need locale etc. Shouldn't look at attributes.
	 * @param response in case we need to set cookies. Shouldn't write to it.
	 */
	protected abstract void buildExcelDocument(
			Map model, HSSFWorkbook workbook, HttpServletRequest request, HttpServletResponse response)
			throws Exception;


	/**
	 * Convenient method to obtain the cell in the given sheet, row and column.
	 * <p>Creates the row and the cell if they still doesn't already exist.
	 * Thus, the column can be passed as an int, the method making the needed downcasts.
	 * @param sheet a sheet object. The first sheet is usually obtained by workbook.getSheetAt(0)
	 * @param row thr row number
	 * @param col the column number
	 * @return the HSSFCell
	 */
	protected HSSFCell getCell(HSSFSheet sheet, int row, int col) {
		HSSFRow sheetRow = sheet.getRow(row);
		if (sheetRow == null) {
			sheetRow = sheet.createRow(row);
		}
		HSSFCell cell = sheetRow.getCell((short) col);
		if (cell == null) {
			cell = sheetRow.createCell((short) col);
		}
		return cell;
	}

	/**
	 * Convenient method to set a String as text content in a cell.
	 * @param cell the cell in which the text must be put
	 * @param text the text to put in the cell
	 */
	protected void setText(HSSFCell cell, String text) {
		cell.setCellType(HSSFCell.CELL_TYPE_STRING);
		cell.setCellValue(text);
	}

}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
蜜桃av噜噜一区| 97久久精品人人做人人爽| 亚洲国产精品激情在线观看| 欧美亚洲动漫另类| 国产精品综合二区| 亚洲成人黄色小说| 中文字幕电影一区| 日韩精品一区在线观看| 色综合色狠狠综合色| 国产成人在线视频网址| 日本不卡在线视频| 一区二区三区在线免费观看| 国产色一区二区| 91精品国产色综合久久不卡电影 | 亚洲一区二区三区精品在线| 国产欧美日韩综合| 精品久久国产字幕高潮| 欧美日韩国产综合视频在线观看| 99久久精品国产导航| 国产综合色视频| 日本成人中文字幕在线视频| 亚洲午夜久久久久久久久久久| 国产精品久久网站| 国产视频不卡一区| 久久久久久久久久久黄色| 日韩三级.com| 欧美一三区三区四区免费在线看 | 日韩一区二区三区三四区视频在线观看 | 日日夜夜精品视频免费| 亚洲欧洲综合另类| 最新久久zyz资源站| 国产精品美女久久福利网站| 国产亚洲精品7777| 国产日产亚洲精品系列| 欧美精品一区二区三区在线播放| 欧美一区二区福利在线| 欧美一区二区久久久| 欧美福利视频一区| 这里只有精品电影| 欧美一区二区大片| 欧美一个色资源| 欧美不卡一区二区三区| 欧美成人免费网站| 2021久久国产精品不只是精品| 精品国产99国产精品| 欧美精品一区二区精品网| 欧美videos中文字幕| 久久亚洲精品小早川怜子| 国产丝袜欧美中文另类| 国产精品不卡一区| 亚洲精品免费一二三区| 亚洲五码中文字幕| 午夜成人在线视频| 美女视频黄久久| 国产精品亚洲成人| 99久久精品久久久久久清纯| 色偷偷88欧美精品久久久| 欧美在线不卡视频| 欧美日韩dvd在线观看| 日韩一级精品视频在线观看| 久久先锋影音av鲁色资源| 欧美激情在线观看视频免费| 亚洲欧美偷拍三级| 午夜精品福利视频网站| 久久电影网站中文字幕| 国产成人av影院| 91麻豆免费视频| 欧美一区二区三区免费观看视频| 久久综合色8888| 亚洲欧美另类图片小说| 日韩影视精彩在线| 国产高清不卡一区二区| 91视频com| 日韩精品一区二区三区在线| 久久久99精品免费观看不卡| 国产精品国产三级国产aⅴ原创 | 极品少妇xxxx偷拍精品少妇| 成人爱爱电影网址| 91精品欧美一区二区三区综合在| 国产欧美日本一区二区三区| 一区二区三区在线视频免费观看| 全国精品久久少妇| 99久久免费国产| 欧美成人性战久久| 亚洲另类在线制服丝袜| 美女网站视频久久| 97国产一区二区| 欧美mv日韩mv国产| 又紧又大又爽精品一区二区| 国产精一区二区三区| 欧美视频一区二区在线观看| 国产日韩欧美麻豆| 日韩**一区毛片| 94-欧美-setu| 久久亚洲精精品中文字幕早川悠里| 国产精品美女久久久久aⅴ| 青青草原综合久久大伊人精品优势| 国产精品白丝jk黑袜喷水| 91黄色激情网站| 欧美va亚洲va| 亚洲激情欧美激情| 樱花草国产18久久久久| 国产盗摄女厕一区二区三区| 欧美午夜影院一区| 久久婷婷综合激情| 亚洲午夜电影在线观看| 国产91精品在线观看| 99re这里只有精品视频首页| 久久久久久久久岛国免费| 亚洲国产综合人成综合网站| 国产麻豆精品视频| 欧美日韩五月天| 国产精品三级av在线播放| 亚洲国产精品久久人人爱蜜臀| 99精品久久只有精品| 日韩欧美国产综合在线一区二区三区| 欧美激情一区二区三区蜜桃视频| 亚洲成人av电影在线| 9l国产精品久久久久麻豆| 337p日本欧洲亚洲大胆精品 | 99久久精品免费观看| 91美女视频网站| 亚洲精品一区二区三区精华液| 午夜影院久久久| 色综合久久中文字幕| 国产视频一区在线播放| 免费高清在线视频一区·| www.亚洲国产| 国产精品狼人久久影院观看方式| 久久成人18免费观看| 欧美精品日韩精品| 一区二区三区四区高清精品免费观看| 国产激情一区二区三区四区| 欧美影院一区二区三区| 伊人色综合久久天天人手人婷| fc2成人免费人成在线观看播放| 精品国产一区二区亚洲人成毛片| 日韩高清不卡一区二区| 欧美视频在线一区| 中文欧美字幕免费| 99精品桃花视频在线观看| 国产精品久久久久影院老司| 粉嫩嫩av羞羞动漫久久久| 久久精品一区八戒影视| 久久成人精品无人区| 欧美精选在线播放| 免费观看在线色综合| 69堂国产成人免费视频| 亚洲成人综合网站| 欧美日韩电影在线| 日韩高清一区在线| 久久久久久影视| 国产成人精品在线看| 国产午夜精品理论片a级大结局 | 免费观看91视频大全| 91精品国产综合久久久久| 无吗不卡中文字幕| 制服丝袜在线91| 日本vs亚洲vs韩国一区三区二区| 欧美日韩一级大片网址| 日欧美一区二区| 日韩欧美黄色影院| 国产一区二区在线观看免费| 日韩午夜激情视频| 成人小视频在线| 亚洲乱码中文字幕综合| 91黄视频在线观看| 天堂成人国产精品一区| 欧美一区二区女人| 国产成人综合在线播放| 亚洲国产欧美在线人成| 欧美一区二区女人| 国产成人夜色高潮福利影视| 国产精品久久久久国产精品日日| 色婷婷综合中文久久一本| 青青草原综合久久大伊人精品 | 欧美调教femdomvk| 日本中文一区二区三区| 久久综合色8888| 欧美亚洲禁片免费| 免费在线看成人av| 国产午夜精品久久久久久免费视| 94色蜜桃网一区二区三区| 午夜私人影院久久久久| 精品sm捆绑视频| 不卡免费追剧大全电视剧网站| 亚洲美女一区二区三区| 欧美精品一区二区三区高清aⅴ| 成人教育av在线| 亚洲午夜私人影院| 精品sm捆绑视频| 色呦呦一区二区三区| 青青草国产成人av片免费| 国产精品人妖ts系列视频| 欧美日韩国产另类一区| 国产剧情在线观看一区二区| 亚洲色图在线看| 国产欧美视频一区二区| 欧美日韩国产在线观看| 福利一区二区在线观看|