cmsdefaultlinksubstitutionhandler.java
来自「找了很久才找到到源代码」· Java 代码 · 共 402 行 · 第 1/2 页
JAVA
402 行
/*
* File : $Source: /usr/local/cvs/opencms/src/org/opencms/staticexport/CmsDefaultLinkSubstitutionHandler.java,v $
* Date : $Date: 2007-09-11 13:44:23 $
* Version: $Revision: 1.4 $
*
* This library is part of OpenCms -
* the Open Source Content Management System
*
* Copyright (C) 2002 - 2005 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 org.opencms.staticexport;
import org.opencms.file.CmsObject;
import org.opencms.file.types.CmsResourceTypeImage;
import org.opencms.main.CmsException;
import org.opencms.main.CmsLog;
import org.opencms.main.OpenCms;
import org.opencms.site.CmsSite;
import org.opencms.site.CmsSiteMatcher;
import org.opencms.util.CmsStringUtil;
import org.opencms.workplace.CmsWorkplace;
import java.net.URI;
import org.apache.commons.logging.Log;
/**
* Default link substitution behavior.<p>
*
* @author Alexander Kandzior
*
* @version $Revision: 1.4 $
*
* @since 7.0.2
*
* @see CmsLinkManager#substituteLink(org.opencms.file.CmsObject, String, String, boolean)
* for the method where this handler is used.
*/
public class CmsDefaultLinkSubstitutionHandler implements I_CmsLinkSubstitutionHandler {
/** The log object for this class. */
private static final Log LOG = CmsLog.getLog(CmsDefaultLinkSubstitutionHandler.class);
/**
* Returns the resource root path in the OpenCms VFS for the given link, or <code>null</code> in
* case the link points to an external site.<p>
*
* If the target URI contains no site information, but starts with the opencms context, the context is removed:<pre>
* /opencms/opencms/system/further_path -> /system/further_path</pre>
*
* If the target URI contains no site information, the path will be prefixed with the current site
* from the provided OpenCms user context:<pre>
* /folder/page.html -> /sites/mysite/folder/page.html</pre>
*
* If the path of the target URI is relative, i.e. does not start with "/",
* the path will be prefixed with the current site and the given relative path,
* then normalized.
* If no relative path is given, <code>null</code> is returned.
* If the normalized path is outsite a site, null is returned.<pre>
* page.html -> /sites/mysite/page.html
* ../page.html -> /sites/mysite/page.html
* ../../page.html -> null</pre>
*
* If the target URI contains a scheme/server name that denotes an opencms site,
* it is replaced by the appropriate site path:<pre>
* http://www.mysite.de/folder/page.html -> /sites/mysite/folder/page.html</pre><p>
*
* If the target URI contains a scheme/server name that does not match with any site,
* or if the URI is opaque or invalid,
* <code>null</code> is returned:<pre>
* http://www.elsewhere.com/page.html -> null
* mailto:someone@elsewhere.com -> null</pre>
*
* @see org.opencms.staticexport.I_CmsLinkSubstitutionHandler#getLink(org.opencms.file.CmsObject, java.lang.String, java.lang.String, boolean)
*/
public String getLink(CmsObject cms, String link, String siteRoot, boolean forceSecure) {
if (CmsStringUtil.isEmpty(link)) {
// not a valid link parameter, return an empty String
return "";
}
// make sure we have an absolute link
String absoluteLink = CmsLinkManager.getAbsoluteUri(link, cms.getRequestContext().getUri());
String vfsName;
String parameters;
int pos = absoluteLink.indexOf('?');
// check if the link has parameters, if so cut them
if (pos >= 0) {
vfsName = absoluteLink.substring(0, pos);
parameters = absoluteLink.substring(pos);
} else {
vfsName = absoluteLink;
parameters = null;
}
String resultLink = null;
String uriBaseName = null;
boolean useRelativeLinks = false;
// determine the target site of the link
CmsSite currentSite = OpenCms.getSiteManager().getCurrentSite(cms);
CmsSite targetSite = null;
if (CmsStringUtil.isNotEmpty(siteRoot)) {
targetSite = OpenCms.getSiteManager().getSiteForSiteRoot(siteRoot);
}
if (targetSite == null) {
targetSite = currentSite;
}
String serverPrefix;
// if the link points to another site, there needs to be a server prefix
if (targetSite != currentSite) {
serverPrefix = targetSite.getUrl();
} else {
serverPrefix = "";
}
// in the online project, check static export and secure settings
if (cms.getRequestContext().currentProject().isOnlineProject()) {
// first check if this link needs static export
CmsStaticExportManager exportManager = OpenCms.getStaticExportManager();
// check if we need relative links in the exported pages
if (exportManager.relativeLinksInExport(cms.getRequestContext().getSiteRoot()
+ cms.getRequestContext().getUri())) {
// try to get base URI from cache
uriBaseName = exportManager.getCachedOnlineLink(exportManager.getCacheKey(
cms.getRequestContext().getSiteRoot(),
cms.getRequestContext().getUri()));
if (uriBaseName == null) {
// base not cached, check if we must export it
if (exportManager.isExportLink(cms, cms.getRequestContext().getUri())) {
// base URI must also be exported
uriBaseName = exportManager.getRfsName(cms, cms.getRequestContext().getUri());
} else {
// base URI dosn't need to be exported
uriBaseName = exportManager.getVfsPrefix() + cms.getRequestContext().getUri();
}
// cache export base URI
exportManager.cacheOnlineLink(exportManager.getCacheKey(
cms.getRequestContext().getSiteRoot(),
cms.getRequestContext().getUri()), uriBaseName);
}
// use relative links only on pages that get exported
useRelativeLinks = uriBaseName.startsWith(OpenCms.getStaticExportManager().getRfsPrefix(
cms.getRequestContext().getSiteRoot() + cms.getRequestContext().getUri()));
}
// check if we have the absolute VFS name for the link target cached
resultLink = exportManager.getCachedOnlineLink(cms.getRequestContext().getSiteRoot() + ":" + absoluteLink);
if (resultLink == null) {
String storedSiteRoot = cms.getRequestContext().getSiteRoot();
try {
cms.getRequestContext().setSiteRoot(targetSite.getSiteRoot());
// didn't find the link in the cache
if (exportManager.isExportLink(cms, vfsName)) {
// export required, get export name for target link
resultLink = exportManager.getRfsName(cms, vfsName, parameters);
// now set the parameters to null, we do not need them anymore
parameters = null;
} else {
// no export required for the target link
resultLink = exportManager.getVfsPrefix().concat(vfsName);
// add cut off parameters if required
if (parameters != null) {
resultLink = resultLink.concat(parameters);
}
}
} finally {
cms.getRequestContext().setSiteRoot(storedSiteRoot);
}
// cache the result
exportManager.cacheOnlineLink(cms.getRequestContext().getSiteRoot() + ":" + absoluteLink, resultLink);
}
// now check for the secure settings
// check if either the current site or the target site does have a secure server configured
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?