私はAJAXを始めたばかりです。インターネットでいくつかのチュートリアルを見つけて作業を開始しましたが、多くのことについてはわかりません。たくさんのコードを貼り付けて申し訳ありませんが、どこが間違っているのかについてはあまりわかりません。でも助けてくれてありがとう!:-)
これが私のJSP(javascript部分のみ)とサーブレットコードです:(例外が続き、通常のJavaアプリケーションに使用する同等のJavaコードが続きます):
JSP:
//--Function to get the xmlhttp object
function getHttpObject(){
var xmlhttp = null;
if (window.XMLHttpRequest){xmlhttp=new XMLHttpRequest();}
else if (window.ActiveXObject){xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");}
else {alert("Your browser does not support XMLHTTP!");}
return xmlhttp;
}
function populateReply(str){
xmlhttp = getHttpObject();
xmlhttp.onreadystatechange=function(){
if(xmlhttp.readyState==4){
ajxfrm.chatresponse.value=xmlhttp.responseText;
}
}
xmlhttp.open("GET","NewServlet?chatinput="+str,true);
xmlhttp.send(null);
}
サーブレット:
public class NewServlet extends HttpServlet implements Servlet {
NetworkAimlFacade aiml = null;
int status = 0;
String botName;
String param[];
GraphBuilder builder;
public NewServlet() throws Exception{
super();
aiml = new NetworkAimlFacade(param);
builder = aiml.getNetworkGraphBuilder();
builder.addDirectoryUnlessAlreadyAdded
(
"C:\\Program Files\\RebeccaAIML\\aiml\\annotated_alice"
);
builder.createGraph();
botName = builder.getBotPredicate("name");
}
private String handleRequest(String param){
return null;
}
public void destroy()
{
try{
aiml.destroy();
}catch(Exception e){
e.printStackTrace();
}
}
protected void doGet(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException{
res.setContentType("text/xml");
res.setHeader("Cache-Control", "no-store, no-cache");
String input = "";
if(req.getParameter("chatinput") != null)
input = req.getParameter("chatinput");
try{
String response = builder.getResponse(input);
if(response!=null) res.getWriter().write(response);
else res.getWriter().write("No");
}catch(Exception e){
e.printStackTrace();
}
}
protected void doPost(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException {
}}
サーブレットからの応答を取得する代わりに、次のエラーが表示されます。
Apache Tomcat/7.0.11 - エラー レポート
HTTP ステータス 500 -
タイプ例外レポート
メッセージ
サーバーで内部エラー () が発生したため、この要求を実行できませんでした。
例外
javax.servlet.ServletException: サーブレット クラス NewServlet のインスタンス化中にエラーが発生しました org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:498) org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100) org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:562) org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:394) org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:243) org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:188) org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:302) java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886) java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908) java.lang.Thread.run(Thread.java:619)
根本的な原因
java.lang.NullPointerException Ice.PropertiesI.<init>(PropertiesI.java:250) Ice.Util.createProperties(Util.java:29) Ice.Util.initialize(Util.java:70) Ice.Util.initialize(Util.java:49) Ice.Util.initialize(Util.java:56) rebecca.NetworkGraphBuilderAIML.<init>(不明なソース) rebecca.NetworkAimlFacade.<init>(不明なソース) NewServlet.<init>(NewServlet.java:27) sun.reflect.NativeConstructorAccessorImpl.newInstance0(ネイティブメソッド) sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39) sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27) java.lang.reflect.Constructor.newInstance(Constructor.java:513) java.lang.Class.newInstance0(Class.java:355) java.lang.Class.newInstance(Class.java:308) org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:498) org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100) org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:562) org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:394) org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:243) org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:188) org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:302) java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886) java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908) java.lang.Thread.run(Thread.java:619)
note根本原因の完全なスタック トレースは、Apache Tomcat/7.0.11 ログで入手できます。
アパッチ トムキャット/7.0.11
これは、通常の Java アプリケーションで使用する同等の Java コードであり、正常に動作します。
public class Console {
public static void main(String args[]) {
NetworkAimlFacade aiml = null;
int status = 0;
try {
aiml = new NetworkAimlFacade(args);
GraphBuilder builder =
aiml.getNetworkGraphBuilder();
builder.addDirectoryUnlessAlreadyAdded
(
"C:\\Program Files\\RebeccaAIML\\aiml\\annotated_alice"
);
builder.createGraph();
String botName =
builder.getBotPredicate("name");
String initialResponse =
builder.getResponse("connect");
System.out.println(botName + " says: " +
initialResponse);
while(true) {
System.out.print("You say> ");
BufferedReader br =
new BufferedReader(new
InputStreamReader(System.in));
String input = br.readLine();
if(input.equals("/exit")) {
break;
} else {
String response =
builder.getResponse(input);
System.out.println("=====================");
//Print out what Rebecca says.
System.out.println(botName + " says: " +
response);
}
}
aiml.destroy();
} catch(NetworkException e) {
e.printStackTrace();
status = 1;
} catch (Exception e) {
e.printStackTrace();
status = 1;
}
System.exit(status);
}
}