Я пытаюсь реализовать простой веб-сервер Grizzly, который при получении HTTP-запроса будет:
- Обработать указанные фильтры
- Повторить запрос обратно отправителю
Я отправляю запрос из soapUI и вижу поведение, которого не ожидаю:
RunServer.java:
public class RunServer{
public static final String HOST = "localhost";
public static final int PORT = 5151;
public static void main(String[] args) {
final HttpServer server = HttpServer.createSimpleServer();
NetworkListener listener = new NetworkListener("echoCalls", "localhost", 5151);
FilterChainBuilder filterChainBuilder = FilterChainBuilder.stateless();
filterChainBuilder.add(new TransportFilter());
filterChainBuilder.add(new StringFilter(Charset.forName("UTF-8")));
//filterChainBuilder.add(new StringFilter(Charset.forName("ISO-8859-1")));
//filterChainBuilder.add(new StringFilter(Charset.forName("ASCII")));
filterChainBuilder.add(new MyEchoFilter());
listener.setFilterChain(filterChainBuilder.build());
server.addListener(listener);
server.getServerConfiguration().addHttpHandler(new MyEchoHandler(), "/echo");
try{
server.start();
System.out.println("Press any key to stop the server...");
System.in.read();
}catch(IOException ioe){
System.err.println(ioe.toString());
}finally{
server.stop();
}
}
}
MyEchoFilter.java:
public class MyEchoFilter extends BaseFilter{
public NextAction handleRead(FilterChainContext ctx)throws IOException{
System.err.println(">>>MyEchoFilter.handleRead()...");
//|why not working? no response, eventual time out. soapui just hangs up after return NextAction...
final Object peerAddress = ctx.getAddress();
final Object message = ctx.getMessage();
ctx.write(peerAddress, message, null);
return ctx.getStopAction();
}
public NextAction handleWrite(FilterChainContext ctx) throws IOException{
System.err.println(">>>MyEchoFilter.handleWrite()...");
return ctx.getStopAction();
}
public NextAction handleConnect(FilterChainContext ctx) throws IOException{
System.err.println(">>>MyEchoFilter.handleConnect()...");
return ctx.getStopAction();
}
public NextAction handleAccept(FilterChainContext ctx) throws IOException{
System.err.println(">>>MyEchoFilter.handleAccept()...");
return ctx.getStopAction();
}
public NextAction handleClose(FilterChainContext ctx) throws IOException{
System.err.println(">>>MyEchoFilter.handleClose()...");
return ctx.getStopAction();
}
}
МойЭхоХандлер:
public class MyEchoHandler extends HttpHandler{
public void service(Request req, Response res) throws Exception{
System.err.println(">>>handler service method...");
BufferedReader requestStream = new BufferedReader(new InputStreamReader(req.getInputStream()));
String reqStrLn;
StringBuffer callContent = new StringBuffer();
while((reqStrLn = requestStream.readLine()) != null) callContent.append(reqStrLn);
res.setContentLength(callContent.length());
res.getWriter().write(callContent.toString());
}
}
В приведенном выше коде метод handleAccept() запускается при инициировании запроса soapUI. Как ни странно, метод handleRead() не срабатывает, пока я не закомментирую строковый фильтр UTF-8 в RunServer:
//filterChainBuilder.add(new StringFilter(Charset.forName("UTF-8")));
Я не могу понять это, если кто-нибудь может объяснить, я был бы признателен.
Но, что более важно, метод service() в MyEchoHandler также не срабатывает.
Это срабатывает, только если я закомментирую строку, которая устанавливает FilterChain в NetworkListener, в RunServer:
//listener.setFilterChain(filterChainBuilder.build());
Когда я делаю избегаю использования FilterChain, я действительно получаю ответ на soapUI, но мне действительно нужен FilterChain.
Может показаться, что я упускаю здесь часть смысла, что я должен избегать обработчиков вообще, в пользу использования фильтров, но я не смог получить ответ на soapUI при использовании фильтров.
Может ли кто-нибудь помочь мне определить ошибку моего пути?
Заранее спасибо!