Struts2 官方教程:表单验证(Form Validation)

2024-05-25 17:08

本文主要是介绍Struts2 官方教程:表单验证(Form Validation),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本篇教程假设读者已经完成了《表单处理》教程的内容,并且拥有一个表单处理的项目。

介绍

在本教程中,我们将探索使用Struts2来验证用户在表单中的输入。读者可以使用两种方法让Struts2进行表单验证。本篇教程会讲解更为基础的方法,即验证过程放在Struts2的动作类之中。

添加验证方法

为了让Struts2 的动作类能够验证用户在Struts2 表单中的输入,读者必须在自己的动作类中定义一个validate方法。使用《表单处理》教程中的项目,现在假设项目要遵循以下业务逻辑:
1.用户必须提供一个名字(first name)
2.用户必须提供一个电子邮箱地址(email address)
3.年龄低于18岁的用户无法注册
如果回顾《表单处理》教程,用户在表单域的输入,被Struts2放置到Java模型类的实例personBean中。这样用户对firstName域的输入,回作为personBeans的firstName实例域的值(通过personBean.setFirstName方法)。
在validate方法中,我们可以通过使用合适的get方法,选择得到personBean实例域的值。一旦我们获得了值,我们可以按照逻辑来实行我们的业务逻辑。
添加下面的validate方法到Register
.java(动作类)中。

validate 方法
public void validate(){
if(personBean.getFirstName().length()==0){
addFieldError("personBean.firstName","必须提供名字。");}if(personBean.getEmail().length()==0){
addFieldError("personBean.email","必须提供电子邮箱地址。");
}if(personBean.getAge()<18){
addFieldError("personBean.age","亲,年龄必须至少为18岁哦,比心");
}
}

当用户点击注册表单上的提交按钮,Struts2回将用户的输入传送到personBeans的实例域。然后Struts2将自动地执行validate方法。如果任何validate中检查的情形发生了,Struts2会调用它的addFieldError方法(动作类从ActionSupport中继承的方法)。
如果出现了任何的错误,Struts2不会调用execute方法,Struts2框架会返回“input”作为调用动作的结果。

掌控被返回的Input

那么,如果Struts返回了表示用户在表单中输入无效的“input”,咋整啊?在大部分情况下,会希望重新展示表单的网页,并且包含表单错误的信息来提示用户准确的错误信息。
为了掌控“input”这个返回值,读者需要将以下内容添加到struts.xml的动作结点中。

<result name="input">/register.jsp</result>

以上的result结点放在register动作中,success的result结点之后、action结点关闭之前。

错误信息

当验证失败、Struts2返回了input,Struts2框架会重新展示register.jsp额面。因为我们使用Struts2表单标签,Struts2会自动地添加错误信息。这些错误信息是我们在addFieldError方法调用时指定的。addFieldError方法有两个参数:第一个是表单域的name、指示了错误发生的位置;第二个是要在表单域显示的错误信息。
那么,下面这个addFieldError方法:

addFieldError("personBean.firstName","必须提供名字。")

将会让信息“必须提供名字”显示在表单中的firstName域。
如果读者已经在《处理表单》教程的项目里应用了上述内容、或者从网络上下载了这个应用的源代码(译者注:动作真快啊大兄弟),那么点击“请注册”的链接;在注册表单,直接点击提交按钮,会看到如下的页面:Struts2调用了validate方法;验证失败,register.jsp带着错误信息们再度降临~撒花~
这里写图片描述

给错误信息们装扮样式

Struts2 的s:head标签可以被用来为错误信息提供包括了样式的CSS。把 s:head 添加 到register.jsp中的 head 结束标签之前。再搞一次前面的过程,将会看到有漂亮颜色的错误代码(译者注:然并卵)
这里写图片描述

总结

本篇教程讲解了:通过在动作类中添加一个validate方法,来验证用户在表单中的输入。另一个更加狂拽酷炫的验证用户输入的方法是使用XML。如果希望学习更多关于在Struts2中使用XML进行验证,就得看《验证(Validateon)》这个教程(但是还没翻译)。

下回预告

下篇教程回讲解,如何使用信息资源文件来从展示页面中分离文本。

这篇关于Struts2 官方教程:表单验证(Form Validation)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1002114

相关文章

android 免费短信验证功能

没有太复杂的使用的话,功能实现比较简单粗暴。 在www.mob.com网站中可以申请使用免费短信验证功能。 步骤: 1.注册登录。 2.选择“短信验证码SDK” 3.下载对应的sdk包,我这是选studio的。 4.从头像那进入后台并创建短信验证应用,获取到key跟secret 5.根据技术文档操作(initSDK方法写在setContentView上面) 6.关键:在有用到的Mo

Steam邮件推送内容有哪些?配置教程详解!

Steam邮件推送功能是否安全?如何个性化邮件推送内容? Steam作为全球最大的数字游戏分发平台之一,不仅提供了海量的游戏资源,还通过邮件推送为用户提供最新的游戏信息、促销活动和个性化推荐。AokSend将详细介绍Steam邮件推送的主要内容。 Steam邮件推送:促销优惠 每当平台举办大型促销活动,如夏季促销、冬季促销、黑色星期五等,用户都会收到邮件通知。这些邮件详细列出了打折游戏、

20170723 做的事 ecdsa的签名验证时间短于bls signature

1 今天在虚拟机 /home/smile/Desktop/20170610/Test//time_ecdsa 文件夹下,找到ecdsa的验证时间是 989.060606μs μs 先 make ,然后run。 再取BLS的签名生成时间: ./run  2  gnuplot 画图,画对比的时间 gnuplot 画图参考教程 http://blog.sciencen

X-AnyLabeling使用教程

1.AI 模型自动分割标注使用教程 2.AI 模型自动目标检测标注使用教程

DDS信号的发生器(验证篇)——FPGA学习笔记8

前言:第一部分详细讲解DDS核心框图,还请读者深入阅读第一部分,以便理解DDS核心思想 三刷小梅哥视频总结! 小梅哥https://www.corecourse.com/lander 一、DDS简介         DDS(Direct Digital Synthesizer)即数字合成器,是一种新型的频率合成技术,具有低成本、低功耗、高分辨率、频率转换时间短、相位连续性好等优点,对数字信

青龙面板2.9之Cdle傻妞机器人编译教程

看到有的朋友对傻妞机器人感兴趣,这里写一下傻妞机器人的编译教程。 第一步,这里以linux amd64为例,去官网下载安装go语言安装包: 第二步,输入下方指令 cd /usr/local && wget https://golang.google.cn/dl/go1.16.7.linux-amd64.tar.gz -O go1.16.7.linux-amd64.tar.gz

青龙面板部署通用教程,含服务器、路由器、X86等部署方法

1. 拉取镜像/更新镜像 docker pull whyour/qinglong:latest 2. 删除镜像 docker rmi whyour/qinglong:latest 3. 启动容器 普通服务器 docker run -dit \-v $PWD/ql/config:/ql/config \-v $PWD/ql/log:/ql/log \-v $PWD/ql/db:

宝塔面板部署青龙面板教程【简单易上手】

首先,你得有一台部署了宝塔面板的服务器(自己用本地电脑也可以)。 宝塔面板部署自行百度一下,很简单,这里就不走流程了,官网版本就可以,无需开心版。 首先,打开宝塔面板的软件商店,找到下图这个软件(Docker管理器)安装,青龙面板还是安装在docker里,这里依赖宝塔面板安装和管理docker。 安装完成后,进入SSH终端管理,输入代码安装青龙面板。ssh可以直接宝塔里操作,也可以安装ssh连接

PS系统教程25

介绍软件 BR(bridge) PS 配套软件,方便素材整理、管理素材 作用:起到桥梁作用 注意:PS和BR尽量保持版本一致 下载和安装可通过CSDN社区搜索,有免费安装指导。 安装之后,我们打开照片只需双击照片,就自动在Ps软件中打开。 前提:电脑上有PS软件 三种预览格式 全屏预览 评星级 直接按数字键就可以 方向键可以更换图片 esc退出 幻灯片放

flex布局学习笔记(flex布局教程)

前端笔试⾯试经常会问到:不定宽⾼如何⽔平垂直居中。最简单的实现⽅法就是flex布局,⽗元素加上如下代码即 可: display: flex; justify-content: center; align-items :center; 。下⾯详细介绍下flex布局吧。   2009年,W3C提出了 Flex布局,可以简便⼂完整⼂响应式地实现各种页⾯布局。⽬前已得到了所有浏览器的⽀持,这意味着,现