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 Web开发中,表单验证通常在前端和后端两部分进行。前端验证可以提供即时反馈,减少不必要的服务器...
总之,"Yolov5目标检测web部署flask框架"项目结合了先进的目标检测技术与轻量级的Web开发框架,为用户提供了一种简单、高效的方法来实现在线实时目标检测。这个过程涉及到深度学习模型的训练、Flask应用的搭建、以及...
在“MVC3 SERVER 服务器端页面检测”这个主题中,我们主要关注的是在服务器端进行的模型验证。在ASP.NET MVC3中,服务器端验证是非常关键的一部分,它确保了用户输入的数据在到达数据库之前是合法和安全的。这通常...
在Android应用开发中,客户端与服务器端的通信是不可或缺的一部分,它使得移动设备能够获取、发送数据,实现功能如登录注册、数据同步、文件上传下载等。本Demo着重展示了这一核心概念,通过实例来帮助开发者理解和...
在实际应用中,这个密码强度检测表单可能会与后端服务器配合,确保在提交表单时也进行服务器端验证。同时,为了提升用户体验,还可以添加一些额外的功能,例如显示密码复杂度的具体描述,或者提供一个“显示密码”...
对于不支持JavaScript的环境,应提供备用的服务器端验证。 7. **自定义验证**:通过扩展LiveValidation,可以创建新的验证方法以适应特定业务场景,如身份证号验证、邮政编码验证等。 在实际项目中,...
- 在服务器端(假设是Node.js环境),我们需要创建对应的API来处理这个请求。比如使用Express框架: ```javascript const express = require('express'); const app = express(); const bodyParser = require('...
综上所述,"检验是否符合条件 表单 登录 交验"这一主题涵盖了从客户端到服务器端的整个表单验证流程,包括JavaScript的客户端验证,JSP的服务器端处理,以及在用户登录场景中的数据验证策略。这些都是Web开发中不可...
总结,本项目结合了深度学习模型YOLOv5和Web开发框架Flask,实现了图片、视频上传预测以及摄像头实时检测的功能。通过优化前端和后端的交互,提供了直观的用户体验,展示了AI技术在实际应用中的强大潜力。在实际部署...
JavaScript可以实现客户端验证,减少服务器端的压力。通过正则表达式或自定义函数,我们可以检查输入是否符合特定格式,如邮箱、电话号码等,并实时向用户提供反馈。 三、动态添加与删除表单字段 JavaScript可以...
在Web开发中,表单验证是必不可少的一环,因为它能够提高用户体验,防止无效或错误的数据提交到服务器,减少服务器端的压力,同时也能保护系统免受恶意攻击。 表单验证通常包括以下几个关键方面: 1. **基本验证**...
服务器端验证通常在接收到表单数据后进行,这一步是必须的,以确保数据安全: 1. 接收数据:使用如Node.js的`req.body`或PHP的`$_POST`接收POST请求中的表单数据。 2. 验证数据:对每个字段执行相应的验证函数,如...
验证通常发生在客户端(浏览器端)和/或服务器端,以提高用户体验并增强数据安全。 二、客户端验证 1. JavaScript验证:JavaScript是最常用的语言进行客户端验证,它可以实时检测用户的输入,防止无效数据提交到...
2. 服务器端Session记录:在接收到表单请求后,服务器可以在Session中记录已处理的状态,当再次收到相同请求时,检查Session状态,若发现已处理过,则拒绝处理。 3. 客户端JavaScript控制:通过JavaScript监听表单...
此外,该框架还支持异步验证,例如检查用户名是否已存在或验证信用卡号的有效性,这些通常需要服务器端的配合。 jQuery的集成使得Tomato Validation Framework 2.1能够无缝地工作在大多数现代Web应用中。jQuery的...
Bootstrap3 是一个流行的前端开发框架,它为开发者提供了丰富的组件和样式,...在实际应用中,根据具体项目的需求,你可能还需要进行一些定制和扩展,例如集成服务器端验证,或者添加更多的验证规则和错误处理逻辑。
JavaScript作为一种客户端脚本语言,被广泛用于实现动态、实时的表单验证,以提升用户体验并减轻服务器端的压力。这篇博客“表单自动验证 JavaScript”探讨了如何利用JavaScript进行高效的表单验证。 首先,表单...
此项目包含一个简单的Java Servlet示例,用于演示如何在服务器端检测表单劫持。主要关注点在于数据签名验证和提交频率监控,这两个关键步骤可以帮助我们发现潜在的表单劫持行为。请根据实际应用环境调整代码,以适应...
框架还支持数据绑定,可以直接与服务器端的数据源进行交互,实现了数据的动态加载和更新,大大减少了开发者的编码工作量。 ExtAspNet框架的另一个亮点是其强大的布局管理机制。它允许开发者轻松创建复杂的页面布局...