2
所以我试图使用TCP套接字在JSP页面上创建一个客户端进行通信,我遇到的问题是每当我在页面中提交表单时,它都会刷新页面并创建一个新的客户端套接字,删除我以前的信息(nomeUtilizador)。我搜索的方式提交表单没有刷新,并尝试它(AJAX),但它从来没有真正解决......JSP套接字没有刷新页面
也许还有其他方法来解决这个问题,就像使它成为套接字只创建一次.. ,或者变量nomeUtilizador由适用于所有刷新...
<% private void ClienteTCP(String host, int port) {
try {
s = new Socket(host, port);
System.err.println("Ligacao estabelecida");
in = new ObjectInputStream(s.getInputStream());
out = new ObjectOutputStream(s.getOutputStream());
System.err.println("Streams criadas");
} catch (UnknownHostException uhEx) {
System.err.println("UnknownHostException");
} catch (IOException ioEx) {
} catch (Exception e) {
}
}
ClienteTCP("localhost", 6000);
String nomeUtilizador = (String) session.getAttribute("nomeUtilizador");
String xmlUtilizador = "C:/Users/leonel/workspace/ParqueEstacionamento/WebContent/xml_clientes/"
+ nomeUtilizador.replaceAll("\\s+", "") + ".xml";
criarDocument(xmlUtilizador);
ArrayList<String> listaParques = getParques();
%><form name="botoes" id="botoes" method="post"
action="parqueOnline.jsp" onsubmit="submitForm()">
<input TYPE="HIDDEN" NAME="buttonName"> <input type="button"
name="botao" value="Estacionar" onclick="showDiv();"> <input
type="submit" name="botao" value="Pagar" onclick="pagar();">
<input type="submit" name="botao" value="Sair" onclick="sair();">
<br />
<div id="escolherParque" style="display: none;" class="escolherParque">
<label>Parques</label> <select name="parque">
<option value=""></option>
<%
for (int i = 0; i < listaParques.size(); i++) {
%>
<option value=<%=listaParques.get(i)%>><%=listaParques.get(i)%></option>
<%
}
%>
</select> <input type="submit" name="estacionar"
value="Escolha o Parque onde quer estacionar.."
onclick="escolherParque();">
</div>
</form>
<%
String botao = request.getParameter("buttonName");
if (botao != null) {
//do more stuff %>
你试图存档什么?据我所知,JSP中的代码在服务器端运行。因此,当您使用您发布的代码创建套接字时,套接字实际上是在应用程序服务器上创建的,而不是在客户端创建的。要使用java在客户端创建套接字,您应该使用applet。如果你需要浏览器和服务器之间的实时通信,你可以考虑使用[web socket](http://www.html5rocks.com/en/tutorials/websockets/basics/)或[web worker](http:// www.w3schools.com/html/html5_webworkers.asp) –
谢谢你的建议人 – user3185775