JSF消息标签验证和代码验证

本文介绍了一种使用JSF技术实现的登录界面验证方法。通过客户端JavaScript和服务器端验证相结合的方式,确保用户输入的有效性和安全性。文章展示了如何利用JSF标签进行输入验证,并通过Java代码实现了自定义验证逻辑。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 这是我学习JSF的一点总结:

我会给大家见绍三种类型的验证:

1.js

2.消息验证标签

3.validator

一、jsp页面:

大家可以参照我标注颜色的代码:

<%@ page language="java" pageEncoding="gb2312"%>
<%@ taglib uri="http://java.sun.com/jsf/html" prefix="h"%>
<%@ taglib uri="http://java.sun.com/jsf/core" prefix="f"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
 <head>
  <title>JSF 登录界面</title>
  <script language="JavaScript">
<!--
function CheckInformation()
{
 
 if (document.getElementById("loginForm:number").value==""){
  alert("学号不能为空!");
  return false;
 }
 
 if (document.getElementById("loginForm:pwd").value==""){
  alert("密码不能为空!");
  return false;
 } 
}
-->
</script>
 </head>
 <body>
  <f:view>
   <h:form id="loginForm">
    <h:panelGrid columns="3">
     <h:outputLabel for="number" value="姓名:"></h:outputLabel>
     <h:inputText id="number" required="true"
      value="#{loginBean.number}"  validator="#{loginBean.validate}"></h:inputText>
     <h:message for="number"></h:message>
     <h:outputLabel for="pwd" value="密码:"></h:outputLabel>
     <h:inputSecret id="pwd" required="true" value="#{loginBean.pwd}">
      <f:validator validatorId="passwordValidator"/>
     </h:inputSecret>
     <h:message for="pwd"></h:message>
    </h:panelGrid>
    <h:panelGrid columns="2">
     <h:commandButton value="登录" action="#{loginBean.login}" οnclick=" return CheckInformation()"/>
     <h:commandButton value="取消" type="reset" />
    </h:panelGrid>
   </h:form>
  </f:view>
 </body>
</html>

二、java关键代码

  ...

 public void validate(FacesContext context, UIComponent component, Object obj) throws ValidatorException {
  String number = (String) obj;
  if (number.length() < 2) {
   FacesMessage message = new FacesMessage(FacesMessage.SEVERITY_ERROR, "用户编号小于2", "用户编号小于2");
   throw new ValidatorException(message);
  }
  ...

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值