All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.richfaces.webapp.ResourceServlet Maven / Gradle / Ivy

/*
 * JBoss, Home of Professional Open Source
 * Copyright 2013, Red Hat, Inc. and individual contributors
 * by the @authors tag. See the copyright.txt in the distribution for a
 * full listing of individual contributors.
 *
 * This 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 software 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.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this software; if not, write to the Free
 * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
 * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
 */
package org.richfaces.webapp;

import java.io.IOException;

import javax.faces.webapp.FacesServlet;
import javax.servlet.Servlet;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.richfaces.log.Logger;
import org.richfaces.log.RichfacesLogger;
import org.richfaces.resource.ResourceHandlerImpl;

/**
 * 

* Servlet which serves mapped resources that makes sure that resources can address relative resource links. *

* *

* ResourceServlet use prefix mapping, i.e. make sure it is not necessary to use suffixes or query parameters to address resources. *

* *

* This servlet is used together with default FacesServlet registered by application. *

* *

* For security reasons, the servlet handles just requests for JSF resources (context path starting with /javax.faces.resource/). *

*/ public class ResourceServlet implements Servlet { private static final Logger LOGGER = RichfacesLogger.RESOURCE.getLogger(); private static final String JAVAX_FACES_RESOURCE_IDENTIFIER = "/javax.faces.resource/"; public static final String RESOURCE_SERVLET_REQUEST_FLAG = ResourceServlet.class.getName(); private ServletConfig servletConfig; private FacesServlet facesServlet; /* * (non-Javadoc) * @see javax.servlet.Servlet#init(javax.servlet.ServletConfig) */ @Override public void init(ServletConfig config) throws ServletException { servletConfig = config; facesServlet = new FacesServlet(); facesServlet.init(config); } /* * (non-Javadoc) * @see javax.servlet.Servlet#getServletConfig() */ @Override public ServletConfig getServletConfig() { return servletConfig; } /* * (non-Javadoc) * @see javax.servlet.Servlet#getServletInfo() */ @Override public String getServletInfo() { return (this.getClass().getName()); } /* * (non-Javadoc) * @see javax.servlet.Servlet#destroy() */ @Override public void destroy() { facesServlet.destroy(); facesServlet = null; } /* * (non-Javadoc) * @see javax.servlet.Servlet#service(javax.servlet.ServletRequest, javax.servlet.ServletResponse) */ @Override public void service(ServletRequest request, ServletResponse response) throws ServletException, IOException { HttpServletRequest req; HttpServletResponse res; try { req = (HttpServletRequest) request; res = (HttpServletResponse) response; } catch (ClassCastException e) { throw new ServletException("non-HTTP request or response"); } httpService(req, res); } private void httpService(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { if (handleRequestByResourceServlet(request)) { request.setAttribute(RESOURCE_SERVLET_REQUEST_FLAG, Boolean.TRUE); facesServlet.service(request, response); } else { sendResourceNotFound(response); } } private boolean handleRequestByResourceServlet(HttpServletRequest request) { String resourcePath = getResourcePathFromRequest(request); if (resourcePath == null) { LOGGER.debug("ResourceServlet detected request which is not JSF resource request: " + request.getPathInfo()); return false; } // when resource path found in the request path, then we can handle the request return true; } private static String getResourcePathFromRequest(HttpServletRequest request) { String resourceName = decodeResourceURL(request); if (resourceName != null) { if (resourceName.startsWith(JAVAX_FACES_RESOURCE_IDENTIFIER)) { return resourceName.substring(JAVAX_FACES_RESOURCE_IDENTIFIER.length()); } if (resourceName.startsWith(ResourceHandlerImpl.RICHFACES_RESOURCE_IDENTIFIER)) { return resourceName; } } return null; } private static String decodeResourceURL(HttpServletRequest request) { String resourceName = null; String facesMapping = getMappingForRequest(request); if (facesMapping != null) { if (facesMapping.startsWith("/")) { // prefix mapping resourceName = request.getPathInfo(); } else { String requestServletPath = request.getServletPath(); resourceName = requestServletPath.substring(0, requestServletPath.length() - facesMapping.length()); } } return resourceName; } private static void sendResourceNotFound(HttpServletResponse response) { response.setStatus(HttpServletResponse.SC_NOT_FOUND); } private static String getMappingForRequest(HttpServletRequest request) { String servletPath = request.getServletPath(); if (servletPath == null) { return null; } if (servletPath.length() == 0) { return "/"; } String pathInfo = request.getPathInfo(); if (pathInfo != null) { return servletPath; } int idx = servletPath.lastIndexOf('.'); if (idx < 0) { return servletPath; } else { return servletPath.substring(idx); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy