public class Webserver
extends java.lang.Object
This enables a Java program to instrument class files loaded by web browsers for applets. Since the (standard) security manager does not allow an applet to create and use a class loader, instrumenting class files must be done by this web server.
Note: although this class is included in the Javassist API, it is provided as a sample implementation of the web server using Javassist. Especially, there might be security flaws in this server. Please use this with YOUR OWN RISK.
Modifier and Type | Field and Description |
---|---|
java.lang.String |
debugDir
If this field is not null, the class files taken from
ClassPool are written out under the directory
specified by this field. |
java.lang.String |
htmlfileBase
The top directory of html (and .gif, .class, ...) files.
|
Constructor and Description |
---|
Webserver(int port)
Constructs a web server.
|
Webserver(java.lang.String port)
Constructs a web server.
|
Modifier and Type | Method and Description |
---|---|
void |
addTranslator(ClassPool cp,
Translator t)
Adds a translator, which is called whenever a client requests
a class file.
|
void |
doReply(java.io.InputStream in,
java.io.OutputStream out,
java.lang.String cmd)
Proceses a HTTP request from a client.
|
void |
end()
Closes the socket.
|
void |
logging(java.lang.String msg)
Prints a log message.
|
void |
logging(java.lang.String msg1,
java.lang.String msg2)
Prints a log message.
|
void |
logging(java.lang.String msg1,
java.lang.String msg2,
java.lang.String msg3)
Prints a log message.
|
void |
logging2(java.lang.String msg)
Prints a log message with indentation.
|
static void |
main(java.lang.String[] args)
Starts a web server.
|
void |
run()
Begins the HTTP service.
|
void |
setClassPool(ClassPool loader)
Requests the web server to use the specified
ClassPool object for obtaining a class file. |
public java.lang.String debugDir
ClassPool
are written out under the directory
specified by this field. The directory name must not end
with a directory separator.public java.lang.String htmlfileBase
If the given URL indicates a class file and the class file
is not found under the directory specified by this variable,
then Class.getResourceAsStream()
is called
for searching the Java class paths.
public Webserver(java.lang.String port) throws java.io.IOException
port
- port numberjava.io.IOException
public Webserver(int port) throws java.io.IOException
port
- port numberjava.io.IOException
public static void main(java.lang.String[] args) throws java.io.IOException
java.io.IOException
public void setClassPool(ClassPool loader)
ClassPool
object for obtaining a class file.public void addTranslator(ClassPool cp, Translator t) throws NotFoundException, CannotCompileException
cp
- the ClassPool
object for obtaining
a class file.t
- a translator.NotFoundException
CannotCompileException
public void end() throws java.io.IOException
java.io.IOException
public void logging(java.lang.String msg)
public void logging(java.lang.String msg1, java.lang.String msg2)
public void logging(java.lang.String msg1, java.lang.String msg2, java.lang.String msg3)
public void logging2(java.lang.String msg)
public void run()
public void doReply(java.io.InputStream in, java.io.OutputStream out, java.lang.String cmd) throws java.io.IOException, BadHttpRequest
out
- the output stream to a clientcmd
- the command received from a clientjava.io.IOException
BadHttpRequest
Javassist, a Java-bytecode translator toolkit.
Copyright (C) 1999- Shigeru Chiba. All Rights Reserved.