📄 cmsstaticexportmanager.java
字号:
/*
* File : $Source: /usr/local/cvs/opencms/src/org/opencms/staticexport/CmsStaticExportManager.java,v $
* Date : $Date: 2006/07/19 12:38:16 $
* Version: $Revision: 1.122 $
*
* This library is part of OpenCms -
* the Open Source Content Mananagement System
*
* Copyright (c) 2005 Alkacon Software GmbH (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 GmbH, 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 org.opencms.staticexport;
import org.opencms.file.CmsFile;
import org.opencms.file.CmsObject;
import org.opencms.file.CmsProperty;
import org.opencms.file.CmsPropertyDefinition;
import org.opencms.file.CmsResource;
import org.opencms.file.CmsVfsResourceNotFoundException;
import org.opencms.file.types.CmsResourceTypeJsp;
import org.opencms.i18n.CmsAcceptLanguageHeaderParser;
import org.opencms.i18n.CmsI18nInfo;
import org.opencms.i18n.CmsLocaleManager;
import org.opencms.loader.I_CmsResourceLoader;
import org.opencms.main.CmsContextInfo;
import org.opencms.main.CmsEvent;
import org.opencms.main.CmsException;
import org.opencms.main.CmsIllegalArgumentException;
import org.opencms.main.CmsLog;
import org.opencms.main.I_CmsEventListener;
import org.opencms.main.OpenCms;
import org.opencms.report.CmsLogReport;
import org.opencms.report.I_CmsReport;
import org.opencms.security.CmsSecurityException;
import org.opencms.site.CmsSiteManager;
import org.opencms.util.CmsFileUtil;
import org.opencms.util.CmsMacroResolver;
import org.opencms.util.CmsRequestUtil;
import org.opencms.util.CmsStringUtil;
import org.opencms.util.CmsUUID;
import org.opencms.workplace.CmsWorkplace;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.collections.map.LRUMap;
import org.apache.commons.logging.Log;
/**
* Provides the functionaility to export resources from the OpenCms VFS
* to the file system.<p>
*
* @author Alexander Kandzior
* @author Michael Moossen
*
* @version $Revision: 1.122 $
*
* @since 6.0.0
*/
public class CmsStaticExportManager implements I_CmsEventListener {
/** Marker for error message attribute. */
public static final String EXPORT_ATTRIBUTE_ERROR_MESSAGE = "javax.servlet.error.message";
/** Marker for error request uri attribute. */
public static final String EXPORT_ATTRIBUTE_ERROR_REQUEST_URI = "javax.servlet.error.request_uri";
/** Marker for error servlet name attribute. */
public static final String EXPORT_ATTRIBUTE_ERROR_SERVLET_NAME = "javax.servlet.error.servlet_name";
/** Marker for error status code attribute. */
public static final String EXPORT_ATTRIBUTE_ERROR_STATUS_CODE = "javax.servlet.error.status_code";
/** Name for the folder default index file. */
public static final String EXPORT_DEFAULT_FILE = "index_export.html";
/** Flag value for links without paramerters. */
public static final int EXPORT_LINK_WITH_PARAMETER = 2;
/** Flag value for links without paramerters. */
public static final int EXPORT_LINK_WITHOUT_PARAMETER = 1;
/** Marker for externally redirected 404 uri's. */
public static final String EXPORT_MARKER = "exporturi";
/** Time given (in seconds) to the static export handler to finish a publish task. */
public static final int HANDLER_FINISH_TIME = 60;
/** Cache value to indicate a true 404 error. */
private static final String CACHEVALUE_404 = "?404";
/** The log object for this class. */
private static final Log LOG = CmsLog.getLog(CmsStaticExportManager.class);
/** Matcher for selecting those resources which should be part of the staic export. */
private static CmsExportFolderMatcher m_exportFolderMatcher;
/** HTTP header Accept-Charset. */
private String m_acceptCharsetHeader;
/** HTTP header Accept-Language. */
private String m_acceptLanguageHeader;
/** Cache for the export links. */
private Map m_cacheExportLinks;
/** Cache for the export uris. */
private Map m_cacheExportUris;
/** Cache for the online links. */
private Map m_cacheOnlineLinks;
/** Cache for the secure links. */
private Map m_cacheSecureLinks;
/** OpenCms default charset header. */
private String m_defaultAcceptCharsetHeader;
/** OpenCms default locale header. */
private String m_defaultAcceptLanguageHeader;
/** List of export resources which should be part of the static export. */
private List m_exportFolders;
/** The additional http headers for the static export. */
private List m_exportHeaders;
/** List of all resources that have the "exportname" property set. */
private Map m_exportnameResources;
/** Indicates if <code>true</code> is the default value for the property "export". */
private boolean m_exportPropertyDefault;
/** Indicates if links in the static export should be relative. */
private boolean m_exportRelativeLinks;
/** List of export rules. */
private List m_exportRules;
/** List of export suffixes where the "export" property default is always <code>"true"</code>. */
private List m_exportSuffixes;
/** Temporary variable for reading the xml config file. */
private CmsStaticExportExportRule m_exportTmpRule;
/** Export url to send internal requests to. */
private String m_exportUrl;
/** Export url with unstubstituted context values. */
private String m_exportUrlConfigured;
/** Export url to send internal requests to without http://servername. */
private String m_exportUrlPrefix;
/** Handler class for static export. */
private I_CmsStaticExportHandler m_handler;
/** Lock object for write access to the {@link #cmsEvent(CmsEvent)} method. */
private Object m_lockCmsEvent;
/** Lock object for export folder deletion in {@link #scrubExportFolders(I_CmsReport)}. */
private Object m_lockScrubExportFolders;
/** Lock object for write access to the {@link #m_exportnameResources} map in {@link #setExportnames()}. */
private Object m_lockSetExportnames;
/** Indicates if the quick static export for plain resources is enabled. */
private boolean m_quickPlainExport;
/** Remote addr. */
private String m_remoteAddr;
/** Prefix to use for exported files. */
private String m_rfsPrefix;
/** Prefix to use for exported files with unstubstituted context values. */
private String m_rfsPrefixConfigured;
/** List of configured rfs rules. */
private List m_rfsRules;
/** Temporary variable for reading the xml config file. */
private CmsStaticExportRfsRule m_rfsTmpRule;
/** Indicates if the static export is enabled or diabled. */
private boolean m_staticExportEnabled;
/** The path to where the static export will be written. */
private String m_staticExportPath;
/** The path to where the static export will be written without the complete rfs path. */
private String m_staticExportPathConfigured;
/** Vfs Name of a resource used to do a "static export required" test. */
private String m_testResource;
/** Prefix to use for internal OpenCms files. */
private String m_vfsPrefix;
/** Prefix to use for internal OpenCms files with unstubstituted context values. */
private String m_vfsPrefixConfigured;
/**
* Creates a new static export property object.<p>
*
*/
public CmsStaticExportManager() {
m_lockCmsEvent = new Object();
m_lockScrubExportFolders = new Object();
m_lockSetExportnames = new Object();
m_exportSuffixes = new ArrayList();
m_exportFolders = new ArrayList();
m_exportHeaders = new ArrayList();
m_rfsRules = new ArrayList();
m_exportRules = new ArrayList();
m_exportTmpRule = new CmsStaticExportExportRule("", "");
m_rfsTmpRule = new CmsStaticExportRfsRule("", "", "", "", "", null);
}
/**
* Adds a new export rule to the configuration.<p>
*
* @param name the name of the rule
* @param description the description for the rule
*/
public void addExportRule(String name, String description) {
m_exportRules.add(new CmsStaticExportExportRule(
name,
description,
m_exportTmpRule.getModifiedResources(),
m_exportTmpRule.getExportResourcePatterns()));
m_exportTmpRule = new CmsStaticExportExportRule("", "");
}
/**
* Adds a regex to the latest export rule.<p>
*
* @param regex the regex to add
*/
public void addExportRuleRegex(String regex) {
m_exportTmpRule.addModifiedResource(regex);
}
/**
* Adds a export uri to the latest export rule.<p>
*
* @param exportUri the export uri to add
*/
public void addExportRuleUri(String exportUri) {
m_exportTmpRule.addExportResourcePattern(exportUri);
}
/**
* Adds a new rfs rule to the configuration.<p>
*
* @param name the name of the rule
* @param description the description for the rule
* @param source the source regex
* @param rfsPrefix the url prefix
* @param exportPath the rfs export path
* @param useRelativeLinks the relative links value
*/
public void addRfsRule(
String name,
String description,
String source,
String rfsPrefix,
String exportPath,
String useRelativeLinks) {
Boolean relativeLinks = (useRelativeLinks == null ? null : Boolean.valueOf(useRelativeLinks));
m_rfsRules.add(new CmsStaticExportRfsRule(
name,
description,
source,
rfsPrefix,
exportPath,
relativeLinks,
m_rfsTmpRule.getRelatedSystemResources()));
m_rfsTmpRule = new CmsStaticExportRfsRule("", "", "", "", "", null);
}
/**
* Adds a regex of related system resources to the latest rfs-rule.<p>
*
* @param regex the regex to add
*/
public void addRfsRuleSystemRes(String regex) {
m_rfsTmpRule.addRelatedSystemRes(regex);
}
/**
* Caches a calculated export uri.<p>
*
* @param rfsName the name of the resource in the "real" file system
* @param vfsName the name of the resource in the VFS
* @param parameters the optional parameters for the generation of the resource
*/
public void cacheExportUri(String rfsName, String vfsName, String parameters) {
m_cacheExportUris.put(rfsName, new CmsStaticExportData(vfsName, parameters));
}
/**
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -