我已经写了一个java桌面应用程序,它接受http请求使用嵌入式NanoHTTPD网络服务器https://github.com/NanoHttpd/nanohttpd,接收到http请求后,我的桌面应用程序进行一些活动并在执行作业时一直写入日志文本文件,当前打开网页的客户端必须等到整个作业完成并且整个页面被发送并且查看日志文件时,我希望日志数据一旦被添加到本地日志文件就发送到客户端,我知道这是使用ajax完成的,但我没有时间去学习它,只是如何使更新java中的某些对象直接反映到网页而无需发送整个页面。如何使用NanoHTTPD显示日志文件
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">
需要多一点的解释存在。 。 我很困惑。 。 网页? Java桌面应用程序?桌面应用程序是否读取日志文件并通过nanohttpd将其发送到网页? – sethu 2014-09-23 08:43:27
@sethu是的,我增加了更多的细节。 – 2014-09-23 11:25:43