java后台--底层ajxs,隐藏帧技术(与后台交接不是通过js判断)
2016-07-29 01:38
169 查看
仿AJax技术,也是Ajax的原理
写一个form表单,把要与后台交接的地方隐藏起来,不给用户看到,也就实现了隐藏帧技术
这是注册界面reg.jsp
这是后台(隐藏的)的交接ValServlet
这是中转站的界面regResult.jsp
写一个form表单,把要与后台交接的地方隐藏起来,不给用户看到,也就实现了隐藏帧技术
这是注册界面reg.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>这是注册页面</title> <script type="text/javascript"> function val(obj){ if(obj.name=="name"){ var value=obj.value; if(value!=null&&value!=""){ document.getElementById("regName").value=value; document.getElementById("regName"); document.forms[1].submit(); } } } function ajaxBack(res){ if(res==1){ msg.innerHTML="用户名已经存在,请换一个!"; }else{ msg.innerHTML="恭喜,可以注册!"; } } </script> </head> <body> <form action="<%request.getContextPath(); %>/RegServlet" method="post"> Name:<input type="text" name="name" onblur="val(this)"> <label id="msg" style="color:red;"></label> <br/> Pwd:<input type="password" name="pwd" "><br/> TEL:<input type="text" name="tel" ><br/> <input type="submit" value="注册"/> </form> <!--注意,一定要写target,不然会转到其他页面--> <form target="dateFrame" action="/jspDemo2/ValServlet" method="post"> <input id="regName" name ="name" type="hidden"><br/> </form> <iframe name="dateFrame" style="display: none;"> </iframe> </body> </html>
这是后台(隐藏的)的交接ValServlet
package cn.hncu.regServlet; import java.io.IOException; import java.io.PrintWriter; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; public class ValServlet extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doPost(request, response); } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html;charset=utf-8"); PrintWriter out = response.getWriter(); request.setCharacterEncoding("utf-8"); String name = request.getParameter("name"); String pwd = request.getParameter("pwd"); String tel = request.getParameter("tel"); if(name!=null && name.trim().length()>0 && name.startsWith("hn")){//正式项目,应该到后台进行验证是否已经存在,这里简化了---假定hncu开头的都可以注册.... request.setAttribute("error", 1);//可以注册的 }else{ request.setAttribute("error", 0);//不能注册,该用户名已经存在! } request.getRequestDispatcher("/jsps/regResult.jsp").forward(request, response); } }
这是中转站的界面regResult.jsp
<%@page import="sun.org.mozilla.javascript.internal.ast.ParenthesizedExpression"%> <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> </head> <body> <script type="text/javascript"> <%-- var err=<%pageContext.findAttribute("error");%> if(err==1){ parent.document.getElementById("msg").innerHTML="恭喜,注册成功!"; }else if(err==0){ parent.document.getElementById("msg").innerHTML="用户名已经存在,请换一个!"; } --%> parent.ajaxBack(); </script> </body> </html>
相关文章推荐
- 在html里面获取到后台的数据(不是通过js)怎样传递到js中
- IT咨询顾问:一次吐血的项目救火 java或判断优化小技巧 asp.net core Session的测试使用心得 【.NET架构】BIM软件架构02:Web管控平台后台架构 NetCore入门篇:(十一)NetCore项目读取配置文件appsettings.json 使用LINQ生成Where的SQL语句 js_jquery_创建cookie有效期问题_时区问题
- js中对中文escape转码,java后台通过URL获取中文参数的问题
- js中的多组json数据同时通过ajx传递到php后台
- java后台调用JS代码判断浏览器版本是否低于IE9,低版本跳转不同页面
- java通过NumberUtils判断是否是double,而不是StringUtils
- 前台js(canvas)生成图片,通过后台java进行保存
- Primefaces中通过RemoteCommand实现JS触发调用Java后台方法
- Android使用webview控件加载本地html,通过Js与后台Java实现数据的传递
- 纯JS的网站流量监控(IP通过后台获取,后台判断防止盗链)
- 判断文件类型(文件的真正类型,不是根据扩展名判断),通过文件头来判断
- Java、Js判断全角半角
- EXTJS AJAX发送数据到JAVA后台 js->jsp->java->html
- js里没有equals方法,java里string判断相等不能用==
- [转]android 2.3.3底层错误导致js调用java程序崩溃
- 通过js判断上传文件类型
- 【asp.net 】使用js结合hidden控件实现在后台运行一段程序后提示确认,确认通过后继续执行后台代码~~~
- 用js实现判断当前网址的来路如果不是指定的来路就跳转到指定页面
- js 传中文,java后台乱码问题
- 在JS及java中判断文件(如图片)存在不存在