Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
   * Copyright (c) 1997-2010 Oracle and/or its affiliates. All rights reserved.
   * The contents of this file are subject to the terms of either the GNU
   * General Public License Version 2 only ("GPL") or the Common Development
   * and Distribution License("CDDL") (collectively, the "License").  You
   * may not use this file except in compliance with the License.  You can
  * obtain a copy of the License at
  * or packager/legal/LICENSE.txt.  See the License for the specific
  * language governing permissions and limitations under the License.
  * When distributing the software, include this License Header Notice in each
  * file and include the License file at packager/legal/LICENSE.txt.
  * GPL Classpath Exception:
  * Oracle designates this particular file as subject to the "Classpath"
  * exception as provided by Oracle in the GPL Version 2 section of the License
  * file that accompanied this code.
  * Modifications:
  * If applicable, add the following below the License Header, with the fields
  * enclosed by brackets [] replaced by your own identifying information:
  * "Portions Copyright [year] [name of copyright owner]"
  * Contributor(s):
  * If you wish your version of this file to be governed by only the CDDL or
  * only the GPL Version 2, indicate your decision by adding "[Contributor]
  * elects to include this software in this distribution under the [CDDL or GPL
  * Version 2] license."  If you don't indicate a single choice of license, a
  * recipient has the option to distribute your version of this file under
  * either the CDDL, the GPL Version 2 or to extend the choice of license to
  * its licensees as provided above.  However, if you add GPL Version 2 code
  * and therefore, elected the GPL Version 2 license, then the option applies
  * only if the new code is made subject to such option by the copyright
  * holder.
 package com.sun.enterprise.web.connector.grizzly.standalone;
This Handler is invoked after the request line has been parsed.

Jeanfrancois Arcand
 public class StaticHandler implements Handler<Request> {
The SocketChannel used to send a static resources.
     private SocketChannel socketChannel;
The FileCache mechanism used to cache static resources.
     protected FileCache fileCache;     
     // ----------------------------------------------------- Constructor ----//
     public StaticHandler(){
Attach a SocketChannel to this object.
     public void attachChannel(SocketChannel socketChannel){
         this. = socketChannel;
         if (  == null && socketChannel != null){
              = FileCacheFactory.getFactory(
Intercept the request and decide if we cache the static resource. If the static resource is already cached, return it.
     public int handle(Request reqint handlerCodethrows IOException{
         if ( == nullreturn .;
        if (handlerCode == . && .isEnabled()){
            String docroot = SelectorThread.getWebAppRootPath();
            MessageBytes mb = req.requestURI();
            ByteChunk requestURI = mb.getByteChunk();
            String uri = req.requestURI().toString();                
        } else if (handlerCode == .) {
            ByteChunk requestURI = req.requestURI().getByteChunk(); 
            if (.sendCache(requestURI.getBytes(), requestURI.getStart(),
                                requestURI.getLength(), ,
                return .;   
        return .;
Get the keep-alive header.
    private boolean keepAlive(Request request){
        MimeHeaders headers = request.getMimeHeaders();
        // Check connection header
        MessageBytes connectionValueMB = headers.getValue("connection");
        if (connectionValueMB != null) {
            ByteChunk connectionValueBC = connectionValueMB.getByteChunk();
            if (findBytes(connectionValueBC.) != -1) {
                return false;
            } else if (findBytes(connectionValueBC
                                 .) != -1) {
                return true;
        return true;
Specialized utility method: find a sequence of lower case bytes inside a ByteChunk.
    protected int findBytes(ByteChunk bcbyte[] b) {
        byte first = b[0];
        byte[] buff = bc.getBuffer();
        int start = bc.getStart();
        int end = bc.getEnd();
        // Look for first char 
        int srcEnd = b.length;
        for (int i = starti <= (end - srcEnd); i++) {
            if (Ascii.toLower(buff[i]) != firstcontinue;
            // found first char, now look for a match
            int myPos = i+1;
            for (int srcPos = 1; srcPos < srcEnd; ) {
                    if (Ascii.toLower(buff[myPos++]) != b[srcPos++])
                    if (srcPos == srcEndreturn i - start// found it
        return -1;
New to GrepCode? Check out our FAQ X