gpt4 book ai didi

java - 如何使用 NanoHTTPD 显示日志文件

转载 作者:行者123 更新时间:2023-12-02 05:26:06 25 4
gpt4 key购买 nike

我编写了一个java桌面应用程序,它使用嵌入式NanoHTTPD Web服务器接受http请求https://github.com/NanoHttpd/nanohttpd ,在收到http请求后,我的桌面应用程序进行一些 Activity ,并在执行其作业时不断写入日志文本文件,当前打开网页的客户端必须等到整个作业完成、发送整个页面并查看日志文件,我希望日志数据在添加到本地日志文件后立即发送到客户端,我知道这是使用 ajax 完成的,但我还没有时间学习它,只是如何更新某个对象在java中直接反射到网页而不需要发送整个页面。

import java.util.ArrayList;
import java.util.LinkedList;
import java.util.Map;

import common.Logging;
import common.TextFiles;
import fi.iki.elonen.NanoHTTPD;
import fi.iki.elonen.ServerRunner;
import fi.iki.elonen.SimpleWebServer;

public class TestServer extends NanoHTTPD {
static boolean isDoingAJob=false;
public TestServer() {
super(8080);
}


@Override public Response serve(IHTTPSession session) {
Method method = session.getMethod();
Map<String,String> params = session.getParms();
String uri = session.getUri();
System.out.println(method + " '" + uri + "' ");
String msg = "<html><style>h1 { color: green; background-color: black;}p { color: gray; background-color: black;}div { color: gray; background-color: black;}body { color: gray; background-color: black;}</style><body><h1>Remote Test Service</h1>";
Map<String, String> parms = session.getParms();
for(String paramKey:parms.keySet()){
String job=params.get(paramKey);

msg+="Status: "+(isDoingAJob?"Waited in queue.":"Immediate run.");
if ("tcl".equalsIgnoreCase(paramKey)){
try {
//if another request is being executed wait until finished
while(isDoingAJob){
Thread.sleep(3000);
}
//Raise a flag while executing a test run
isDoingAJob=true;
SomeJobClass.doSomeWork(job.split(" "));
isDoingAJob=false;
ArrayList<String> lines=TextFiles.load(Logging.getLogFile().toString());
for(String line: lines){
msg+="<p>"+line+"</p>";
}
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} else{
//echo help if parameter key is not tcl
ArrayList<String> lines=TextFiles.load("some help.txt");
for(String line: lines){
msg+="<p>"+line+"</p>";
}
}
}

//show this when no parameters passed
if (parms.isEmpty()){
ArrayList<String> lines=TextFiles.load("some help.txt");
for(String line: lines){
msg+="<p>"+line+"</p>";
}
}
msg += "</body></html>";
return new NanoHTTPD.Response(msg);
}


public static void main(String[] args) {
ServerRunner.run(TestServer.class);
}
}

我找到了这个代码http://www.binpress.com/app/jquery-log-viewer/570但对我不起作用

<html>
<head>
<script src="http://code.jquery.com/jquery-latest.js"></script>
<script src="jquery.logviewer.js"></script>
<script type="text/javascript">

jQuery(document).bind("ready", function() {
jQuery('#logcontent').logViewer({logUrl: 'log.html'});
});
</script>
</head>
<body>
Live log:<br/>
<textarea id="logcontent" autocomplete="off">

最佳答案

最简单的方法如下:

package fi.iki.elonen;

import org.apache.commons.io.FileUtils;

import java.io.File;
import java.io.IOException;
import java.util.List;
import java.util.Map;

public class Stackoverflowtest extends NanoHTTPD{
static boolean isDoingAJob=false;
public Stackoverflowtest() {
super(8080);
}


@Override public Response serve(IHTTPSession session) {
Method method = session.getMethod();
Map<String,String> params = session.getParms();
String uri = session.getUri();
System.out.println(method + " '" + uri + "' ");
String msg = "<html><style>h1 { color: green; background-color: black;}p { color: gray; background-color: black;}div { color: gray; background-color: black;}body { color: gray; background-color: black;}</style><body><h1>Remote Test Service</h1>";
try {
List<String> lines= FileUtils.readLines(new File("<fileloc>"));
for(String line: lines){
msg+="<p>"+line+"</p>";
}
} catch (Exception e) {
e.printStackTrace();
}
msg += "</body><script>setTimeout(function(){\n" +
" window.location.reload(1);\n" +
"}, 5000);</script></html>";
return new NanoHTTPD.Response(msg);
}


public static void main(String[] args) {
try {
new Stackoverflowtest().start();
} catch (IOException e) {
e.printStackTrace();
}
}
}

注意底部的脚本。它只是让浏览器每 5 秒重新加载一次。您不需要 ajax 或任何东西来获得简单的解决方案。如果您想构建更复杂的东西,例如仅将新添加的行添加到浏览器,那么解决方案将需要进行一些更改。

注意:为了使其正常工作,在 NanoHTTPD 类的 run() 方法中,我将 myThread.setDeamon(true) 更改为 false。否则你需要让你的主线程 hibernate 很长时间。否则程序就会退出。

关于java - 如何使用 NanoHTTPD 显示日志文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25989280/

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