使用javascript及servlet实现客户端和服务器端的表单验证

上海驾校

特点

客户端确认

         – 减少服务器负载
         – 缩短用户等待时间
         – 兼容性难

• 服务器端确认
         – 统一确认
         – 兼容性强

         – 服务器负载重

JavaScript实现客户端验证

<html>
	<head>
		<script type="text/javascript">
			function validate() {
				var userName = document.getElementById("userName1");
				var passWord = document.getElementById("passWord1");
				var repassWord = document.getElementById("repassWord1");
				if(userName.value == "") {
					alert("用户名不能不为空");
					return false;
				}
				if(passWord.value.length < 6 || passWord.value.length > 10){
					alert("密码必须符合规则");
					return false;
				}
				if(repassWord.value.length < 6 || repassWord.value.length > 10){
					alert("密码必须符合规则");
					return false;
				}
				if(passWord.value != repassWord.value){
					alert("密码前后不一致");
					return false;
				}
				return true;
			}
		</script>

	</head>

	<body>
		<form method="post" onsubmit="return validate()">
			userName:
			<input type="text" name="userName" id="userName1">
			<br>
			passWord:
			<input type="password" name="passWord" id="passWord1">
			<br>
			re-passWord:
			<input type="password" name="repassWord" id="repassWord1">
			<br>
			<input type="submit" value="提交">
		</form>
	</body>
</html>


但是客户端验证是不可靠的,如用户直接在浏览器输入栏输入:localhost:8080/temp/login.jsp/servlet?username=123&password=123

服务端验证

    public void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        String userName = request.getParameter("userName");
        String passWord = request.getParameter("passWord");
        String repassWord = request.getParameter("repassWord");
        List<String> list = new ArrayList<String>();
        if ("".equals(userName)) {
            list.add("用户名不能不为空");
        }
        if (passWord.length() < 6 || passWord.length() > 10) {
            list.add("密码必须符合规则");
        }
        if (repassWord.length() < 6 || repassWord.length() > 10) {
            list.add("密码必须符合规则");
        }
        if (passWord != null && repassWord != null
                && passWord.equals(repassWord)) {
            list.add("密码前后不一致");
        }
        if(list.isEmpty()){
            request.setAttribute("userName", userName);
            request.setAttribute("userName", passWord);
            request.getRequestDispatcher("失败的的jsp页面");
        }else{
            request.setAttribute("error", list);
        }
    }

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值