`
cookieandsession
  • 浏览: 20297 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

服务器端表单检验(非检验框架实现)

    博客分类:
  • j2ee
 
阅读更多
public class RegisterForm {
	private String username;
	private String password;
	private String password2;
	private String email;
	private String birthday;
	private String nickname;
	
	private String client_checkcode;
	private String server_checkcode;
	
	private Map<String, String> errors = new HashMap<String, String>();

	
	//用户名不能为空,并且要是3-8位字母
	//密码不能为空,并且是3-8位数字
	//确认密码不能为空,并且要和一次一致
	//电子邮箱不能为空,并且要是一个格式合法的邮箱
	//生日可以为空,不为空时,必须要是一个日期
	//昵称不可以为空,并且要是汉字
	public boolean validate() {
		if (username == null || "".equals(username.trim())) {
			errors.put("username", "用户名不能为空");
			return false;
		} else {
			if (!username.matches("[a-zA-Z]{3,8}")) {
				errors.put("username", "用户名必须为3到8位字母");
				return false;
			}
		}
		
		if (password == null || "".equals(password.trim())) {
			errors.put("password", "密码不能为空");
			return false;
		} else {
			if(!password.matches("\\d{3,8}")) {
				errors.put("password", "密码必须为3到8位数字");
				return false;
			}
		}

		if (password2 == null || "".equals(password2.trim())) {
			errors.put("password2", "确认密码不能为空");
			return false;
		} else {
			if (!password2.equals(password)) {
				errors.put("password2", "两次密码必须一致");
				return false;
			}
		}
		
		if(email==null || "".equals(email.trim())) {
			errors.put("email", "邮箱不能为空");
			return false;
		} else {
			if(!email.matches("\\w+@\\w+[\\.\\w]+")) { //sabc@sina.com
				errors.put("email", "邮箱格式不正确");
				return false;
			}
		}
		
		if (birthday != null && !"".equals(birthday.trim())) {
			try {
				DateLocaleConverter dlc = new DateLocaleConverter();
				dlc.convert(birthday, "yyyy-MM-dd");
			} catch(Exception e) {
				errors.put("birthday", "日期格式不正确");
				return false;
			}
		}
		
		if (nickname == null || "".equals(nickname.trim())) {
			errors.put("nickname", "昵称不能为空");
			return false;
		} else {
			if (!nickname.matches("^([\u4e00-\u9fa5]+)$")) {
				errors.put("nickname", "昵称应为汉字");
				return false;
			}
		}
		
		if (client_checkcode == null || "".equals(client_checkcode.trim())) {
			errors.put("client_checkcode", "必须输入验证码");
			return false;
		} else {
			if (!server_checkcode.equals(client_checkcode)) {
				errors.put("client_checkcode", "验证码正确");
				return false;
			}
		}
		return true;
	}

	public String getUsername() {
		return username;
	}

	public void setUsername(String username) {
		this.username = username;
	}

	public String getPassword() {
		return password;
	}

	public void setPassword(String password) {
		this.password = password;
	}

	public String getPassword2() {
		return password2;
	}

	public void setPassword2(String password2) {
		this.password2 = password2;
	}

	public String getEmail() {
		return email;
	}

	public void setEmail(String email) {
		this.email = email;
	}

	public String getBirthday() {
		return birthday;
	}

	public void setBirthday(String birthday) {
		this.birthday = birthday;
	}

	public String getNickname() {
		return nickname;
	}

	public void setNickname(String nickname) {
		this.nickname = nickname;
	}
	
	public String getClient_checkcode() {
		return client_checkcode;
	}

	public void setClient_checkcode(String client_checkcode) {
		this.client_checkcode = client_checkcode;
	}

	public String getServer_checkcode() {
		return server_checkcode;
	}

	public void setServer_checkcode(String server_checkcode) {
		this.server_checkcode = server_checkcode;
	}

	public Map<String, String> getErrors() {
		return errors;
	}

	public void setErrors(Map<String, String> errors) {
		this.errors = errors;
	}
}
分享到:
评论

相关推荐

    java表单验证框架

    本框架以简洁、高效为特点,通过在表单字段上添加正则表达式标签,即可实现对用户提交信息的自动化验证。 在Java Web开发中,表单验证通常在前端和后端两部分进行。前端验证可以提供即时反馈,减少不必要的服务器...

    Yolov5目标检测web部署flask框架

    总之,"Yolov5目标检测web部署flask框架"项目结合了先进的目标检测技术与轻量级的Web开发框架,为用户提供了一种简单、高效的方法来实现在线实时目标检测。这个过程涉及到深度学习模型的训练、Flask应用的搭建、以及...

    MVC3 SERVER 服务器端页面检测

    在“MVC3 SERVER 服务器端页面检测”这个主题中,我们主要关注的是在服务器端进行的模型验证。在ASP.NET MVC3中,服务器端验证是非常关键的一部分,它确保了用户输入的数据在到达数据库之前是合法和安全的。这通常...

    Android客户端与服务器端通信Demo

    在Android应用开发中,客户端与服务器端的通信是不可或缺的一部分,它使得移动设备能够获取、发送数据,实现功能如登录注册、数据同步、文件上传下载等。本Demo着重展示了这一核心概念,通过实例来帮助开发者理解和...

    jQuery密码强度智能检测表单.zip

    在实际应用中,这个密码强度检测表单可能会与后端服务器配合,确保在提交表单时也进行服务器端验证。同时,为了提升用户体验,还可以添加一些额外的功能,例如显示密码复杂度的具体描述,或者提供一个“显示密码”...

    LiveValidation超好用的表单验证框架(包含中文帮助)

    对于不支持JavaScript的环境,应提供备用的服务器端验证。 7. **自定义验证**:通过扩展LiveValidation,可以创建新的验证方法以适应特定业务场景,如身份证号验证、邮政编码验证等。 在实际项目中,...

    ajax 检测用户名是否被占用

    - 在服务器端(假设是Node.js环境),我们需要创建对应的API来处理这个请求。比如使用Express框架: ```javascript const express = require('express'); const app = express(); const bodyParser = require('...

    检验是否符合条件 表单 登录 交验

    综上所述,"检验是否符合条件 表单 登录 交验"这一主题涵盖了从客户端到服务器端的整个表单验证流程,包括JavaScript的客户端验证,JSP的服务器端处理,以及在用户登录场景中的数据验证策略。这些都是Web开发中不可...

    yolov5在flask部署网页支持在线上传预测图片与视频功能以及摄像头检测功能

    总结,本项目结合了深度学习模型YOLOv5和Web开发框架Flask,实现了图片、视频上传预测以及摄像头实时检测的功能。通过优化前端和后端的交互,提供了直观的用户体验,展示了AI技术在实际应用中的强大潜力。在实际部署...

    原生Javascript开发让你的表单亮起来

    JavaScript可以实现客户端验证,减少服务器端的压力。通过正则表达式或自定义函数,我们可以检查输入是否符合特定格式,如邮箱、电话号码等,并实时向用户提供反馈。 三、动态添加与删除表单字段 JavaScript可以...

    万能表单验证

    在Web开发中,表单验证是必不可少的一环,因为它能够提高用户体验,防止无效或错误的数据提交到服务器,减少服务器端的压力,同时也能保护系统免受恶意攻击。 表单验证通常包括以下几个关键方面: 1. **基本验证**...

    表单验证的完整应用

    服务器端验证通常在接收到表单数据后进行,这一步是必须的,以确保数据安全: 1. 接收数据:使用如Node.js的`req.body`或PHP的`$_POST`接收POST请求中的表单数据。 2. 验证数据:对每个字段执行相应的验证函数,如...

    表单验证

    验证通常发生在客户端(浏览器端)和/或服务器端,以提高用户体验并增强数据安全。 二、客户端验证 1. JavaScript验证:JavaScript是最常用的语言进行客户端验证,它可以实时检测用户的输入,防止无效数据提交到...

    thinkphp3.2 防止表单重复提交

    2. 服务器端Session记录:在接收到表单请求后,服务器可以在Session中记录已处理的状态,当再次收到相同请求时,检查Session状态,若发现已处理过,则拒绝处理。 3. 客户端JavaScript控制:通过JavaScript监听表单...

    校验框架-Tomato-ValidationFramework-2.1

    此外,该框架还支持异步验证,例如检查用户名是否已存在或验证信用卡号的有效性,这些通常需要服务器端的配合。 jQuery的集成使得Tomato Validation Framework 2.1能够无缝地工作在大多数现代Web应用中。jQuery的...

    简单实用的Bootstrap3表单验证插件

    Bootstrap3 是一个流行的前端开发框架,它为开发者提供了丰富的组件和样式,...在实际应用中,根据具体项目的需求,你可能还需要进行一些定制和扩展,例如集成服务器端验证,或者添加更多的验证规则和错误处理逻辑。

    表单自动验证 javascript

    JavaScript作为一种客户端脚本语言,被广泛用于实现动态、实时的表单验证,以提升用户体验并减轻服务器端的压力。这篇博客“表单自动验证 JavaScript”探讨了如何利用JavaScript进行高效的表单验证。 首先,表单...

    java代码-检测表单劫持插件

    此项目包含一个简单的Java Servlet示例,用于演示如何在服务器端检测表单劫持。主要关注点在于数据签名验证和提交频率监控,这两个关键步骤可以帮助我们发现潜在的表单劫持行为。请根据实际应用环境调整代码,以适应...

    ExtAspNet框架

    框架还支持数据绑定,可以直接与服务器端的数据源进行交互,实现了数据的动态加载和更新,大大减少了开发者的编码工作量。 ExtAspNet框架的另一个亮点是其强大的布局管理机制。它允许开发者轻松创建复杂的页面布局...

Global site tag (gtag.js) - Google Analytics