gpt4 book ai didi

java - 线程 "main"com.sun.jersey.api.client.ClientHandlerException : java.net.ConnectException 中的异常:连接被拒绝:连接

转载 作者:行者123 更新时间:2023-11-30 08:45:13 25 4
gpt4 key购买 nike

我用的是neo4j 2.2.4

我试试这个程序,这是我的测试代码

package neo4j.rest.client;
import javax.ws.rs.core.MediaType;
import org.json.JSONObject;
import com.sun.jersey.api.client.Client;
import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.WebResource;
public class MyRestClient {
public static void main(String[] args) {
MyRestClient jersey = new MyRestClient();
jersey.createNode();
jersey.sendCypher();
}
public void createNode(){
//Create a REST Client
Client client = Client.create();
//Define a resource (REST Endpoint) which needs to be Invoked
//for creating a Node
WebResource resource = client.resource("http://localhost:7474").path("/db/data/node");
//Define properties for the node.
JSONObject node = new JSONObject();
node.append("Name", "John");
System.out.println(node.toString());
//Invoke the rest endpoint as JSON request
ClientResponse res = resource.accept(MediaType.APPLICATION_JSON)
.entity(node.toString())
.post(ClientResponse.class);
//Print the URI of the new Node
System.out.println("URI of New Node = " + res.getLocation());
}
public void sendCypher() {
//Create a REST Client
Client client = Client.create();
//Define a resource (REST Endpoint) which needs to be Invoked
//for executing Cypher Query
WebResource resource = client.resource("http://localhost:7474").path("/db/data/cypher");
//Define JSON Object and Cypher Query
JSONObject cypher = new JSONObject();
cypher.accumulate("query", "match n return n limit 10");
//Invoke the rest endpoint as JSON request
ClientResponse res = resource.accept(MediaType.APPLICATION_JSON).entity(cypher.toString())
.post(ClientResponse.class);
//Print the response received from the Server
System.out.println(res.getEntity(String.class));
}
}

这是我的错误信息,

{"Name":["John"]} Exception in thread "main" com.sun.jersey.api.client.ClientHandlerException: java.net.ConnectException: Connection refused: connect at com.sun.jersey.client.urlconnection.URLConnectionClientHandler.handle(URLConnectionClientHandler.java:149) at com.sun.jersey.api.client.Client.handle(Client.java:648) at com.sun.jersey.api.client.WebResource.handle(WebResource.java:670) at com.sun.jersey.api.client.WebResource.access$200(WebResource.java:74) at com.sun.jersey.api.client.WebResource$Builder.post(WebResource.java:553) at neo4j.rest.client.MyRestClient.createNode(MyRestClient.java:30) at neo4j.rest.client.MyRestClient.main(MyRestClient.java:14) Caused by: java.net.ConnectException: Connection refused: connect at java.net.DualStackPlainSocketImpl.connect0(Native Method) at java.net.DualStackPlainSocketImpl.socketConnect(DualStackPlainSocketImpl.java:69) at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:337) at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:198) at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:180) at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:157) at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:391) at java.net.Socket.connect(Socket.java:579) at java.net.Socket.connect(Socket.java:528) at sun.net.NetworkClient.doConnect(NetworkClient.java:180) at sun.net.www.http.HttpClient.openServer(HttpClient.java:388) at sun.net.www.http.HttpClient.openServer(HttpClient.java:483) at sun.net.www.http.HttpClient.(HttpClient.java:213) at sun.net.www.http.HttpClient.New(HttpClient.java:300) at sun.net.www.http.HttpClient.New(HttpClient.java:316) at sun.net.www.protocol.http.HttpURLConnection.getNewHttpClient(HttpURLConnection.java:992) at sun.net.www.protocol.http.HttpURLConnection.plainConnect(HttpURLConnection.java:928) at sun.net.www.protocol.http.HttpURLConnection.connect(HttpURLConnection.java:846) at sun.net.www.protocol.http.HttpURLConnection.getOutputStream(HttpURLConnection.java:1087) at com.sun.jersey.client.urlconnection.URLConnectionClientHandler$1$1.getOutputStream(URLConnectionClientHandler.java:225) at com.sun.jersey.api.client.CommittingOutputStream.commitWrite(CommittingOutputStream.java:117) at com.sun.jersey.api.client.CommittingOutputStream.write(CommittingOutputStream.java:89) at sun.nio.cs.StreamEncoder.writeBytes(StreamEncoder.java:221) at sun.nio.cs.StreamEncoder.implFlushBuffer(StreamEncoder.java:291) at sun.nio.cs.StreamEncoder.implFlush(StreamEncoder.java:295) at sun.nio.cs.StreamEncoder.flush(StreamEncoder.java:141) at java.io.OutputStreamWriter.flush(OutputStreamWriter.java:229) at java.io.BufferedWriter.flush(BufferedWriter.java:254) at com.sun.jersey.core.util.ReaderWriter.writeToAsString(ReaderWriter.java:191) at com.sun.jersey.core.provider.AbstractMessageReaderWriterProvider.writeToAsString(AbstractMessageReaderWriterProvider.java:128) at com.sun.jersey.core.impl.provider.entity.StringProvider.writeTo(StringProvider.java:88) at com.sun.jersey.core.impl.provider.entity.StringProvider.writeTo(StringProvider.java:58) at com.sun.jersey.api.client.RequestWriter.writeRequestEntity(RequestWriter.java:300) at com.sun.jersey.client.urlconnection.URLConnectionClientHandler._invoke(URLConnectionClientHandler.java:204) at com.sun.jersey.client.urlconnection.URLConnectionClientHandler.handle(URLConnectionClientHandler.java:147) ... 6 more

谢谢。

最佳答案

  • 检查您的 Neo4j 服务器是否已启动并正在运行。打开http://localhost:7474即可在您的浏览器中。

  • 如果您使用 Neo4j 的默认设置,您的代码将有效。因为授权是默认启用的。您有两个选择:

    1. 将授权 header 添加到您的请求中

      client.addFilter(new HTTPBasicAuthFilter("neo4j","your_password"));

    2. 禁用授权

neo4j-server.properties

# Disable authorization
dbms.security.auth_enabled=false

关于java - 线程 "main"com.sun.jersey.api.client.ClientHandlerException : java.net.ConnectException 中的异常:连接被拒绝:连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33404538/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com