📄 cmsdumploader.java
字号:
/*
* File : $Source: /usr/local/cvs/opencms/src/com/opencms/flex/Attic/CmsDumpLoader.java,v $
* Date : $Date: 2003/05/13 13:18:20 $
* Version: $Revision: 1.12.2.1 $
*
* This library is part of OpenCms -
* the Open Source Content Mananagement System
*
* Copyright (C) 2002 - 2003 Alkacon Software (http://www.alkacon.com)
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* For further information about Alkacon Software, please see the
* company website: http://www.alkacon.com
*
* For further information about OpenCms, please see the
* project website: http://www.opencms.org
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
package com.opencms.flex;
import com.opencms.boot.I_CmsLogChannels;
import com.opencms.core.A_OpenCms;
import com.opencms.core.CmsException;
import com.opencms.file.CmsFile;
import com.opencms.file.CmsObject;
import com.opencms.file.CmsResource;
import com.opencms.flex.cache.CmsFlexCache;
import com.opencms.flex.cache.CmsFlexController;
import com.opencms.flex.cache.CmsFlexRequest;
import com.opencms.flex.cache.CmsFlexResponse;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
* Dump loader for binary or other unprocessed resource types.<p>
*
* This loader is used to deliver static sub-elements of pages processed
* by other loaders.
*
* @author Alexander Kandzior (a.kandzior@alkacon.com)
* @version $Revision: 1.12.2.1 $
*/
public class CmsDumpLoader extends com.opencms.launcher.CmsDumpLauncher implements I_CmsResourceLoader {
/** The CmsFlexCache used to store generated cache entries in */
private static CmsFlexCache m_cache;
/** Flag for debugging output. Set to 9 for maximum verbosity. */
private static final int DEBUG = 0;
/**
* The constructor of the class is empty and does nothing.<p>
*/
public CmsDumpLoader() {
// NOOP
}
/**
* Destroy this ResourceLoder, this is a NOOP so far.<p>
*/
public void destroy() {
// NOOP
}
/**
* Return a String describing the ResourceLoader,
* which is <code>"A simple dump loader that extends from com.opencms.launcher.CmsDumpLauncher"</code><p>
*
* @return a describing String for the ResourceLoader
*/
public String getResourceLoaderInfo() {
return "A simple dump loader that extends from com.opencms.launcher.CmsDumpLauncher";
}
/**
* Initialize the ResourceLoader,
* not much done here, only the FlexCache is initialized for dump elements.<p>
*
* @param openCms an OpenCms object to use for initalizing
*/
public void init(A_OpenCms openCms) {
m_cache = (CmsFlexCache)A_OpenCms.getRuntimeProperty(C_LOADER_CACHENAME);
if (I_CmsLogChannels.C_LOGGING && A_OpenCms.isLogging(I_CmsLogChannels.C_FLEX_LOADER))
A_OpenCms.log(I_CmsLogChannels.C_FLEX_LOADER, this.getClass().getName() + " initialized!");
}
/**
* Basic top-page processing method for this I_CmsResourceLoader,
* this method is called if the page is called as a sub-element
* on a page not already loded with a I_CmsResourceLoader,
* which most often would be a I_CmsLauncher then.<p>
*
* @param cms the initialized CmsObject which provides user permissions
* @param file the requested OpenCms VFS resource
* @param req the original servlet request
* @param res the original servlet response
*
* @throws ServletException might be thrown in the process of including the JSP
* @throws IOException might be thrown in the process of including the JSP
*
* @see I_CmsResourceLoader
* @see com.opencms.launcher.I_CmsLauncher
* @see #service(CmsObject, CmsResource, CmsFlexRequest, CmsFlexResponse)
*/
public void load(CmsObject cms, CmsFile file, HttpServletRequest req, HttpServletResponse res)
throws ServletException, IOException {
CmsFlexController controller = new CmsFlexController(cms, file, m_cache, req, res);
req.setAttribute(CmsFlexController.ATTRIBUTE_NAME, controller);
CmsFlexRequest f_req = new CmsFlexRequest(req, controller);
CmsFlexResponse f_res = new CmsFlexResponse(res, controller, false, false);
controller.pushRequest(f_req);
controller.pushResponse(f_res);
service(cms, file, f_req, f_res);
}
/**
* Does the job of dumping the contents of the requested file to the
* output stream, this method is called directly if the element is
* called as a sub-element from another I_CmsResourceLoader.<p>
*
* @param cms used to access the OpenCms VFS
* @param file the reqested JSP file resource in the VFS
* @param req the current request
* @param res the current response
*
* @throws ServletException might be thrown in the process of including the JSP
* @throws IOException might be thrown in the process of including the JSP
*
* @see com.opencms.flex.cache.CmsFlexRequestDispatcher
*/
public void service(CmsObject cms, CmsResource file, ServletRequest req, ServletResponse res)
throws ServletException, IOException {
long timer1 = 0;
if (DEBUG > 0) {
timer1 = System.currentTimeMillis();
System.err.println("========== DumpLoader loading: " + file.getAbsolutePath());
}
try {
res.getOutputStream().write(cms.readFile(file.getAbsolutePath()).getContents());
} catch (CmsException e) {
System.err.println("Error in CmsDumpLoader: " + e.toString());
if (DEBUG > 0) System.err.println(com.opencms.util.Utils.getStackTrace(e));
throw new ServletException("Error in CmsDumpLoader processing", e);
}
if (DEBUG > 0) {
long timer2 = System.currentTimeMillis() - timer1;
System.err.println("========== Time delivering dump for " + file.getAbsolutePath() + ": " + timer2 + "ms");
}
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -