|
What this is
Other links
The source code/* * Copyright 1999-2004 The Apache Sofware Foundation. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /* Based on Ajp11ConnectionHandler and Ajp12 implementation of JServ */ package org.apache.tomcat.modules.server; import java.io.BufferedInputStream; import java.io.IOException; import java.io.InputStream; import java.net.InetAddress; import java.net.Socket; import org.apache.tomcat.core.ContextManager; import org.apache.tomcat.core.Request; import org.apache.tomcat.util.aaa.SimplePrincipal; class Ajp12 { Socket socket; InputStream sin; BufferedInputStream ajpin; private boolean tomcatAuthentication=true; boolean shutdown=false; boolean isPing=false; boolean doLog; String secret=null; public Ajp12() { } // Debug only - use only to debug this component void d( String s ) { System.out.print("Ajp12: "); System.out.println( s ); } public int doRead() throws IOException { return ajpin.read(); } public int doRead( byte b[], int off, int len ) throws IOException { return ajpin.read( b,off,len); } public void setSocket( Socket s ) throws IOException { this.socket = s; sin = s.getInputStream(); ajpin = new BufferedInputStream(sin); } public void setSecret( String s ) { secret=s; } public void readNextRequest(Request req) throws IOException { String dummy,token1,token2; int marker; int signal; try { boolean more=true; while (more) { marker = ajpin.read(); switch (marker) { case 0: //NOP marker useful for testing if stream is OK break; case 1: //beginning of request req.method().setString( readString(ajpin, null)); //Zone String contextPath = readString(ajpin, null); // GS, the following commented line causes the Apache + // Jserv + Tomcat combination to hang with a 404!!! // if("ROOT".equals( contextPath ) ) contextPath=""; if("ROOT".equalsIgnoreCase( contextPath ) ) contextPath=null; // XXX Do not set the context - we need extra info. // this have to be rewritten !!! // if( contextPath!= null ) // req.setContext( contextM.getContext( contextPath )); //Servlet - not used dummy=readString(ajpin, null); //Server hostname req.serverName().setString(readString(ajpin, null) ); //System.out.println("XXX hostname: " + req.serverName()); //Apache document root dummy = readString(ajpin, null); req.pathInfo().setString( readString(ajpin, null)); //Apache parsed path-translated XXX Bug in mod_jserv !!!!! dummy = readString(ajpin, null); req.queryString().setString( readString(ajpin, null)); req.remoteAddr().setString(readString(ajpin, "")); req.remoteHost().setString( readString(ajpin, "")); if (isTomcatAuthentication()) dummy=readString(ajpin, null); else { req.setRemoteUser( readString(ajpin, null)); // Note that roles are not integrated with apache req.setUserPrincipal( new SimplePrincipal( req.getRemoteUser() )); } req.setAuthType(readString(ajpin, null)); //remote port dummy = readString(ajpin, null); // System.out.println("XXX rport " + dummy ); req.method().setString( readString(ajpin, null)); req.requestURI().setString( readString(ajpin, "")); // XXX don't set lookup path - problems with URL rewriting. // need to be fixed. //if(contextPath!=null && contextPath.length() >0 ) //lookupPath=requestURI.substring( contextPath.length()+1 ); //script filename dummy = readString(ajpin, null); //script name dummy = readString(ajpin, null); req.serverName().setString( readString(ajpin, "")); int serverPort=80; try { String p=readString(ajpin, null); //System.out.println("XXX p " + p); if(p==null ) p="80"; serverPort= Integer.parseInt(p); } catch (Exception any) { any.printStackTrace(); } req.setServerPort( serverPort ); /* Quick and dirty patch to set https scheme in ajp12 * but I recommand using ajp13 instead */ if (serverPort == 443) req.scheme().setString("https"); // System.out.println("XXX port: " + req.getServerPort()); //server protocol String proto=readString(ajpin,null); if( proto==null ) proto="HTTP/1.0"; req.protocol().setString (proto); //server signature dummy = readString(ajpin, ""); //server software dummy = readString(ajpin, ""); req.setJvmRoute( readString(ajpin, null)); dummy = readString(ajpin, ""); dummy = readString(ajpin, ""); break; /** * Marker = 5 will be used by mod_jserv to send environment * vars as key+value (dynamically configurable). * can be considered as "reserved", and safely ignored by * other connectors. * env_vars is (above in this code) commented out for * performance issues. so theses env vars are simply * ignored. (just here for compatibility) * but it is where mod_jserv would place SSL_* env vars * (by exemple) * See the new parameter for mod_jserv (version > 1.1): * ApJServEnvVar localname remotename * - jluc */ case 5: // Environment vars token1 = readString(ajpin, null); token2 = readString(ajpin, ""); /* * Env variables should go into the request attributes * table. * * Also, if one of the request attributes is HTTPS=on * assume that there is an SSL connection. */ req.setAttribute(token1, token2); if(token1.equals("HTTPS") && token2.equals("on")) { req.scheme().setString("https"); } break; case 3: // Header token1 = readString(ajpin, null); token2 = readString(ajpin, ""); // if( "Host".equalsIgnoreCase( token1 )) { // System.out.println("XXX Host: " + token2); // } req.getMimeHeaders().addValue(token1).setString(token2); break; case 254: // Signal signal = ajpin.read(); if (signal == 0) { // PING implemented as signal try { // close the socket connection after we send reply socket.getOutputStream().write(0); // PING reply sin.close(); } catch (IOException ignored) { req.getContextManager().log("Exception closing, ignored", ignored); } isPing = true; return; } else { try { // close the socket connection before handling any // signal but get the addresses first so they are // not corrupted InetAddress serverAddr = socket.getLocalAddress(); InetAddress clientAddr = socket.getInetAddress(); if ( (signal== 15) && isSameAddress(serverAddr, clientAddr) ) { if( secret!=null ) { String stopMsg=readString(ajpin, ""); if( ! secret.equals( stopMsg ) ) { req.getContextManager().log("Attempt to stop with the wrong secret"); return; } } ContextManager cm=req.getContextManager(); cm.shutdown(); cm.log("Exiting" ); // same behavior as in past, because it seems // that stopping everything doesn't work - // need to figure // out what happens with the threads ( XXX ) // until we remove the System.exit() call we // also need to close the socket to allow the // underlying layer to shutdown the connection // properly. Setting soLinger small will // speed this up. socket.setSoLinger(true, 0); sin.close(); System.exit(0); shutdown=true; return; } sin.close(); } catch (Exception ignored) { req.getContextManager().log("Ignored exception " + "processing signal " + signal, ignored); } } return; case 4: case 255: more=false; break; case -1: throw new java.io.IOException("Stream closed prematurely"); default: throw new java.io.IOException("Stream broken"); } // switch } // while } catch (IOException ioe) { throw ioe; } catch (Exception e) { req.getContextManager().log("Uncaught exception handling request", e); } // REQUEST_URI may includes query string String requestURI=req.requestURI().toString(); int indexQ=requestURI.indexOf("?"); int rLen=requestURI.length(); if ( (indexQ >-1) && ( indexQ < rLen) ) { req.queryString(). setString( requestURI.substring(indexQ + 1, requestURI.length())); req.requestURI().setString( requestURI.substring(0, indexQ)); } } /** * Return |
... this post is sponsored by my books ... | |
#1 New Release! |
FP Best Seller |
Copyright 1998-2024 Alvin Alexander, alvinalexander.com
All Rights Reserved.
A percentage of advertising revenue from
pages under the /java/jwarehouse
URI on this website is
paid back to open source projects.