JSp+ajax用户登录验证

[img]http://dl2.iteye.com/upload/attachment/0088/2001/4ee085e5-47e0-3995-ad42-62e4a53cfc2f.png[/img]
用户登陆界面,想要实现输入账号之后离开输入框就验证该账号是否存在,输入角色、账号、密码之后,点击登录,如果正确就跳转到index.jsp,错误不跳转并且在密码输入框下显示提示信息;有一个没输入就提示,信息也是在密码输入框下。

我现在的问题是:若果什么也不输,点击登录,会闪一下,但闪过之后就是重置了页面。输入正确也是闪一下就重置页面.账号验证没问题,就是登录有问题,但是搞不定,大侠们看看吧!
login.jsp
[code="java"]


                <tr>
                <td align="right">角色类型:</td>
                <td><select name="role" id="role" onBlur="checkRole(this)">
                <option value="0">-请选择角色-</option>
                        <%
                            List<Role> list = new ArrayList<Role>();
                                RoleDao dao = new RoleDaoImpl();
                                list = dao.findAllRoles();//调用实现类的查询全部方法
                                for (int i = 0; i < list.size(); i++) {
                                    Role r = list.get(i);
                        %>
                        <option value="<%=r.getR_id()%>"><%=r.getR_name()%></option>
                        <%
                            }
                        %>
                </select>
                </td>
                <td align="left">
                            &nbsp;
                            <span id="roleSpan"></span>
                        </td>
            </tr>
            <tr>
                <td align="right">账号:</td>
                <td>
                <input type="text" name="number" id="number" onblur="checkNumber(this)">
                </td>
                 <td width="256" align="left">
                            &nbsp;
                            <span id="numberSpan"></span>
                        </td>
                </tr><!--  当输入名字后离开输入框即调用-->
            <tr>
                <td align="right">密码:</td>
                <td><input type="password" name="pwd" id="pwd" onBlur="checkPsw(this)" >
                </td>
                <td align="left">
                            &nbsp;
                            <span id="pwdSpan"></span>
                        </td>
            </tr>
            <tr>
         <td  align="left">&nbsp;<span id="feedback_info"></span></td>
    </tr>
            <tr>
                <td colspan="1">
                            <input type="submit" value="登录" onclick="checkLogin(this.form)"/>

                    <input type="button" value="注册"
                    onclick="javascript:window.location.href='User/Register.jsp'"></td>

            </tr>
        </table>
    </form>[/code]

login.js
[code="java"]var xmlHttp;
function createXMLHttpRequest() {
if (window.XMLHttpRequest) {
var xmlHttp = new XMLHttpRequest(); //mozilla浏览器

}
else if (window.ActiveXObject) {
try {
var xmlHttp = new ActiveX0bject("Msxml2.XMLHTTP"); //IE老版本

}
catch (e)
{ }
try {
var xmlHttp = new ActiveXObject("Microsoft.XMLHTTP"); //IE新版本

}
catch (e)
{ }
}
if (!xmlHttp) {
window.alert("不能创建XMLHttpRequest对象实例");
return false;
}
else
return xmlHttp;
////}///////花括号放错地方
}

// 检查账号,给出提示信息
function checkNumber(Number) {
var numberSpan = document.getElementById("numberSpan");

    if (Number.value == "") {
        numberSpan.innerHTML = "账号必须填写".fontcolor("red");
        return false;
    } else {

     xmlHttp = createXMLHttpRequest(); //createXMLHttpRequest申明的是局部变量,这里访问不到xmlHttp,要给xmlHttp变量赋值才行
    var url="servlet/CheckNumberServlet?number="+Number.value+"&LoginTime="+new Date().getTime(); 
    url = encodeURI(url);  //转换码后再传输 
    xmlHttp.open("GET",url,true);//加时间戳防止IE缓存
    //xmlhttp.setRequestHeader( "Content-Type", "text/html;charset=UTF-8" );
    xmlHttp.onreadystatechange = handleStateChange1;
    xmlHttp.send(null);
    return true;
    }
}

function handleStateChange1() {
    var numberSpan = document.getElementById("numberSpan");

    if (xmlHttp.readyState == 4) {
        if (xmlHttp.status == 200) {
           // alert("来自服务器的响应:"+xmlHttp.responseText);   
           if (xmlHttp.responseText == 'true') {///////responseText是字符串,不能和boolean变量直接比较
              // alert("存在");   
               numberSpan.innerHTML = "<img src='Img/g.gif'>";
                document.getElementById("feedback_info").innerHTML="";
                return true;
            }
            else if (xmlHttp.responseText == 'false') {///////responseText是字符串,不能和boolean变量直接比较
             // alert("不存在");   
                numberSpan.innerHTML = "账号不存在".fontcolor("red");
                return false;
            }

        }
        else alert("服务器端错误");
    }
}

// 检查密码,给出提示信息
function checkPsw(pswNode) {
var spanNode1 = document.getElementById("pswSpan");
var Role= document.getElementById("role");
var Number= document.getElementById("number");
if (pswNode.value == "") {
spanNode1.innerHTML = "密码必须填写".fontcolor("red");
return false;
} else {

         pwdSpan.innerHTML = "<img src='Img/g.gif'>";
        document.getElementById("feedback_info").innerHTML="";
        return true;
        }
    }

// 检查是否选中角色
function checkRole(selNode) {
    var index = selNode.selectedIndex;// 获得选中下标
    var spanNode1 = document.getElementById("roleSpan");
    if (index <= 0) {
        spanNode1.innerHTML = "必须选择角色".fontcolor("red");
        return false;
    } else {
        spanNode1.innerHTML = "<img src='Img/g.gif'>";
        document.getElementById("feedback_info").innerHTML="";
        return true;
    }
}
// 检查表单
function checkLogin(o) {

    var Role=o.role;
    var Number= o.number;
    var Pwd= o.pwd;
    if(checkNumber(Number)&&checkPsw(Psw) &&checkRole(Role))
        {
     xmlHttp = createXMLHttpRequest(); //createXMLHttpRequest申明的是局部变量,这里访问不到xmlHttp,要给xmlHttp变量赋值才行
    var url="servlet/CheckLoginServlet?number="+Number.value+"&role="+Role.value+"&pwd="+Pwd.value+"&LoginTime="+new Date().getTime(); 
    url = encodeURI(url);  //转换码后再传输 
    xmlHttp.open("GET",url,true);//加时间戳防止IE缓存
    //xmlhttp.setRequestHeader( "Content-Type", "text/html;charset=UTF-8" );
    xmlHttp.onreadystatechange = handleStateChange2;
    xmlHttp.send(null);
    return true;
        }
    else{
        document.getElementById("feedback_info").innerHTML="请填写每一项".fontcolor("red");
        return false;
    }
}
function handleStateChange2() {
    if (xmlHttp.readyState == 4) {
        if (xmlHttp.status == 200) {
           //alert("来自服务器的响应:" + xmlHttp.responseText);   
            if(xmlHttp.responseText == '0'){
                document.getElementById("feedback_info").innerHTML="账号与密码不匹配".fontcolor("red");
                return false;
            }
            else if(xmlHttp.responseText == '1'){

                document.getElementById("feedback_info").innerHTML="";
                window.location.href="index.jsp";
                return true;
            }
        }
        else alert("服务器端错误");
    }
}[/code]

chuckLoginservlet
[code="java"]public void doGet(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {
    response.setContentType("text/html");
    doPost(request, response);// 调用doPost方法
}

public void doPost(HttpServletRequest request, HttpServletResponse response)
        throws ServletException, IOException {
    request.setCharacterEncoding("utf-8");
    response.setContentType("text/html;charset=UTF-8");

    String number="";
    try {
        number = new String(request.getParameter("number").getBytes(
                "ISO-8859-1"), "UTF-8");
    } catch (Exception e1) {
        System.out.println("number为空");
    }

    String role="0";
    int rID=0;
    try {
        role = new String(request.getParameter("role").getBytes(
                "ISO-8859-1"), "UTF-8");
        rID=Integer.parseInt(role);//把获得的role的值转成整型
    } catch (Exception e1) {
        System.out.println(request.getParameter("role")+"******role");
    }

    String pwd="";
    try {
        pwd = new String(request.getParameter("pwd").getBytes(
                "ISO-8859-1"), "UTF-8");
    } catch (Exception e) {

     System.out.println(request.getParameter("pwd")+"****pwd");
    }
    // String txt = new String(number.getBytes("ISO-8859-1"), "UTF-8");
    // System.out.println(txt+"********");
    PrintWriter out = response.getWriter();
    User u = new User();
    UserDao ud = new UserDaoImpl();
    u = ud.findUserByNumber(number);//通过账号找到用户对象

    if (u != null) {// 找到该用户

            int u_id = u.getU_id();// 获得该用户的ID
            UserRole ur = new UserRole();
            UserRoleDao urd = new UserRoleDaoImpl();
            ur = urd.findUserRoleByUserId(u_id);// 找到中间表UserRole的记录
            int r_id = ur.getRole().getR_id();// 由Userrole表找到Role表的相对应角色名称
            if (r_id==rID && u.getU_password().equals(pwd))// 如果数据中的角色和密码与之对应
            {
                out.write("1");//1表示验证通过
            } else {
                out.write("0");//0表示密码与账号不匹配
            }

        }

    out.flush();
    out.close();
}[/code]

2个回答

checkLogin(this.form)"/> 这里是有问题的,知道this代表什么吗?它是代表input这个对象,而this.form就是代表input里面有一个 form这个属相的值,最关键是你的type="submit" 这个就是提交,而你的表单action都是空的,所以那里都没提交上去
你这里有四个错误

muyexia521
木叶下521 我的天!终于搞定啦!写错字母了!if(checkNumber(Num)&&checkPsw(Pwd) &&checkRole(Role))里的checkPsw(pwd)写成pws,哎!粗心大意害死人啊!谢谢您的帮助!太谢谢您啦!
6 年多之前 回复
jinandmei
jinbingchuan checkNumber你已经在失去焦点的时候进行了验证,就没必要再去验证了,其它2个是需要的额
6 年多之前 回复
jinandmei
jinbingchuan 那你可以把这个 checkPsw(pwd) &&checkRole(role))变为 var isPsw = checkPsw(pwd); var isRole = checkRole(role); if(isPsw &&isRole()){ }这样好调试,没问题后再合并
6 年多之前 回复
muyexia521
木叶下521 在提交时三个都验证是为了防止用户没输入任何东西都提交的情况发生,我觉得不能去吧?
6 年多之前 回复
jinandmei
jinbingchuan 我看你的checkNumber这个方法已经在失去焦点进行了验证,提交的时候就不需要了,把这个方法去掉
6 年多之前 回复
muyexia521
木叶下521 走到f(checkNumber(num)&&checkPsw(pwd) &&checkRole(role)),然后检查checkNumber(),接着应该检查checkPsw(pwd)啊,可是没检查,就跳出啦
6 年多之前 回复
jinandmei
jinbingchuan 还有就是点击登录的时候,不要去用ajax去验证,因为它是异步的,也就是说你的代码可能已经结束了,但是你后台还没还回数据,这个是初期很多人出现的问题
6 年多之前 回复
jinandmei
jinbingchuan 嗯,是的,我看错了,这个时候最好的办法是打开 debug,看走到哪里了
6 年多之前 回复
jinandmei
jinbingchuan var Role=document.getElementById("role"); var Number=document.getElementById("number"); var Pwd=document.getElementById("pwd"); 其它地方也需要改呀 if(checkNumber(Number)&&checkPsw(Psw) &&checkRole(Role)) 这里改了吗 你上面获得是对象,并且Number这个是js的内置数字对象,不要使用,另外改个名字最好 可以改为 var roleValue=document.getElementById("role").value; var num=document.getElementById("number").value; var pwd=document.getElementById("pwd").value; 然后 if(checkNumber(num)&&checkPsw(pwd) &&checkRole(roleValue)) 所以都需要修改呀,还有可能其它地方也需要修改,注意下
6 年多之前 回复
muyexia521
木叶下521 恩恩!那是!牛人啊!我都看到在好几个帖子都有您的身影!唔!还有点小问题,我把 checkLogin(this.form)那句改为 <input type="button" value="登录" onclick="checkLogin()"/>,在js文件里改为: function checkLogin() { var Role=document.getElementById("role"); var Number=document.getElementById("number"); var Pwd=document.getElementById("pwd"); 还是不反应,您看怎么办呢?
6 年多之前 回复
yunzhu666
yunzhu666 眼光真犀利,这么多代码里面直接抓住问题关键,顶一个
6 年多之前 回复
jinandmei
jinbingchuan 1 this.form不对 2 上面不对,checkLogin里面肯定也是不对的。 3 提交type="submit" 改为button 4 所有验证通过可以动态document.forms[0].submit()这样动态修改表单让它提交
6 年多之前 回复

[code="java"] var Role=document.getElementById("role");
var Number=document.getElementById("number");
var Pwd=document.getElementById("pwd");
其它地方也需要改呀
if(checkNumber(Number)&&checkPsw(Psw) &&checkRole(Role)) 这里改了吗
你上面获得是对象,并且Number这个是js的内置数字对象,不要使用,另外改个名字最好
可以改为

var roleValue=document.getElementById("role").value;
var num=document.getElementById("number").value;
var pwd=document.getElementById("pwd").value;

然后

if(checkNumber(num)&&checkPsw(pwd) &&checkRole(roleValue))

所以都需要修改呀,还有可能其它地方也需要修改,注意下
[/code]

muyexia521
木叶下521 大哥啊!您说的不对吧!checkNumber()接受的是对象啊。不是值啊。
6 年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
JSp+ajax用户登录验证
[img]http://dl2.iteye.com/upload/attachment/0088/2001/4ee085e5-47e0-3995-ad42-62e4a53cfc2f.png[/img] 用户登陆界面,想要实现输入账号之后离开输入框就验证该账号是否存在,输入角色、账号、密码之后,点击登录,如果正确就跳转到index.jsp,错误不跳转并且在密码输入框下显示提示信息;有一个没输入就提示,信息也是在密码输入框下。 我现在的问题是:若果什么也不输,点击登录,会闪一下,但闪过之后就是重置了页面。输入正确也是闪一下就重置页面.账号验证没问题,就是登录有问题,但是搞不定,大侠们看看吧! login.jsp [code="java"]<form id="form" name="form" method="post" action="" > <table border="0"> <tr> <td align="right">角色类型:</td> <td><select name="role" id="role" onBlur="checkRole(this)"> <option value="0">-请选择角色-</option> <% List<Role> list = new ArrayList<Role>(); RoleDao dao = new RoleDaoImpl(); list = dao.findAllRoles();//调用实现类的查询全部方法 for (int i = 0; i < list.size(); i++) { Role r = list.get(i); %> <option value="<%=r.getR_id()%>"><%=r.getR_name()%></option> <% } %> </select> </td> <td align="left"> &nbsp; <span id="roleSpan"></span> </td> </tr> <tr> <td align="right">账号:</td> <td> <input type="text" name="number" id="number" onblur="checkNumber(this)"> </td> <td width="256" align="left"> &nbsp; <span id="numberSpan"></span> </td> </tr><!-- 当输入名字后离开输入框即调用--> <tr> <td align="right">密码:</td> <td><input type="password" name="pwd" id="pwd" onBlur="checkPsw(this)" > </td> <td align="left"> &nbsp; <span id="pwdSpan"></span> </td> </tr> <tr> <td align="left">&nbsp;<span id="feedback_info"></span></td> </tr> <tr> <td colspan="1"> <input type="submit" value="登录" onclick="checkLogin(this.form)"/> <input type="button" value="注册" onclick="javascript:window.location.href='User/Register.jsp'"></td> </tr> </table> </form>[/code] login.js [code="java"]var xmlHttp; function createXMLHttpRequest() { if (window.XMLHttpRequest) { var xmlHttp = new XMLHttpRequest(); //mozilla浏览器 } else if (window.ActiveXObject) { try { var xmlHttp = new ActiveX0bject("Msxml2.XMLHTTP"); //IE老版本 } catch (e) { } try { var xmlHttp = new ActiveXObject("Microsoft.XMLHTTP"); //IE新版本 } catch (e) { } } if (!xmlHttp) { window.alert("不能创建XMLHttpRequest对象实例"); return false; } else return xmlHttp; ////}///////花括号放错地方 } // 检查账号,给出提示信息 function checkNumber(Number) { var numberSpan = document.getElementById("numberSpan"); if (Number.value == "") { numberSpan.innerHTML = "账号必须填写".fontcolor("red"); return false; } else { xmlHttp = createXMLHttpRequest(); //createXMLHttpRequest申明的是局部变量,这里访问不到xmlHttp,要给xmlHttp变量赋值才行 var url="servlet/CheckNumberServlet?number="+Number.value+"&LoginTime="+new Date().getTime(); url = encodeURI(url); //转换码后再传输 xmlHttp.open("GET",url,true);//加时间戳防止IE缓存 //xmlhttp.setRequestHeader( "Content-Type", "text/html;charset=UTF-8" ); xmlHttp.onreadystatechange = handleStateChange1; xmlHttp.send(null); return true; } } function handleStateChange1() { var numberSpan = document.getElementById("numberSpan"); if (xmlHttp.readyState == 4) { if (xmlHttp.status == 200) { // alert("来自服务器的响应:"+xmlHttp.responseText); if (xmlHttp.responseText == 'true') {///////responseText是字符串,不能和boolean变量直接比较 // alert("存在"); numberSpan.innerHTML = "<img src='Img/g.gif'>"; document.getElementById("feedback_info").innerHTML=""; return true; } else if (xmlHttp.responseText == 'false') {///////responseText是字符串,不能和boolean变量直接比较 // alert("不存在"); numberSpan.innerHTML = "账号不存在".fontcolor("red"); return false; } } else alert("服务器端错误"); } } // 检查密码,给出提示信息 function checkPsw(pswNode) { var spanNode1 = document.getElementById("pswSpan"); var Role= document.getElementById("role"); var Number= document.getElementById("number"); if (pswNode.value == "") { spanNode1.innerHTML = "密码必须填写".fontcolor("red"); return false; } else { pwdSpan.innerHTML = "<img src='Img/g.gif'>"; document.getElementById("feedback_info").innerHTML=""; return true; } } // 检查是否选中角色 function checkRole(selNode) { var index = selNode.selectedIndex;// 获得选中下标 var spanNode1 = document.getElementById("roleSpan"); if (index <= 0) { spanNode1.innerHTML = "必须选择角色".fontcolor("red"); return false; } else { spanNode1.innerHTML = "<img src='Img/g.gif'>"; document.getElementById("feedback_info").innerHTML=""; return true; } } // 检查表单 function checkLogin(o) { var Role=o.role; var Number= o.number; var Pwd= o.pwd; if(checkNumber(Number)&&checkPsw(Psw) &&checkRole(Role)) { xmlHttp = createXMLHttpRequest(); //createXMLHttpRequest申明的是局部变量,这里访问不到xmlHttp,要给xmlHttp变量赋值才行 var url="servlet/CheckLoginServlet?number="+Number.value+"&role="+Role.value+"&pwd="+Pwd.value+"&LoginTime="+new Date().getTime(); url = encodeURI(url); //转换码后再传输 xmlHttp.open("GET",url,true);//加时间戳防止IE缓存 //xmlhttp.setRequestHeader( "Content-Type", "text/html;charset=UTF-8" ); xmlHttp.onreadystatechange = handleStateChange2; xmlHttp.send(null); return true; } else{ document.getElementById("feedback_info").innerHTML="请填写每一项".fontcolor("red"); return false; } } function handleStateChange2() { if (xmlHttp.readyState == 4) { if (xmlHttp.status == 200) { //alert("来自服务器的响应:" + xmlHttp.responseText); if(xmlHttp.responseText == '0'){ document.getElementById("feedback_info").innerHTML="账号与密码不匹配".fontcolor("red"); return false; } else if(xmlHttp.responseText == '1'){ document.getElementById("feedback_info").innerHTML=""; window.location.href="index.jsp"; return true; } } else alert("服务器端错误"); } }[/code] chuckLoginservlet [code="java"]public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html"); doPost(request, response);// 调用doPost方法 } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { request.setCharacterEncoding("utf-8"); response.setContentType("text/html;charset=UTF-8"); String number=""; try { number = new String(request.getParameter("number").getBytes( "ISO-8859-1"), "UTF-8"); } catch (Exception e1) { System.out.println("number为空"); } String role="0"; int rID=0; try { role = new String(request.getParameter("role").getBytes( "ISO-8859-1"), "UTF-8"); rID=Integer.parseInt(role);//把获得的role的值转成整型 } catch (Exception e1) { System.out.println(request.getParameter("role")+"******role"); } String pwd=""; try { pwd = new String(request.getParameter("pwd").getBytes( "ISO-8859-1"), "UTF-8"); } catch (Exception e) { System.out.println(request.getParameter("pwd")+"****pwd"); } // String txt = new String(number.getBytes("ISO-8859-1"), "UTF-8"); // System.out.println(txt+"********"); PrintWriter out = response.getWriter(); User u = new User(); UserDao ud = new UserDaoImpl(); u = ud.findUserByNumber(number);//通过账号找到用户对象 if (u != null) {// 找到该用户 int u_id = u.getU_id();// 获得该用户的ID UserRole ur = new UserRole(); UserRoleDao urd = new UserRoleDaoImpl(); ur = urd.findUserRoleByUserId(u_id);// 找到中间表UserRole的记录 int r_id = ur.getRole().getR_id();// 由Userrole表找到Role表的相对应角色名称 if (r_id==rID && u.getU_password().equals(pwd))// 如果数据中的角色和密码与之对应 { out.write("1");//1表示验证通过 } else { out.write("0");//0表示密码与账号不匹配 } } out.flush(); out.close(); }[/code]
AJAX+jsp无刷新验证码实例
AJAX+jsp无刷新验证码实例
ajax请求提交到controller,页面404提示找不到jsp
用layui写的一个登陆表单,想在Ajax中验证,然后通过ajax的回调函数跳转到查全部的Controller,我登录的controller返回的是一个map,页面为什么报错找不到jsp,但是我后台确实得到了前台传过来的登录信息 **提交按钮** ![图片说明](https://img-ask.csdn.net/upload/201908/28/1566958559_704708.png) **前台** ![图片说明](https://img-ask.csdn.net/upload/201908/28/1566958584_464006.png) **后台** ![图片说明](https://img-ask.csdn.net/upload/201908/28/1566958606_79447.png) **报错** ![图片说明](https://img-ask.csdn.net/upload/201908/28/1566958630_204160.png) 在这里插入图片描述已经阻止表单提交了,还是不行,来个大佬救救孩子叭
关于权限验证在前端ajax的提示如何实现
mvc做了个拦截器,对每个页面的链接都做了权限验证,如果没有权限的跳到一个提示没有权限的页面,这块目前是可以实现的,但jsp页面上还有很多ajax的请求。这些请求被拦截后该如何在当前页面上提示,比如跳个提示框弹出没有权限的提示之类的。虽然想想可以在每个ajax请求连接中做权限验证,判断如果false直接在ajax回调中输出提示框权限验证失败,但这么一来似乎每个ajax请求中都要去加这么一段方法。这个方法不是很高效,也不适合维护管理,如果通过再做个拦截器专门对所有ajax连接做拦截,但又不知道该如何甄别哪些连接请求。请教有没有更好的思路可以对所有ajax的返回做拦截提示的?谢谢
java编写验证码验证问题。
使用mycelipse+tomcat编写网站,验证码生成正常,但是到了验证码验证环节,需要对用户输入的验证码验证,我想的是把验证码传到JSP页面,在servlet生成session传验证码,但是貌似是JSP比serclet先运行,所以取到的总是上一个值,从jsp写生成session,servlet能取到验证码(文字),但是JSP取不到。后来想到用ajax,但是那个验证码的值取到的是一直变的,困扰我两天了,希望高手帮帮我,我是刚毕业的大学生,动的比较少,希望您在解答的时候能介绍的详细些,最好能给出代码。
当OpenSessionInView 遇到Ajax
<p><span style="background-color: #888888;">OpenSessionInView</span> 把Hibernate的Session 带到了页面,解决了Hibernate 实体加载lazy问题。<br><br>我有一实际问题,标准使用是:<span style="background-color: #ffff00;">Jsp-&gt;Struts2 Action-&gt;JSP</span>,问题是现在页面使用AJAX验证,比如Jquery Validate Eng...,当所有验证都通过提交到Action,Action继续后台验证,最后Action不返回任何<span style="background-color: #ff00ff;">Result(return null)</span>,而返回Ajax验证需要的<span style="background-color: #ff00ff;">JSON</span>数据,利用JSP页面的AJAX验证框架跳转。<br><br>这样却无法实现OpenSessionInView.JSP得不到关联实体的属性。<br><br>流程是这样的:<br><span style="background-color: #ffff00;">JSP(1)-&gt;Action-&gt;JSP(1)-&gt;其他JSP (用户点击一次执行的操作),在 "其他JSP" 有使用lazy的实体对象属性。</span><br><br>是否是因为不再同一个request中了,而无法实现OpenSessionInView.</p> <p> </p>
ajax如何实现页面跳转
当我用AJAX像服务器发送一个登录请求后,服务器验证数据是否正确,是则跳到另一个 页面,否则返回一个数据错误的信息给AJAX,页面不刷新。 当验证正确时我用的是servlet的 request.getRequestDispatcher("../index.jsp").forward(request, response);跳转方式 错误就直接out.print();可是不管怎样都是跳到了那个请求页面 请问要怎样才能跳到另一个页面,还能带着数据过去 ajax代码 //声明XMLHttpRequest对象 var xmlrequest; //初始化XMLHttpRequest function createXMLHttpRequest(){ if(window.XMLHttpRequest){ xmlrequest = new XMLHttpRequest(); }else if(window.ActiveXObject){ try{ xmlrequest = new ActiveXObject("Msxml2.XMLHTTP"); }catch(e){ try{ xmlrequest = new ActiveXObject("Microsoft.XMLHTTP"); }catch(e){ } } } } //定义回调函数 function processResponse(){ //响应完成 if(xmlrequest.readyState == 4){ //响应正常 if(xmlrequest.status == 200){ var head = xmlrequest.responseText; alert(head); } } } servlet代码 public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { System.out.println("post被触发了"); request.setCharacterEncoding("UTF-8"); response.setContentType("text/html;charset=UTF-8"); String account = request.getParameter("account"); String password = request.getParameter("password"); if (account == "admin" & password == "admin"){ request.getRequestDispatcher("../index.jsp").forward(request, response); }else{ PrintWriter out = response.getWriter(); out.print("错误"); }
在jsp中添加数据时怎样验证重复?
在jsp页面中,有一个添加的表单,有几个文本框,在输入数据时,怎样验证输入的数据是否数据库中已经存在,如果有,提示一下。,求教,有代码最好
有关ajax与jsp交互的问题
1. 直接在js文件里通过ajax来获取服务器上listAll.jsp的结果( 封装好的字符串),形式如下: ....... xmlHttp.onreadystatechange = handleStateChange; xmlHttp.open("GET", "Json.txt", true); xmlHttp.send(null); ......... 2. listAll.jsp文件 [code] <%@page contentType="text/html; charset=UTF-8"%> <%@page import="org.springframework.context.ApplicationContext"%> <%@page import="org.springframework.context.support.ClassPathXmlApplicationContext"%> <%@page import="com.oasis.dao.ListUnitItemsDAO"%> <%@page import="com.oasis.dao.UnitItem"%> <%@page import="java.util.List"%> <%@page import="org.json.simple.JSONArray"%> <% request.setCharacterEncoding("UTF-8"); ApplicationContext context = new ClassPathXmlApplicationContext( "applicationContext.xml"); ListUnitItemsDAO listItems = (ListUnitItemsDAO) context.getBean("listUnitItemsDAO"); List<UnitItem> list = listItems.listAll(); JSONArray array = listItems.list2Json(list); out.print(array.toString()); out.flush(); %> [/code] 且该jsp的输出也已经验证,以及里面调用的各些业务方法也都没问题。。。 <b>我的问题是</b>:直接打开HTML文件(导入了该js文件),它能获取到jsp的输出结果么?如果不行(因为前台没显示出结果来),该怎样配置(jsp不用再在服务器或哪儿配置么?)
基于SSH框架的AJAX,在struts标签下验证id是否存在,或者使用JQuery和JSON
我在做一个简单的例子,对输入表单进行验证,因为在JSP页面中使用了struts的标签,现在在action名-方法名-validation.xml里进行的验证可以正常工作,但是在尝试利用ajax方式进行异步服务器端验证的时候遇到了困难,查了一些资料,说是struts2.1以后的版本中,不能再用struts标签进行ajax验证,而是要通过struts-dojo标签,而我找了几个这个版本的例子,发现实现的方式是在struts表单中加入onblur属性触发js函数,这样的话还何必使用struts标签的form呢?于是又找了一些不使用<s:form>表单的例子,用到了Jquery.js和json插件,但现在还有一些疑问如下. 1.<s:form>表单中能嵌套使用普通的html标签么?我尝试在<s:form>内部的<s:textfield>后加入<scan id="xxx">这样的标签发现没用,放到<s:form>外面则可以正常显示,那么如果在<s:form>内部想要实现异步验证显示不同的提示应该怎么实现呢? 2.针对一个<s:textfield>提交的内容 比如用户名或者ID这样在数据库中不允许重复的字段,是否只能用onblur="xx"这样的方式来进行失去焦点时进入xx这个js函数进行验证?我看的struts书中对struts2.0中可以通过设置<s:form>中 theme="ajax"来实现,那么相对应的struts2.1版本应该如何实现呢? 3.我又找了不用<s:form>标签的例子,是用jquery.js和json插件,但例子使用的输入只有一个<input>样式的,没有包含在<form>里 那么如果<form>有了提交的action 单独一行的输入如何执行自己单独要执行的验证action呢? 字打的比较多也比较乱,因为我的基础比较差,见谅.
使用ajax验证帐号是否重复,使用innerHTML在页面得不到信息
js代码: var xhr = getXhr(); function getXhr(){ var xhr = null; try { xhr = new XMLHttpRequest(); } catch (trymicrosoft) { try { xhr = new ActiveXObject("Msxml2.XMLHTTP"); } catch (othermicrosoft) { try { xhr = new ActiveXObject("Microsoft.XMLHTTP"); } catch (failed) { xhr = false; } } } if (!xhr) { alert("err Happend!"); } return xhr; } function check() { var user = document.getElementById("user").value; var url = "RegisterServlet?id=" + user; if (xhr.readyState == 4 && xhr.status == 200) { var str = xhr.responseText; if (str=="OK") { document.getElementById("checkname").innerHTML="用户名可用"; } else { doucument.getElementById("checkname").innerHTML="用户名重复"; } } xhr.open('get',url,true); xhr.send(null); } 前端代码: ![图片说明](https://img-ask.csdn.net/upload/201601/01/1451624017_737138.png) servlet代码: public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html"); request.setCharacterEncoding("UTF-8"); response.setCharacterEncoding("utf-8"); PrintWriter out=response.getWriter(); String username=request.getParameter("id"); System.out.println(username); if(username.equals("1")){ out.println("OK"); }else { out.println("NO"); } } 我测试用户名输入是否为1来判断,从servlet传值过来,但是在jsp里面span标签那显示不出来信息, 测试显示这个错误: ReferenceError: doucument is not defined,报错行数在js的if判断innerhtml行 各位大大帮忙看看
关于ajax异步表单校验的问题
登录的jsp页面上有两个form,分别对应邮箱注册和手机号注册两个标签页下的表单,我现在已经完成了ajax的表单校验,在测试的时候出现了这种情况: 在手机号注册的标签页下的手机号<input>中填写了手机号,但点击邮箱注册的标签依旧会检验这个手机号是否可以注册。甚至于我只把光标移动到了手机号<input>框里面什么都不填,点击邮箱注册的标签依旧会验证。 我想实现的效果是两个标签页互不影响,这个是不是在js代码里实现?怎么实现呢?
jquery ajax 上传文件 后台取不到file
正在做一个文件上传的程序,在上传之前需要验证文件的大小,不能超过10M,我采用的是jquery ajax的方式提交到后台Action,由后台Action判断文件大小。 首先看jsp页面: <form name="upload" method="post" enctype="multipart/form-data" action="publish/publish_upload.action" > <span> <s:text name="publish.content"/> <input type="file" name="file" id="uploadfile" onchange="checkFileSize()"> <font size="2" id="xx" color="blue" style="margin-left:30px; ">上传的文件不得大于10M</font> 。。。。省略部分.... </form> javascript代码: function checkFileSize() { var uploadfile = jq("#uploadfile"); var returnval = false; if(uploadfile.val()==""){ alert("请选择需要上传的文件"); return false; } var formData = new FormData(); formData.append("userfile",jq("#uploadfile")); var url = "ajax/ajax_checkFileSize.action"; jq.ajax({ type: "POST", url: url, async: false, enctype: 'multipart/form-data', data: formData, cache: false, contentType: false, processData: false, success: function (msg) { if(msg=="0"){ jq("#checkfile").text(""); alert("上传文件"+uploadfile.val()+"大于10M"); returnval = false; }else{ jq("#checkfile").text("文件可以上传"); jq("#checkfile").reset(); returnval = true; } } }); return returnval; } ajax后台判断也很简单: public String checkFileSize() throws IOException{ out = response.getWriter(); String message=""; try { response.setCharacterEncoding("utf-8"); double size = (double)file.length()/1048576; if(size>10){ message = "0"; }else{ message = "1"; } } catch (Exception e) { e.printStackTrace(); message="0"; }finally{ out.write(message); out.flush(); out.close(); } return null; } 但是每次都在double size = (double)file.length()/1048576;这里报空指针异常 请大家帮忙看看!
ajax返回500 (Internal Server Error)的问题
源码如下: $(function(){ $.validator.setDefaults({ submitHandler: function() { //表单验证成功并提交时执行 butsub(); } }); $("#submit_form_zzjs").validate(); var flag=true; function butsub(){ var formData = new FormData($("#submit_form_zzjs")[0]); if(flag){ $.ajax({ url: 'publish_server_chose.jsp', type: "POST", data: formData, cache: false, processData: false, contentType: false, beforeSend: function(){ flag=false; //防止发送两次请求 }, success: function (data) { flag = true; alert("发布成功!"); parent.location.href='personal_center_server.jsp'; }, error:function(){ alert("请先入驻实验室!"); } }); } } }); publish_server_chose.jsp: System.out.println("开始处理..."); String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; String trid=request.getSession().getAttribute("trid").toString(); if("".equals(trid)){ response.sendRedirect("login.jsp"); } int user_trid=Integer.parseInt(trid); System.out.println(user_trid); ci.adp.Table table = ci.adp.Table.getInstance("UT_JCW_SERVE"); DataRow row_one=Table.getInstance("ut_jcw_facilitor").queryDataRow("USERID="+user_trid+" AND PUBSTATE='已发布'"); DataRow row_two=table.newDataRow(); row_two.setValue("SSCID", row_one.getValueInt("TRID")); row_two.setValue("STATE", "正在审核"); row_two.setValue("ISDELETE", "否"); String message=""; //生成文件保存目录 String savePath = getServletConfig().getServletContext() .getRealPath("upload_publish"); //上传时生成的临时文件保存目录 String tempPath = getServletConfig().getServletContext() .getRealPath("temp_publish"); SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM"); String ymd = sdf.format(new Date()); savePath += "/" + ymd + ""; //创建文件夹 File dirFile = new File(savePath); if (!dirFile.exists()) { dirFile.mkdirs(); } tempPath += "/" + ymd + ""; //创建临时文件夹 File dirTempFile = new File(tempPath); if (!dirTempFile.exists()) { dirTempFile.mkdirs(); } //创建一个DiskFileItemFactory工厂,文件解析 DiskFileItemFactory factory = new DiskFileItemFactory(); factory.setSizeThreshold(20 * 1024 * 1024); //设定使用内存超过5M时,将产生临时文件并存储于临时目录中。 factory.setRepository(new File(tempPath)); //设定存储临时文件的目录。 ServletFileUpload upload = new ServletFileUpload(factory); upload.setHeaderEncoding("UTF-8"); upload.setFileSizeMax(1024 * 1024); // try { List<FileItem> items = upload.parseRequest(request); //获取formdata表单内容 for (FileItem item : items) { if (item.isFormField()) { //普通文本 String name = item.getFieldName(); String value = item.getString("UTF-8");//解决普通输入项的数据的中文乱码问题 if("bigclass".equals(name)){ row_two.setValue("DETAIL", value); }else if("smallclass_zzjs_net".equals(name)){ row_two.setValue("TYPEID", value); } row_two.setValue(name, value); System.out.println(name+"="+value); } else { //附件文件 if (item.getSize() > 0) { String filename = item.getName(); String fileFileName = item.getFieldName(); //获取name属性名称 if (filename.equals("")) { filename = "file"; } //获取文件名部分 filename = filename.substring(filename .lastIndexOf("\\") + 1); String fileExtName = filename.substring(filename .lastIndexOf(".")); System.out.println(filename); System.out.println(fileFileName); InputStream in = item.getInputStream(); String saveFilename = makeFileName(); saveFilename = URLEncoder.encode(saveFilename, "UTF-8"); //转码 //得到文件的保存目录 String realSavePath = makePath(saveFilename, savePath); String file_path = realSavePath + "" + saveFilename + fileExtName; file_path = file_path.replaceAll("\\\\", "/"); file_path=file_path.substring(file_path.indexOf("upload")); System.out.println(file_path); if ("IMAGE".equals(fileFileName)) { row_two.setValue("IMAGE", file_path); } //创建一个文件输出流 ,文件路径+生产的文件名.后缀 FileOutputStream out1 = new FileOutputStream( realSavePath + "" + saveFilename + fileExtName); //创建一个缓冲区 byte buffer[] = new byte[1024]; //判断输入流中的数据是否已经读完的标识 int len = 0; //循环将输入流读入到缓冲区当中,(len=in.read(buffer))>0就表示in里面还有数据 while ((len = in.read(buffer)) > 0) { //使用FileOutputStream输出流将缓冲区的数据写入到指定的目录(savePath + "\\" + filename)当中 out1.write(buffer, 0, len); } in.close(); out1.close(); message = "文件上传成功!"; } } } row_two.update(); JSONObject obj=new JSONObject(); obj.put("data",message ); out.println(obj); } catch (FileUploadBase.FileSizeLimitExceededException e) { response.getWriter().print("单个文件超出最大值!!!"); return; } catch (FileUploadBase.SizeLimitExceededException e) { e.printStackTrace(); response.getWriter().print("上传文件的总的大小超出限制的最大值!!!"); return; } catch (Exception e) { response.getWriter().print("文件上传失败!"); e.printStackTrace(); } 执行ajax,返回publish_server_chose.jsp 500 (Internal Server Error),已困扰一周时间,求大神点拨。
关于Ajax xmlhttp的问题
我想实现的功能是这样的,利用ajax的异步请求在提交表单之前实现对一个输入框中数据的验证,期待实现的效果是点击提交按钮,如果输入数据符合要求,就提交表单。但是现在实现的效果是点击提交按钮,在校验输入数据符合要求后,还需要再点击一次才能提交表单。 代码如下: jsp: < form action="formaction.action" method="post" onsubmit="return formsubmit()"> < input type="submit" value="提交表单">< /form> js: ``` function formsubmit(){ var xmlhttp; xmlhttp=ajaxfun(); var datavalue=document.getElementById("data").value; var url="datacheckaction?data="+datavalue+"&time="+(new Date().getTime()); xmlhttp.open("post",url,true); xmlhttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded"); xmlhttp.send(null); xmlhttp.onreadystatechange=function(){ if(xmlhttp.readyState==4 && xmlhttp.status==200){ document.getElementById("spandata").innerHTML=xmlhttp.responseText; } } } if(document.getElementById("spandata").innerHTML==""){ return true; }else{ return false; } } ``` 这个xmlhttp.responseText测试了没问题,数据校验通过是个"",校验不通过是个"wrong"。。。 用span和alert测试了几次,也有一些想法但是很快就都否定了,不知道问题在哪里。。。 忘记补充一点,有一个想法是这样的。。spandata这个地方在jsp页面上的初始值有,是"此项不可为空",我觉得最有可能的问题是formsubmit()这个函数的最后几行,判断spandata是否为空是在得到异步请求结果之前,应该是这样。。。但是不知道怎么解决
开发JSP项目只用JSP+javascript不行么?
各位大神,在下最近一直都在思考一个问题,问题就是: 开发JSP项目,只用X.jsp页面,以及页面上的javascript验证,最多再加上一些类以及方法行不行? 前一阵子忙的一个管理信息系统,我做的部分全是这样做的: A.jsp 负责显示、客户录入、录入检验 A.jsp submit 给 B.jsp B.jsp 负责接收数据、处理数据、数据库操作,然后返回A.jsp这种前台显示页面 录入检验中用到了javascript 数据处理中用到过自己定义的类和方法 为了客户体验现在正在考虑加上ajax 可是其他人不是这么做的,其他人从.jsp页面到severlet, 然后到action什么的.do什么的 来来回回实现的功能跟我的差不多啊,而且我的维护和更新更容易,直接更新.jsp页面就可以了,他们的还要配置web.xml,strut_config.xml等等 所以我开始疑惑了,既然实现的功能都是一样的,只用JSP + javascript + java的类和方法 不可以麽?为什么要引入struts 和 spring等等这些东西呢(我对这些不太懂)?
ajax 返回值问题
<script> function yanzheng() { var varify = document.getElementById("verify").value; var code = document.sendMail.code.value; var phone = document.sendMail.phone.value; var number = code+"_"+phone; var cellphone = document.sendMail.cellphone.value; var ajax=new AJAXRequest; ajax.get( "verify.jsp?verify="+varify+"&number="+number+"&cellphone="+cellphone+"&random="+Math.random(), function(obj) { alert(document.getElementById("returnAnswer").value=obj.responseText); //document.getElementById("returnAnswer").innerHTML=obj.responseText; //接受ajax返回的值 if((document.getElementById("returnAnswer").value=obj.responseText)==1){ document.sendMail.operate.value="sure_Click"; document.sendMail.submit(); } else{ document.getElementById("returnAnswer").innerHTML=obj.responseText; } } ); } </script> [code="java"][/code] <input type="button" value="立即呼叫" onclick="yanzheng()" /> <span id="returnAnswer"></span> verify.jsp页面代码: <html> <c:choose> <c:when test="${fn:length(param.number)==13 || fn:length(param.cellphone)==11 }"> <c:choose> <c:when test="${param.verify==sessionScope.rand}"> 1 </c:when> <c:otherwise> <c:out value="验证码错误" /> </c:otherwise> </c:choose> </c:when> <c:otherwise> <c:out value="固话/下灵通 或 移动电话输入错误" /> </c:otherwise> </c:choose> </html>[code="java"][/code] 问题: 我点击button按钮时,跳转到verify.jsp做验证 然后返回值后 判断是否跳转。 如果 verify.jsp 里 我不加<html></html> 则可以正常运行,但是加上之后 返回的值是"<html>1</html>" 如果页面还有其他代码的话 统统返回, 所以判断不成功,但是 在linux下 不加<html></html>的话,返回值是错误的,win 是可以的。 所以现在想 有什么办法 能让 加上<html>后,返回的值还是具体的“1” 而不是“<html>1</html>” 请各位指点一下
jquery的$.get()获取验证码的问题。
这是我们学校的门户登录页面[我是链接,戳我!](http://211.85.162.240:8080/cas/login ""),通过观察其页面代码的提交部分,其提交方式是原始表单。 ``` <script type="text/javascript"> function submitForm(){ var date = new Date(); var ajax_path = "./getVcode.jsp?timestamp="+date.getTime(); var flag = false; $.get(ajax_path , function(data){ var ajaxStr = data.toLowerCase(); ajaxStr = ajaxStr.replace(/\s+/g,""); ajaxStr = ajaxStr.replace(/\r\n/g,""); ajaxStr = ajaxStr.replace(/<\/?.+?>/g,""); var inputStr = $("#vcode").val().toLowerCase(); var username = $("#username").val(); var password = $("#password").val(); if(''==username){ $("#msg").html("请输入用户名!"); $("#username").trigger("focus"); return false; } if(''==password){ $("#msg").html("请输入密码!"); $("#password").trigger("focus"); return false; } if(''==inputStr){ $("#msg").html("请输入验证码!"); $("#vcode").trigger("focus"); return false; } if(ajaxStr==inputStr){ $("#fm1").submit(); }else{ $("#msg").html("验证码错误!"); $("#vcode").trigger("focus"); return false; } }); </script> ``` 知道了其验证码是客户端对比的(其实这样还不如没有),也就是说有可能通过直接访问脚本中的211.85.162.240:8080/cas/getVcode.jsp?timestamp=...来直接获得正确的验证码,确实,当我访问了一次http://211.85.162.240:8080/cas/getVerificationCode?dateTime=...获取验证码图片(这是必须的一步),再访问http://211.85.162.240:8080/cas/getVcode.jsp?timestamp=...是可以得到验证码的,而在文件中通过jquery的$.get()方法却获取不到验证码,这是我的代码: ``` <script src="Scripts/jquery-1.9.1.min.js"></script> <script> $(function () { var date = new Date(); $("#randpic").attr("src", "http://211.85.162.240:8080/cas/getVerificationCode?dateTime=" + date.getTime()); $("#get").click(function () { var ajax_path = "http://211.85.162.240:8080/cas/getVcode.jsp?timestamp=1453276786065"; $.get(ajax_path, function (data) { var ajaxStr = data.toLowerCase(); ajaxStr = ajaxStr.replace(/\s+/g, ""); ajaxStr = ajaxStr.replace(/\r\n/g, ""); ajaxStr = ajaxStr.replace(/<\/?.+?>/g, ""); $("#text").val(ajaxStr); }); }); }); </script> ``` 不是说地址栏输入和$.get()本质是一样吗?那么我该如何编写才能在js中获取到正确的验证码呢?
ssh项目页面url包含Action名时ajax上传文件返回错误500
本人正在做一个网站,暂时做到能够正常登录和注销,现在希望在已登录页面加一个文件上传功能。 目前该功能代码已经完成,在一般的jsp和html页面内都能正常使用,在该网站项目内虽然也能正常使用,但是在执行success后会跳出java.lang.nullpointerexception,无法回到原页面上。现已经确认后台代码没有问题,问题发生在action的return后。代码如下,这一方面的一些原理我的确还不是很懂,还请各位指点一二,谢谢。 1.jsp、html以及网站内jsp都是使用的这一段代码,前两者可用项目内的不可用 ``` <form id="myForm"> 选择Excel:<input type="file" name="input"> <button onclick="btn()">上传</button> </form> <script src="https://code.jquery.com/jquery-3.2.1.min.js"></script> <script type="text/javascript"> function btn(){ var formData = new FormData($("#myForm")[0]); $.ajax({ type : "post", url : "/Web_project/Fill/upload", data : formData, async: false, cache: false, contentType: false, processData: false, error: function (result) { alert('异常'); }, success: function (result) { if(result.error == ""){ alert("已上传"); }else{ alert("失败") } } }); } </script> ``` 2.upload.action对应的result ``` @Result(name="uploaded",type="json",params={"root","mm"}) ``` 3.jsp页面下的url和项目action跳转后的url,这是我发现的两者唯一区别,不知道是不是能证明什么问题 ![图片说明](https://img-ask.csdn.net/upload/201903/06/1551811215_326338.jpg) ![图片说明](https://img-ask.csdn.net/upload/201903/06/1551811226_117785.jpg) ******************** ************************************ 虽然不是很清楚原因,但是我个人认为是ajax提交了页面后,页面刷新,触发了登录用的action,再次检验用户登录,但是却没有取到数据,所以空指针。(个人猜测,没有详细了解) 我给action这段代码加了一个判断session是否为空,不为空则直接返回的代码段,这么一来在ajax提交页面后,action内验证登录的部分代码不会再次运行,页面也确实没有出现错误而是正常停留在原页面。 虽然没有能直接解决我的问题,但是很感谢各位的建议和帮助。
一个简单问题!$.ajax() 实现登陆!
# ajax **已经能够成功验证了** function checkUser(){ var username = $("#username").val(); var password = $("#password").val(); $.ajax({ type: "post", url: "logincheck", data: {"username":username,"password":password}, success:function(data){ location.href = "index.jsp"; } }); } # servlet String un = request.getParameter("username"); String pd = request.getParameter("password"); userCheck uc = new userCheck(); String res = uc.getUser(un,pd); if(!res.equals("userwrong") && !res.equals("passwordwrong")) { **request.getSession().setAttribute("username", res);**验证后的数据已经保存在session里了 } # html <%String username=(String)request.getSession().getAttribute("username"); if(username == null){ %> <input type="button" class="buttontype2" id="login" value="登录" onclick="checkUser();" 问题就是我需要重新刷新一下这个页面,才能进入if判断语句去读取session,我就是不知道如何刷新这个页面,在服务器重定位还是在ajax seccess回调函数进行刷新页面?求大神解答!
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
【JSON解析】浅谈JSONObject的使用
简介 在程序开发过程中,在参数传递,函数返回值等方面,越来越多的使用JSON。JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,同时也易于机器解析和生成、易于理解、阅读和撰写,而且Json采用完全独立于语言的文本格式,这使得Json成为理想的数据交换语言。 JSON建构于两种结构: “名称/值”对的集合(A Collection of name/va...
《MySQL 性能优化》之理解 MySQL 体系结构
本文介绍 MySQL 的体系结构,包括物理结构、逻辑结构以及插件式存储引擎。
程序员请照顾好自己,周末病魔差点一套带走我。
程序员在一个周末的时间,得了重病,差点当场去世,还好及时挽救回来了。
卸载 x 雷某度!GitHub 标星 1.5w+,从此我只用这款全能高速下载工具!
作者 | Rocky0429 来源 | Python空间 大家好,我是 Rocky0429,一个喜欢在网上收集各种资源的蒟蒻… 网上资源眼花缭乱,下载的方式也同样千奇百怪,比如 BT 下载,磁力链接,网盘资源等等等等,下个资源可真不容易,不一样的方式要用不同的下载软件,因此某比较有名的 x 雷和某度网盘成了我经常使用的工具。 作为一个没有钱的穷鬼,某度网盘几十 kb 的下载速度让我...
只因接了一个电话,程序员被骗 30 万!
今天想给大家说一个刚刚发生在我身边的一起真实的诈骗经历,我的朋友因此被骗走30万。注:为了保护当事人隐私,部分情节进行了修改。1平安夜突来的电话开始以为就像普通的诈骗一样,想办法让你把钱...
我一个37岁的程序员朋友
周末了,人一旦没有点事情干,心里就瞎想,而且跟几个老男人坐在一起,更容易瞎想,我自己现在也是 30 岁了,也是无时无刻在担心自己的职业生涯,担心丢掉工作没有收入,担心身体机能下降,担心突...
python自动下载图片
近日闲来无事,总有一种无形的力量萦绕在朕身边,让朕精神涣散,昏昏欲睡。 可是,像朕这么有职业操守的社畜怎么能在上班期间睡瞌睡呢,我不禁陷入了沉思。。。。 突然旁边的IOS同事问:‘嘿,兄弟,我发现一个网站的图片很有意思啊,能不能帮我保存下来提升我的开发灵感?’ 作为一个坚强的社畜怎么能说自己不行呢,当时朕就不假思索的答应:‘oh, It’s simple. Wait for me for a ...
一名大专同学的四个问题
【前言】   收到一封来信,赶上各种事情拖了几日,利用今天要放下工作的时机,做个回复。   2020年到了,就以这一封信,作为开年标志吧。 【正文】   您好,我是一名现在有很多困惑的大二学生。有一些问题想要向您请教。   先说一下我的基本情况,高考失利,不想复读,来到广州一所大专读计算机应用技术专业。学校是偏艺术类的,计算机专业没有实验室更不用说工作室了。而且学校的学风也不好。但我很想在计算机领...
复习一周,京东+百度一面,不小心都拿了Offer
京东和百度一面都问了啥,面试官百般刁难,可惜我全会。
Java 14 都快来了,为什么还有这么多人固守Java 8?
从Java 9开始,Java版本的发布就让人眼花缭乱了。每隔6个月,都会冒出一个新版本出来,Java 10 , Java 11, Java 12, Java 13, 到2020年3月份,...
达摩院十大科技趋势发布:2020 非同小可!
【CSDN编者按】1月2日,阿里巴巴发布《达摩院2020十大科技趋势》,十大科技趋势分别是:人工智能从感知智能向认知智能演进;计算存储一体化突破AI算力瓶颈;工业互联网的超融合;机器间大规模协作成为可能;模块化降低芯片设计门槛;规模化生产级区块链应用将走入大众;量子计算进入攻坚期;新材料推动半导体器件革新;保护数据隐私的AI技术将加速落地;云成为IT技术创新的中心 。 新的画卷,正在徐徐展开。...
轻松搭建基于 SpringBoot + Vue 的 Web 商城应用
首先介绍下在本文出现的几个比较重要的概念: 函数计算(Function Compute): 函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上传。函数计算准备计算资源,并以弹性伸缩的方式运行用户代码,而用户只需根据实际代码运行所消耗的资源进行付费。Fun: Fun 是一个用于支持 Serverless 应用部署的工具,能帮助您便捷地管理函数计算、API ...
Python+OpenCV实时图像处理
目录 1、导入库文件 2、设计GUI 3、调用摄像头 4、实时图像处理 4.1、阈值二值化 4.2、边缘检测 4.3、轮廓检测 4.4、高斯滤波 4.5、色彩转换 4.6、调节对比度 5、退出系统 初学OpenCV图像处理的小伙伴肯定对什么高斯函数、滤波处理、阈值二值化等特性非常头疼,这里给各位分享一个小项目,可通过摄像头实时动态查看各类图像处理的特点,也可对各位调参、测试...
2020年一线城市程序员工资大调查
人才需求 一线城市共发布岗位38115个,招聘120827人。 其中 beijing 22805 guangzhou 25081 shanghai 39614 shenzhen 33327 工资分布 2020年中国一线城市程序员的平均工资为16285元,工资中位数为14583元,其中95%的人的工资位于5000到20000元之间。 和往年数据比较: yea...
为什么猝死的都是程序员,基本上不见产品经理猝死呢?
相信大家时不时听到程序员猝死的消息,但是基本上听不到产品经理猝死的消息,这是为什么呢? 我们先百度搜一下:程序员猝死,出现将近700多万条搜索结果: 搜索一下:产品经理猝死,只有400万条的搜索结果,从搜索结果数量上来看,程序员猝死的搜索结果就比产品经理猝死的搜索结果高了一倍,而且从下图可以看到,首页里面的五条搜索结果,其实只有两条才是符合条件。 所以程序员猝死的概率真的比产品经理大,并不是错...
害怕面试被问HashMap?这一篇就搞定了!
声明:本文以jdk1.8为主! 搞定HashMap 作为一个Java从业者,面试的时候肯定会被问到过HashMap,因为对于HashMap来说,可以说是Java集合中的精髓了,如果你觉得自己对它掌握的还不够好,我想今天这篇文章会非常适合你,至少,看了今天这篇文章,以后不怕面试被问HashMap了 其实在我学习HashMap的过程中,我个人觉得HashMap还是挺复杂的,如果真的想把它搞得明明白...
毕业5年,我问遍了身边的大佬,总结了他们的学习方法
我问了身边10个大佬,总结了他们的学习方法,原来成功都是有迹可循的。
推荐10个堪称神器的学习网站
每天都会收到很多读者的私信,问我:“二哥,有什么推荐的学习网站吗?最近很浮躁,手头的一些网站都看烦了,想看看二哥这里有什么新鲜货。” 今天一早做了个恶梦,梦到被老板辞退了。虽然说在我们公司,只有我辞退老板的份,没有老板辞退我这一说,但是还是被吓得 4 点多都起来了。(主要是因为我掌握着公司所有的核心源码,哈哈哈) 既然 4 点多起来,就得好好利用起来。于是我就挑选了 10 个堪称神器的学习网站,推...
这些软件太强了,Windows必装!尤其程序员!
Windows可谓是大多数人的生产力工具,集娱乐办公于一体,虽然在程序员这个群体中都说苹果是信仰,但是大部分不都是从Windows过来的,而且现在依然有很多的程序员用Windows。 所以,今天我就把我私藏的Windows必装的软件分享给大家,如果有一个你没有用过甚至没有听过,那你就赚了????,这可都是提升你幸福感的高效率生产力工具哦! 走起!???? NO、1 ScreenToGif 屏幕,摄像头和白板...
阿里面试,面试官没想到一个ArrayList,我都能跟他扯半小时
我是真的没想到,面试官会这样问我ArrayList。
曾经优秀的人,怎么就突然不优秀了。
职场上有很多辛酸事,很多合伙人出局的故事,很多技术骨干被裁员的故事。说来模板都类似,曾经是名校毕业,曾经是优秀员工,曾经被领导表扬,曾经业绩突出,然而突然有一天,因为种种原因,被裁员了,...
大学四年因为知道了这32个网站,我成了别人眼中的大神!
依稀记得,毕业那天,我们导员发给我毕业证的时候对我说“你可是咱们系的风云人物啊”,哎呀,别提当时多开心啦????,嗯,我们导员是所有导员中最帅的一个,真的???? 不过,导员说的是实话,很多人都叫我大神的,为啥,因为我知道这32个网站啊,你说强不强????,这次是绝对的干货,看好啦,走起来! PS:每个网站都是学计算机混互联网必须知道的,真的牛杯,我就不过多介绍了,大家自行探索,觉得没用的,尽管留言吐槽吧???? 社...
良心推荐,我珍藏的一些Chrome插件
上次搬家的时候,发了一个朋友圈,附带的照片中不小心暴露了自己的 Chrome 浏览器插件之多,于是就有小伙伴评论说分享一下我觉得还不错的浏览器插件。 我下面就把我日常工作和学习中经常用到的一些 Chrome 浏览器插件分享给大家,随便一个都能提高你的“生活品质”和工作效率。 Markdown Here Markdown Here 可以让你更愉快的写邮件,由于支持 Markdown 直接转电子邮...
看完这篇HTTP,跟面试官扯皮就没问题了
我是一名程序员,我的主要编程语言是 Java,我更是一名 Web 开发人员,所以我必须要了解 HTTP,所以本篇文章就来带你从 HTTP 入门到进阶,看完让你有一种恍然大悟、醍醐灌顶的感觉。 最初在有网络之前,我们的电脑都是单机的,单机系统是孤立的,我还记得 05 年前那会儿家里有个电脑,想打电脑游戏还得两个人在一个电脑上玩儿,及其不方便。我就想为什么家里人不让上网,我的同学 xxx 家里有网,每...
史上最全的IDEA快捷键总结
现在Idea成了主流开发工具,这篇博客对其使用的快捷键做了总结,希望对大家的开发工作有所帮助。
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
谁是华为扫地僧?
是的,华为也有扫地僧!2020年2月11-12日,“养在深闺人不知”的华为2012实验室扫地僧们,将在华为开发者大会2020(Cloud)上,和大家见面。到时,你可以和扫地僧们,吃一个洋...
Idea 中最常用的10款插件(提高开发效率),一定要学会使用!
学习使用一些插件,可以提高开发效率。对于我们开发人员很有帮助。这篇博客介绍了开发中使用的插件。
AI 没让人类失业,搞 AI 的人先失业了
最近和几个 AI 领域的大佬闲聊 根据他们讲的消息和段子 改编出下面这个故事 如有雷同 都是巧合 1. 老王创业失败,被限制高消费 “这里写我跑路的消息实在太夸张了。” 王葱葱哼笑一下,把消息分享给群里。 阿杰也看了消息,笑了笑。在座几位也都笑了。 王葱葱是个有名的人物,21岁那年以全额奖学金进入 KMU 攻读人工智能博士,累计发表论文 40 余篇,个人技术博客更是成为深度学习领域内风向标。 ...
立即提问