gpt4 book ai didi

java - 无法通过对象输出流将对象从一个 http 处理程序发送到另一个

转载 作者:搜寻专家 更新时间:2023-11-01 00:54:24 25 4
gpt4 key购买 nike

因此,在我的应用程序中,我将请求从 http 服务器处理程序 发送到另一台服务器。问题是第二台服务器卡在了读取对象上。我试图自己弄清楚,但看不到问题所在。所有流都关闭了,也许对客户端的响应在错误的地方?我不知道这是为什么..

这是我的客户:

public class ClientSimulator {

private Random random;
private static int clientCounter = 1;

public static void main(String[] args) throws Exception {
new ClientSimulator();
new ClientSimulator();
new ClientSimulator();
}

private ClientSimulator() {

this.random = new Random();
RuntimeMXBean rmb = ManagementFactory.getRuntimeMXBean();
long arrivalTime = rmb.getUptime();

System.out.println("thread no. " + clientCounter++ + " arrival time: " + arrivalTime);
try {
String myurl= "http://localhost:8080/sender";
String serverResponse = createClient(myurl);
System.out.println(serverResponse);
} catch (Exception e) {
e.printStackTrace();
}
}

private String createClient(String myurl) throws Exception {
URL url;
BufferedReader reader = null;
StringBuilder stringBuilder;

try {
//Standard HTTP connection
url = new URL(schedulerUrl);
HttpURLConnection connection = (HttpURLConnection) url.openConnection();
connection.setDoInput(true);
connection.setDoOutput(true);

int[] arr = {
random.nextInt(10-1)+1,
random.nextInt(10-1)+1,
random.nextInt(10-1)+1,
random.nextInt(10-1)+1,
random.nextInt(10-1)+1,
};
Task t = new Task(arr);

ObjectOutputStream oos = new ObjectOutputStream(connection.getOutputStream());
oos.writeObject(t);
oos.close();

// read the output from the server
reader = new BufferedReader(new InputStreamReader(connection.getInputStream()));
stringBuilder = new StringBuilder();
//print the response
String line = reader.readLine();
stringBuilder.append(line);

return stringBuilder.toString();
} catch (Exception e) {
e.printStackTrace();
throw e;
} finally {
if (reader != null) {
try {
reader.close();
} catch (IOException ioe) {
ioe.printStackTrace();
}
}
}
}

private boolean getRandBool(){
return this.random.nextBoolean();
}
}

这是我将请求从主服务器发送到另一台服务器的方式:

@Override
public void handle(HttpExchange httpExchange) throws IOException {

String template = "\nClient no. %s connected!";

//Getting task
Task t;
ObjectInputStream ois = new ObjectInputStream(httpExchange.getRequestBody());
try {
System.out.print("Recieved object:");
t = (Task) ois.readObject();
t.setDeadline(deadline);
t.setHard(isHard);
System.out.print(" not sorted array: ");
int[] arr = (int[]) t.getData();
for (int anArr : arr) {
System.out.print(anArr + " ");
}
ois.close();

String response = "response for client no. " + clientCounter;
httpExchange.sendResponseHeaders(200, response.length());
OutputStream os = httpExchange.getResponseBody();
os.write(response.getBytes());
os.close();
clientCounter++;

HttpURLConnection test = (HttpURLConnection) new URL(fogServ1URL).openConnection();
test.setDoOutput(true);
System.out.println("test__1");
ObjectOutputStream stream = new ObjectOutputStream(test.getOutputStream());
stream.flush();
System.out.println("test__2");
stream.writeObject(t);
System.out.println("test__3");
stream.close();
System.out.println("test__4");
test.getResponseCode();
System.out.println("test__5"); //this doesn't print
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
}

这是来自第二个服务器的处理程序:

class RootHandler implements HttpHandler{
private static int clientCounter = 1;

@Override
public void handle(HttpExchange exchange) throws IOException {



System.out.println("\nRoot handler; \n\tclient no. " + clientCounter++);

Task t;
ObjectInputStream ois = new ObjectInputStream(exchange.getRequestBody());
try {
System.out.println("Recieved object:"); //only this is on the console
t = (Task) ois.readObject();
ois.close();
System.out.println("Array not sorted:");
int[] arr = (int[]) t.getData();
for (int anArr : arr) {
System.out.print(anArr + " ");
}
TaskSolver.solve(t);
System.out.println("\nArray sorted!");
for (int anArr : (int[])t.getData()) {
System.out.print(anArr + " ");
}
} catch (ClassNotFoundException e) {
e.printStackTrace();
}

String response = "Server up!";
exchange.sendResponseHeaders(200, response.getBytes().length);
OutputStream os = exchange.getResponseBody();
os.write(response.getBytes());
os.close();
}
}

我不明白,因为我以相同的方式将 Task 从客户端发送到主服务器并正常工作。我只是无法读取下一台服务器的输出。我究竟做错了什么?

顺便说一句。如果有人好奇为什么我要将相同的对象发送到另一台服务器:我计划创建更多服务器,主服务器将根据类型/包含 header 向它们发送请求。

最佳答案

在第二个服务器中读取对象时发生了一些 IOException,因为 RootHandler 类的 handle 方法中的 IOException 被传递给调用方法而不是处理它。因此像 Internal Server Error 响应状态这样的错误被发送到客户端(第一台服务器)。

由于在第二台服务器中存在异常,test.getResponseCode() 抛出 IOException,因为它未在第一台服务器的 handle 方法中处理

System.out.println("test__5");

未被调用。

如果您想知道发生了什么,请在服务器的 handle 方法中捕获 IOException 并打印 Stack trace。

关于java - 无法通过对象输出流将对象从一个 http 处理程序发送到另一个,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48420875/

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