2017-02-22 7 views
5

私はデフォルトのGWTプロジェクトを作成し、CouchDBをデータベースとして使用して簡単なエントリでデータベースにドキュメントを作成しようとしました。以前は、UIとしてCouchDB 1.6すなわち布団を使用していました。さて、最近、UIとしてCouchDB 2.0すなわちFauxtonを使用しようとしています。Javaを使用してCouchDB 2.0 fauxtonでドキュメントを作成

問題: -

のCouchDB 2.0で文書を作成することができません。

サーバ側CODE: -

public String greetServer(String input) throws IllegalArgumentException { 
     // Verify that the input is valid. 
     System.out.println(input); 

     Session session=new Session("192.168.1.48",5984); 
     Database db=session.getDatabase("testing"); 
     Document doc=new Document(); 
     doc.put("name", input); 
     db.saveDocument(doc); 

     return "Hello, " + input; 
    } 

例外: -

2017-02-22 17:23:41.147:WARN:/:qtp10750155-45: Exception while dispatching incoming RPC call 
com.google.gwt.user.server.rpc.UnexpectedException: Service method 'public abstract java.lang.String com.dbconnect.client.GreetingService.greetServer(java.lang.String) throws java.lang.IllegalArgumentException' threw an unexpected exception: net.sf.json.JSONException: JSONObject["update_seq"] is not a number. 
    at com.google.gwt.user.server.rpc.RPC.encodeResponseForFailure(RPC.java:416) 
    at com.google.gwt.user.server.rpc.RPC.invokeAndEncodeResponse(RPC.java:605) 
    at com.google.gwt.user.server.rpc.RemoteServiceServlet.processCall(RemoteServiceServlet.java:333) 
    at com.google.gwt.user.server.rpc.RemoteServiceServlet.processCall(RemoteServiceServlet.java:303) 
    at com.google.gwt.user.server.rpc.RemoteServiceServlet.processPost(RemoteServiceServlet.java:373) 
    at com.google.gwt.user.server.rpc.AbstractRemoteServiceServlet.doPost(AbstractRemoteServiceServlet.java:62) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:648) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:729) 
    at org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder.java:812) 
    at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:587) 
    at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:143) 
    at org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:577) 
    at org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:223) 
    at org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1127) 
    at org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:515) 
    at org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:185) 
    at org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1061) 
    at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:141) 
    at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:97) 
    at org.eclipse.jetty.server.handler.RequestLogHandler.handle(RequestLogHandler.java:95) 
    at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:97) 
    at org.eclipse.jetty.server.Server.handle(Server.java:499) 
    at org.eclipse.jetty.server.HttpChannel.handle(HttpChannel.java:311) 
    at org.eclipse.jetty.server.HttpConnection.onFillable(HttpConnection.java:257) 
    at org.eclipse.jetty.io.AbstractConnection$2.run(AbstractConnection.java:544) 
    at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:635) 
    at org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:555) 
    at java.lang.Thread.run(Unknown Source) 
Caused by: 
net.sf.json.JSONException: JSONObject["update_seq"] is not a number. 
    at net.sf.json.JSONObject.getDouble(JSONObject.java:2090) 
    at net.sf.json.JSONObject.getInt(JSONObject.java:2109) 
    at com.fourspaces.couchdb.Database.<init>(Database.java:50) 
    at com.fourspaces.couchdb.Session.getDatabase(Session.java:185) 
    at com.dbconnect.server.GreetingServiceImpl.greetServer(GreetingServiceImpl.java:22) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) 
    at java.lang.reflect.Method.invoke(Unknown Source) 
    at com.google.gwt.user.server.rpc.RPC.invokeAndEncodeResponse(RPC.java:587) 
    at com.google.gwt.user.server.rpc.RemoteServiceServlet.processCall(RemoteServiceServlet.java:333) 
    at com.google.gwt.user.server.rpc.RemoteServiceServlet.processCall(RemoteServiceServlet.java:303) 
    at com.google.gwt.user.server.rpc.RemoteServiceServlet.processPost(RemoteServiceServlet.java:373) 
    at com.google.gwt.user.server.rpc.AbstractRemoteServiceServlet.doPost(AbstractRemoteServiceServlet.java:62) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:648) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:729) 
    at org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder.java:812) 
    at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:587) 
    at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:143) 
    at org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:577) 
    at org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:223) 
    at org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1127) 
    at org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:515) 
    at org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:185) 
    at org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1061) 
    at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:141) 
    at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:97) 
    at org.eclipse.jetty.server.handler.RequestLogHandler.handle(RequestLogHandler.java:95) 
    at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:97) 
    at org.eclipse.jetty.server.Server.handle(Server.java:499) 
    at org.eclipse.jetty.server.HttpChannel.handle(HttpChannel.java:311) 
    at org.eclipse.jetty.server.HttpConnection.onFillable(HttpConnection.java:257) 
    at org.eclipse.jetty.io.AbstractConnection$2.run(AbstractConnection.java:544) 
    at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:635) 
    at org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:555) 
    at java.lang.Thread.run(Unknown Source) 

/******************* *************** EDIT 1 ************************/ Link where mentioned about update_seq

  • 問題は、データベースの作成時にautoが行ったコードでupdate_seqを更新していないことです。だから、何が問題なのか分からない。

  • このデータベースは、CouchDB 2.0で簡単にjavaを使用して作成されています。

  • 新しいバージョンのJARファイルを使用する必要がありますか?>COUCHDB JARS(USED AT TIME OF 1\COUCHDB 1.6

+0

私はエラーがかなり問題が何であるかを言うと思います。更新されたUIは文字列として 'update_seq'を送り、1.xサーバ上にまだ長い値を待っているサーバを送ります。したがって、サーバを2.xにアップデートすると良いスタートになるでしょう。 – Veeram

+0

Sir、すでに2.0に移行し、そこを越えて基本的な機能を実行しようとしていますが、失敗しました。私たちはupdate_seqフィールドで自動生成フィールドを使って何もしません。 couchdb 2.0の公式ドキュメントのupdate_seqフィールドの値はまだintを表示しています。私はリンクを投稿しました。 – Vartika

+0

サーバライブラリも2.0にアップデートしましたか?あなたが共有するスクリーンショットのjarファイル – Veeram

答えて

2

問題が(ほぼ5年前の最後のgithubの上でコミット)couchdb4jは、古いものとしなければなりません。

この投稿では、より積極的に取り組んでいるクライアントライブラリを使用することを提案しています。 EktorpCouchDB Java client参照)。あなたがリンクされ

移行ドキュメント(https://blog.couchdb.org/2016/08/17/migrating-to-couchdb-2-0/)に直面しているcouchbd4j-問題に

背景の状態:

を最も重要なのは、アップデート以降、またはシーケンスは、多数の任意ではありません 長いが文字列。

あなたが直接 UPDATE_SEQ を扱うが、couchdb4jいません言ったように。

updateSeq = json.getInt("update_seq"); 

そして、これはもはやCouchDBの2で動作しません:

couchdb4jクライアント・ライブラリの現在の実装では、次のコードを使用して整数として、サーバー応答特性UPDATE_SEQを解析します。どこにでもクライアントで、私は、これは助けを願っていhttps://github.com/mbreese/couchdb4j/blob/master/src/java/com/fourspaces/couchdb/Database.java(59行を参照)

、 クリスチャン

+0

が残っていますが、まだ混乱があります。 coutb4jの代わりにektorp jarを使用するように言っていますか? couchdb4jは長い間更新されていないため。私を許しても、答えをはっきりと理解できませんでした。どのように私はupdate_seqデータ型を変更したいのですか – Vartika

+0

これについて完全にはっきりしていないのは残念です。最新のcouchdb4j client-libraryとcouchdb 2.0は、update_seqの処理方法に互換性がありません。そのため、別のクライアントライブラリに切り替える必要があります。 couchdbのための良いクライアントライブラリに関する議論は、私が提供したリンクで見つけることができます。 –

+0

申し訳ありませんが、他のライブラリを検索しようとしましたが、使用できませんでした。どのようにしてセッションを作成し、データを取得し、ドキュメントを作成するのか、コードはどのようになりますか?申し訳ありません – Vartika

0

使用マッチングやjarファイルの新しいバージョン:0

は、ここでは、この行を含む最新のコードへのリンクですサーバとしても機能します。ファイルバージョンのディレクトリ検索を行うことができます。古いファイルが選択される可能性を排除するために、プロジェクト全体をきれいにして再構築する。

関連する問題