Wicket sul server di java basato auto scritta
Domanda
Hey yall, ho un wicket- e anche una questione di server correlati:
Abbiamo costruito un piccolo server con Java (sì, lo so, perché ri-inventare la ruota ... ho ottenuto che molto quando ho posto la domanda sul wicket-mailing-list) .... quindi facciamo solo per esempio, è un disperato bisogno b / c ... ehm ... io ancora non riesco a pensare a una buona ragione, ma non c'è molto che posso fare al riguardo ... così finalmente ho avuto questo piccolo server per eseguire servlet ... per quanto ne so, a correre wicket è necessario un server in grado di eseguire i servlet ... (come per la mia mancanza di inglese diciamo solo: si suppone essere un servlet container come Tomcat) ... ora che io ho questa bellissima assistente, qualcuno ha un'idea che cosa devo fare, in modo che i miei wicket-apps eseguiti su di esso? Come faccio a dire il mio server che si suppone di eseguire un wicket-app?
La speranza ho spiegato bene ... thnx in anticipo:)
... dg
ok, un po 'di fonte ... Ho fatto questo a seguito di un tutorial:
HTTPServer dove la "magia" avviene:
while (!shutdown) {
// ... all the stuff before
//check if this is a request for a servlet or a static resource
//a request for a servlet begins with "/servlet/"
if (request.getUri().startsWith("/servlet/")) {
System.out.println( "SERVLET-REQUEST\n\n" );
ServletProcessor2 processor = new ServletProcessor2();
processor.process(request, response);
}
else {
System.out.println( "STATICRESOURCE-REQUEST" );
StaticResourceProcessor processor = new StaticResourceProcessor();
processor.process(request, response);
}
// ... all the stuff after
}
Ora la ServletProcessor:
public class ServletProcessor2 {
public void process(Request request, Response response) {
String uri = request.getUri();
String servletName = uri.substring(uri.lastIndexOf("/") + 1);
System.out.println( "SERVLETNAME ... " + servletName );
URLClassLoader loader = null;
try {
// create a URLClassLoader
URL[] urls = new URL[1];
URLStreamHandler streamHandler = null;
File classPath = new File(Constants.WEB_ROOT);
// the forming of repository is taken from the createClassLoader method in
// org.apache.catalina.startup.ClassLoaderFactory
String repository = (new URL("file", null, classPath.getCanonicalPath() + File.separator)).toString() ;
System.out.println( "REPOSITORY ... " + repository );
// the code for forming the URL is taken from the addRepository method in
// org.apache.catalina.loader.StandardClassLoader class.
urls[0] = new URL(null, repository, streamHandler);
loader = new URLClassLoader(urls);
}
catch (IOException e) {
System.out.println(e.toString() );
}
Class myClass = null;
try {
myClass = loader.loadClass(servletName);
}
catch (ClassNotFoundException e) {
System.out.println("FEHLER: " + e.toString() + " ... CAUSE: " + e.getCause() );
e.printStackTrace();
}
Servlet servlet = null;
RequestFacade requestFacade = new RequestFacade(request);
ResponseFacade responseFacade = new ResponseFacade(response);
try {
servlet = (Servlet) myClass.newInstance();
servlet.service((ServletRequest) requestFacade, (ServletResponse) responseFacade);
}
catch (Exception e) {
System.out.println( "Fehler: " + e.toString() + " ... CAUSE: " + e.getCause() );
e.printStackTrace();
}
catch (Throwable e) {
System.out.println(e.toString());
}
}
}
Soluzione
La semplice risposta è che sarà necessario implementare il Servlet API . La documentazione wicket non sembra di dire ciò che la versione richiesta esatta, ma io sono sicuro che sarà di almeno 2,4. Non è un lavoro che vi consiglio di fare, è una cosa difficile da fare correttamente e il tuo solo aprendo la vostra auto per un mondo di dolore.
Se hai bisogno di incorporare un server allora potrei raccomandare di iniziare con molo e personalizzarlo per soddisfare le esigenze di che cosa mai avete. Jetty ha una licenza molto permissiva in modo da non dovete preoccuparvi di usare in un prodotto commerciale e può scalare praticamente con il meglio di loro.