当前位置: 首页>>代码示例>>Java>>正文


Java ByteChunk.getStart方法代码示例

本文整理汇总了Java中org.apache.tomcat.util.buf.ByteChunk.getStart方法的典型用法代码示例。如果您正苦于以下问题:Java ByteChunk.getStart方法的具体用法?Java ByteChunk.getStart怎么用?Java ByteChunk.getStart使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在org.apache.tomcat.util.buf.ByteChunk的用法示例。


在下文中一共展示了ByteChunk.getStart方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: convertMB

import org.apache.tomcat.util.buf.ByteChunk; //导入方法依赖的package包/类
/**
 * Character conversion of the a US-ASCII MessageBytes.
 */
protected void convertMB(MessageBytes mb) {

    // This is of course only meaningful for bytes
    if (mb.getType() != MessageBytes.T_BYTES) {
        return;
    }

    ByteChunk bc = mb.getByteChunk();
    CharChunk cc = mb.getCharChunk();
    int length = bc.getLength();
    cc.allocate(length, -1);

    // Default encoding: fast conversion
    byte[] bbuf = bc.getBuffer();
    char[] cbuf = cc.getBuffer();
    int start = bc.getStart();
    for (int i = 0; i < length; i++) {
        cbuf[i] = (char) (bbuf[i + start] & 0xff);
    }
    mb.setChars(cbuf, 0, length);

}
 
开发者ID:liaokailin,项目名称:tomcat7,代码行数:26,代码来源:CoyoteAdapter.java

示例2: convertMB

import org.apache.tomcat.util.buf.ByteChunk; //导入方法依赖的package包/类
/**
 * Character conversion of the a US-ASCII MessageBytes.
 */
protected void convertMB(MessageBytes mb) {

	// This is of course only meaningful for bytes
	if (mb.getType() != MessageBytes.T_BYTES) {
		return;
	}

	ByteChunk bc = mb.getByteChunk();
	CharChunk cc = mb.getCharChunk();
	int length = bc.getLength();
	cc.allocate(length, -1);

	// Default encoding: fast conversion
	byte[] bbuf = bc.getBuffer();
	char[] cbuf = cc.getBuffer();
	int start = bc.getStart();
	for (int i = 0; i < length; i++) {
		cbuf[i] = (char) (bbuf[i + start] & 0xff);
	}
	mb.setChars(cbuf, 0, length);

}
 
开发者ID:how2j,项目名称:lazycat,代码行数:26,代码来源:CoyoteAdapter.java

示例3: doWrite

import org.apache.tomcat.util.buf.ByteChunk; //导入方法依赖的package包/类
/**
 * Write chunk.
 */
@Override
public int doWrite(ByteChunk chunk, Response res) throws IOException {
    try {
        int len = chunk.getLength();
        int start = chunk.getStart();
        byte[] b = chunk.getBuffer();
        addToBB(b, start, len);
        byteCount += chunk.getLength();
        return chunk.getLength();
    } catch (IOException ioe) {
        response.action(ActionCode.CLOSE_NOW, ioe);
        // Re-throw
        throw ioe;
    }
}
 
开发者ID:liaokailin,项目名称:tomcat7,代码行数:19,代码来源:InternalNioOutputBuffer.java

示例4: convertMB

import org.apache.tomcat.util.buf.ByteChunk; //导入方法依赖的package包/类
/**
 * Character conversion of the a US-ASCII MessageBytes.
 */
protected void convertMB(MessageBytes mb) {

    // This is of course only meaningful for bytes
    if (mb.getType() != MessageBytes.T_BYTES)
        return;
    
    ByteChunk bc = mb.getByteChunk();
    CharChunk cc = mb.getCharChunk();
    int length = bc.getLength();
    cc.allocate(length, -1);

    // Default encoding: fast conversion
    byte[] bbuf = bc.getBuffer();
    char[] cbuf = cc.getBuffer();
    int start = bc.getStart();
    for (int i = 0; i < length; i++) {
        cbuf[i] = (char) (bbuf[i + start] & 0xff);
    }
    mb.setChars(cbuf, 0, length);

}
 
开发者ID:lamsfoundation,项目名称:lams,代码行数:25,代码来源:CoyoteAdapter.java

示例5: unescapeDoubleQuotes

import org.apache.tomcat.util.buf.ByteChunk; //导入方法依赖的package包/类
/**
 * Unescapes any double quotes in the given cookie value.
 *
 * @param bc The cookie value to modify
 */
private static void unescapeDoubleQuotes(ByteChunk bc) {

    if (bc == null || bc.getLength() == 0 || bc.indexOf('"', 0) == -1) {
        return;
    }

    int src = bc.getStart();
    int end = bc.getEnd();
    int dest = src;
    byte[] buffer = bc.getBuffer();

    while (src < end) {
        if (buffer[src] == '\\' && src < end && buffer[src+1]  == '"') {
            src++;
        }
        buffer[dest] = buffer[src];
        dest ++;
        src ++;
    }
    bc.setEnd(dest);
}
 
开发者ID:sunmingshuai,项目名称:apache-tomcat-7.0.73-with-comment,代码行数:27,代码来源:Cookies.java

示例6: findBytes

import org.apache.tomcat.util.buf.ByteChunk; //导入方法依赖的package包/类
/**
 * Specialized utility method: find a sequence of lower case bytes inside
 * a ByteChunk.
 */
protected int findBytes(ByteChunk bc, byte[] 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 = start; i <= (end - srcEnd); i++) {
    if (Ascii.toLower(buff[i]) != first) continue;
    // 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++])
        break;
            if (srcPos == srcEnd) return i - start; // found it
    }
}
return -1;

}
 
开发者ID:lamsfoundation,项目名称:lams,代码行数:28,代码来源:Http11Processor.java

示例7: doWrite

import org.apache.tomcat.util.buf.ByteChunk; //导入方法依赖的package包/类
/**
 * Write chunk.
 */
@Override
public int doWrite(ByteChunk chunk, Response res) throws IOException {
	try {
		int len = chunk.getLength();
		int start = chunk.getStart();
		byte[] b = chunk.getBuffer();
		addToBB(b, start, len);
		byteCount += chunk.getLength();
		return chunk.getLength();
	} catch (IOException ioe) {
		response.action(ActionCode.CLOSE_NOW, ioe);
		// Re-throw
		throw ioe;
	}
}
 
开发者ID:how2j,项目名称:lazycat,代码行数:19,代码来源:InternalNioOutputBuffer.java

示例8: doWrite

import org.apache.tomcat.util.buf.ByteChunk; //导入方法依赖的package包/类
/**
 * Write chunk.
 */
@Override
public int doWrite(ByteChunk chunk, Response res) throws IOException {
	try {
		int len = chunk.getLength();
		int start = chunk.getStart();
		byte[] b = chunk.getBuffer();
		while (len > 0) {
			int thisTime = len;
			if (bbuf.position() == bbuf.capacity()) {
				flushBuffer();
			}
			if (thisTime > bbuf.capacity() - bbuf.position()) {
				thisTime = bbuf.capacity() - bbuf.position();
			}
			bbuf.put(b, start, thisTime);
			len = len - thisTime;
			start = start + thisTime;
		}
		byteCount += chunk.getLength();
		return chunk.getLength();
	} catch (IOException ioe) {
		response.action(ActionCode.CLOSE_NOW, ioe);
		// Re-throw
		throw ioe;
	}
}
 
开发者ID:how2j,项目名称:lazycat,代码行数:30,代码来源:InternalAprOutputBuffer.java

示例9: findBytes

import org.apache.tomcat.util.buf.ByteChunk; //导入方法依赖的package包/类
/**
 * Specialized utility method: find a sequence of lower case bytes inside a
 * ByteChunk.
 */
protected int findBytes(ByteChunk bc, byte[] 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 = start; i <= (end - srcEnd); i++) {
		if (Ascii.toLower(buff[i]) != first) {
			continue;
		}
		// 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++]) {
				break;
			}
			if (srcPos == srcEnd) {
				return i - start; // found it
			}
		}
	}
	return -1;
}
 
开发者ID:how2j,项目名称:lazycat,代码行数:32,代码来源:AbstractHttp11Processor.java

示例10: findBytes

import org.apache.tomcat.util.buf.ByteChunk; //导入方法依赖的package包/类
/**
 * Specialized utility method: find a sequence of lower case bytes inside
 * a ByteChunk.
 */
protected int findBytes(ByteChunk bc, byte[] 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 = start; i <= (end - srcEnd); i++) {
        if (Ascii.toLower(buff[i]) != first) {
            continue;
        }
        // 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++]) {
                break;
            }
            if (srcPos == srcEnd) {
                return i - start; // found it
            }
        }
    }
    return -1;
}
 
开发者ID:sunmingshuai,项目名称:apache-tomcat-7.0.73-with-comment,代码行数:32,代码来源:AbstractHttp11Processor.java

示例11: decode

import org.apache.tomcat.util.buf.ByteChunk; //导入方法依赖的package包/类
/**
 * Decodes Base64 data into octets
 *
 * @param base64DataBC
 *            Byte array containing Base64 data
 * @param decodedDataCC
 *            The decoded data chars
 */
public static void decode(ByteChunk base64DataBC, CharChunk decodedDataCC) {
	int start = base64DataBC.getStart();
	int end = base64DataBC.getEnd();
	byte[] base64Data = base64DataBC.getBuffer();

	decodedDataCC.recycle();

	// handle the edge case, so we don't have to worry about it later
	if (end - start == 0) {
		return;
	}

	int numberQuadruple = (end - start) / FOURBYTE;
	byte b1 = 0, b2 = 0, b3 = 0, b4 = 0, marker0 = 0, marker1 = 0;

	// Throw away anything not in base64Data

	int encodedIndex = 0;
	int dataIndex = start;
	char[] decodedData = null;

	{
		// this sizes the output array properly - rlw
		int lastData = end - start;
		// ignore the '=' padding
		while (base64Data[start + lastData - 1] == PAD) {
			if (--lastData == 0) {
				return;
			}
		}
		decodedDataCC.allocate(lastData - numberQuadruple, -1);
		decodedDataCC.setEnd(lastData - numberQuadruple);
		decodedData = decodedDataCC.getBuffer();
	}

	for (int i = 0; i < numberQuadruple; i++) {
		dataIndex = start + i * 4;
		marker0 = base64Data[dataIndex + 2];
		marker1 = base64Data[dataIndex + 3];

		b1 = base64Alphabet[base64Data[dataIndex]];
		b2 = base64Alphabet[base64Data[dataIndex + 1]];

		if (marker0 != PAD && marker1 != PAD) {
			// No PAD e.g 3cQl
			b3 = base64Alphabet[marker0];
			b4 = base64Alphabet[marker1];

			decodedData[encodedIndex] = (char) ((b1 << 2 | b2 >> 4) & 0xff);
			decodedData[encodedIndex + 1] = (char) ((((b2 & 0xf) << 4) | ((b3 >> 2) & 0xf)) & 0xff);
			decodedData[encodedIndex + 2] = (char) ((b3 << 6 | b4) & 0xff);
		} else if (marker0 == PAD) {
			// Two PAD e.g. 3c[Pad][Pad]
			decodedData[encodedIndex] = (char) ((b1 << 2 | b2 >> 4) & 0xff);
		} else if (marker1 == PAD) {
			// One PAD e.g. 3cQ[Pad]
			b3 = base64Alphabet[marker0];

			decodedData[encodedIndex] = (char) ((b1 << 2 | b2 >> 4) & 0xff);
			decodedData[encodedIndex + 1] = (char) ((((b2 & 0xf) << 4) | ((b3 >> 2) & 0xf)) & 0xff);
		}
		encodedIndex += 3;
	}
}
 
开发者ID:how2j,项目名称:lazycat,代码行数:73,代码来源:Base64.java

示例12: parseHost

import org.apache.tomcat.util.buf.ByteChunk; //导入方法依赖的package包/类
/**
 * Parse host.
 */
protected void parseHost(MessageBytes valueMB) {

    if (valueMB == null || valueMB.isNull()) {
        // HTTP/1.0
        // If no host header, use the port info from the endpoint
        // The host will be obtained lazily from the socket if required
        // using ActionCode#REQ_LOCAL_NAME_ATTRIBUTE
        request.setServerPort(endpoint.getPort());
        return;
    }

    ByteChunk valueBC = valueMB.getByteChunk();
    byte[] valueB = valueBC.getBytes();
    int valueL = valueBC.getLength();
    int valueS = valueBC.getStart();
    int colonPos = -1;
    if (hostNameC.length < valueL) {
        hostNameC = new char[valueL];
    }

    boolean ipv6 = (valueB[valueS] == '[');
    boolean bracketClosed = false;
    for (int i = 0; i < valueL; i++) {
        char b = (char) valueB[i + valueS];
        hostNameC[i] = b;
        if (b == ']') {
            bracketClosed = true;
        } else if (b == ':') {
            if (!ipv6 || bracketClosed) {
                colonPos = i;
                break;
            }
        }
    }

    if (colonPos < 0) {
        if (!endpoint.isSSLEnabled()) {
            // 80 - Default HTTP port
            request.setServerPort(80);
        } else {
            // 443 - Default HTTPS port
            request.setServerPort(443);
        }
        request.serverName().setChars(hostNameC, 0, valueL);
    } else {
        request.serverName().setChars(hostNameC, 0, colonPos);

        int port = 0;
        int mult = 1;
        for (int i = valueL - 1; i > colonPos; i--) {
            int charValue = HexUtils.getDec(valueB[i + valueS]);
            if (charValue == -1 || charValue > 9) {
                // Invalid character
                // 400 - Bad request
                response.setStatus(400);
                setErrorState(ErrorState.CLOSE_CLEAN, null);
                break;
            }
            port = port + (charValue * mult);
            mult = 10 * mult;
        }
        request.setServerPort(port);
    }

}
 
开发者ID:liaokailin,项目名称:tomcat7,代码行数:69,代码来源:AbstractHttp11Processor.java

示例13: parseHost

import org.apache.tomcat.util.buf.ByteChunk; //导入方法依赖的package包/类
/**
 * Parse host.
 */
protected void parseHost(MessageBytes valueMB) {

	if (valueMB == null || valueMB.isNull()) {
		// HTTP/1.0
		// If no host header, use the port info from the endpoint
		// The host will be obtained lazily from the socket if required
		// using ActionCode#REQ_LOCAL_NAME_ATTRIBUTE
		request.setServerPort(endpoint.getPort());
		return;
	}

	ByteChunk valueBC = valueMB.getByteChunk();
	byte[] valueB = valueBC.getBytes();
	int valueL = valueBC.getLength();
	int valueS = valueBC.getStart();
	int colonPos = -1;
	if (hostNameC.length < valueL) {
		hostNameC = new char[valueL];
	}

	boolean ipv6 = (valueB[valueS] == '[');
	boolean bracketClosed = false;
	for (int i = 0; i < valueL; i++) {
		char b = (char) valueB[i + valueS];
		hostNameC[i] = b;
		if (b == ']') {
			bracketClosed = true;
		} else if (b == ':') {
			if (!ipv6 || bracketClosed) {
				colonPos = i;
				break;
			}
		}
	}

	if (colonPos < 0) {
		if (!endpoint.isSSLEnabled()) {
			// 80 - Default HTTP port
			request.setServerPort(80);
		} else {
			// 443 - Default HTTPS port
			request.setServerPort(443);
		}
		request.serverName().setChars(hostNameC, 0, valueL);
	} else {
		request.serverName().setChars(hostNameC, 0, colonPos);

		int port = 0;
		int mult = 1;
		for (int i = valueL - 1; i > colonPos; i--) {
			int charValue = HexUtils.getDec(valueB[i + valueS]);
			if (charValue == -1 || charValue > 9) {
				// Invalid character
				// 400 - Bad request
				response.setStatus(400);
				setErrorState(ErrorState.CLOSE_CLEAN, null);
				break;
			}
			port = port + (charValue * mult);
			mult = 10 * mult;
		}
		request.setServerPort(port);
	}

}
 
开发者ID:how2j,项目名称:lazycat,代码行数:69,代码来源:AbstractHttp11Processor.java

示例14: decode

import org.apache.tomcat.util.buf.ByteChunk; //导入方法依赖的package包/类
/**
 * Decodes Base64 data into octets
 *
 * @param base64DataBC Byte array containing Base64 data
 * @param decodedDataCC The decoded data chars
 */
public static void decode( ByteChunk base64DataBC, CharChunk decodedDataCC)
{
    int start = base64DataBC.getStart();
    int end = base64DataBC.getEnd();
    byte[] base64Data = base64DataBC.getBuffer();
    
    decodedDataCC.recycle();
    
    // handle the edge case, so we don't have to worry about it later
    if(end - start == 0) { return; }

    int      numberQuadruple    = (end - start)/FOURBYTE;
    byte     b1=0,b2=0,b3=0, b4=0, marker0=0, marker1=0;

    // Throw away anything not in base64Data

    int encodedIndex = 0;
    int dataIndex = start;
    char[] decodedData = null;
    
    {
        // this sizes the output array properly - rlw
        int lastData = end - start;
        // ignore the '=' padding
        while (base64Data[start+lastData-1] == PAD)
        {
            if (--lastData == 0)
            {
                return;
            }
        }
        decodedDataCC.allocate(lastData - numberQuadruple, -1);
        decodedDataCC.setEnd(lastData - numberQuadruple);
        decodedData = decodedDataCC.getBuffer();
    }

    for (int i = 0; i < numberQuadruple; i++)
    {
        dataIndex = start + i * 4;
        marker0   = base64Data[dataIndex + 2];
        marker1   = base64Data[dataIndex + 3];

        b1 = base64Alphabet[base64Data[dataIndex]];
        b2 = base64Alphabet[base64Data[dataIndex +1]];

        if (marker0 != PAD && marker1 != PAD)
        {
            //No PAD e.g 3cQl
            b3 = base64Alphabet[ marker0 ];
            b4 = base64Alphabet[ marker1 ];

            decodedData[encodedIndex]   = (char) ((  b1 <<2 | b2>>4 ) & 0xff);
            decodedData[encodedIndex + 1] =
                (char) ((((b2 & 0xf)<<4 ) |( (b3>>2) & 0xf) ) & 0xff);
            decodedData[encodedIndex + 2] = (char) (( b3<<6 | b4 ) & 0xff);
        }
        else if (marker0 == PAD)
        {
            //Two PAD e.g. 3c[Pad][Pad]
            decodedData[encodedIndex]   = (char) ((  b1 <<2 | b2>>4 ) & 0xff);
        }
        else if (marker1 == PAD)
        {
            //One PAD e.g. 3cQ[Pad]
            b3 = base64Alphabet[ marker0 ];

            decodedData[encodedIndex]   = (char) ((  b1 <<2 | b2>>4 ) & 0xff);
            decodedData[encodedIndex + 1] =
                (char) ((((b2 & 0xf)<<4 ) |( (b3>>2) & 0xf) ) & 0xff);
        }
        encodedIndex += 3;
    }
}
 
开发者ID:sunmingshuai,项目名称:apache-tomcat-7.0.73-with-comment,代码行数:80,代码来源:Base64.java

示例15: parseHost

import org.apache.tomcat.util.buf.ByteChunk; //导入方法依赖的package包/类
/**
 * Parse host.
 */
public void parseHost(MessageBytes valueMB) {

    if (valueMB == null || (valueMB != null && valueMB.isNull()) ) {
        // HTTP/1.0
        request.setServerPort(request.getLocalPort());
        try {
            request.serverName().duplicate(request.localName());
        } catch (IOException e) {
            response.setStatus(400);
            error = true;
        }
        return;
    }

    ByteChunk valueBC = valueMB.getByteChunk();
    byte[] valueB = valueBC.getBytes();
    int valueL = valueBC.getLength();
    int valueS = valueBC.getStart();
    int colonPos = -1;
    if (hostNameC.length < valueL) {
        hostNameC = new char[valueL];
    }

    boolean ipv6 = (valueB[valueS] == '[');
    boolean bracketClosed = false;
    for (int i = 0; i < valueL; i++) {
        char b = (char) valueB[i + valueS];
        hostNameC[i] = b;
        if (b == ']') {
            bracketClosed = true;
        } else if (b == ':') {
            if (!ipv6 || bracketClosed) {
                colonPos = i;
                break;
            }
        }
    }

    if (colonPos < 0) {
        if (request.scheme().equalsIgnoreCase("https")) {
            // 443 - Default HTTPS port
            request.setServerPort(443);
        } else {
            // 80 - Default HTTTP port
            request.setServerPort(80);
        }
        request.serverName().setChars(hostNameC, 0, valueL);
    } else {

        request.serverName().setChars(hostNameC, 0, colonPos);

        int port = 0;
        int mult = 1;
        for (int i = valueL - 1; i > colonPos; i--) {
            int charValue = HexUtils.DEC[(int) valueB[i + valueS]];
            if (charValue == -1) {
                // Invalid character
                error = true;
                // 400 - Bad request
                response.setStatus(400);
                break;
            }
            port = port + (charValue * mult);
            mult = 10 * mult;
        }
        request.setServerPort(port);

    }

}
 
开发者ID:lamsfoundation,项目名称:lams,代码行数:74,代码来源:AjpAprProcessor.java


注:本文中的org.apache.tomcat.util.buf.ByteChunk.getStart方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。