struts2_自定义类型转换失败的提示信息

简介:   之前有一段时间,我老是把struts2的validate验证与类型转换混为一谈.最近才发现两者是两回事. 从拦截器配置不可以看来.找到struts-default.

  之前有一段时间,我老是把struts2的validate验证与类型转换混为一谈.最近才发现两者是两回事.

从拦截器配置不可以看来.找到struts-default.xml:发现如下代码:

 

<interceptor-stack name="defaultStack">
               <!--类型转换错误的拦截器 -->
                <interceptor-ref name="conversionError"/>
                <!--数据校验的拦截器 -->
                <interceptor-ref name="validation">
                    <param name="excludeMethods">input,back,cancel,browse</param>
                </interceptor-ref>
</interceptor-stack>

 如此,才知道.仅仅定义了validate验证的xml,仅仅只能解决验证问题.当类型转换失败时,只能执行默认的报错内容.

  为了了解如何自定义类型转换失败时的提醒内容.我做了一个简单的例子.

  首先,建一个struts2的project.如下图所示:

 定义action
public class Action1 extends ActionSupport {
	private int iCount;

	 public String execute() throws Exception {

	
		this.addActionMessage("提交成功!");
		return SUCCESS;

	}

	public int getICount() {
		return iCount;
	}

	public void setICount(int count) {
		iCount = count;
	}
}

 
定义验证xml:
    
<validators>
    <field name="iCount">
        <field-validator type="int" short-circuit="true">
        	<param name="min">0</param>
        	<param name="max">10</param>
            <message>输入的数据必须为整数,且范围是${min}到${10}之间</message>
        </field-validator>
    </field>
</validators>

 

  在浏览器地址栏中输入:http://127.0.0.1:9900/TestStrutsConvertor/result1.jsp

  运行结果如下所示:

  

     

  显然,我们的validate配置生效了,但类型转换却不在此范围内,无法在validate的xml配置.

  下面,给出自定义类型转换失败处理的配置.

  其实很简单,在Action1.java的所在包路径下,创建一个名为Action1,后缀为properties的文件.切记:文件名必须为Action1

  

       然后在Action1.properties中配置如下语句:

      invalid.fieldvalue.iCount=输入内容必须为整数

 

  再次在浏览器地址栏中输入:http://127.0.0.1:9900/TestStrutsConvertor/result1.jsp

  运行结果如下:

  

 

 如此,我们的目的就达到了.

 

  

相关文章
|
2天前
|
前端开发 Java UED
SpringMVC全局异常处理+拦截器使用+参数校验
通过使用 SpringMVC 的全局异常处理、拦截器和参数校验,可以有效提升 Web 应用程序的安全性、稳定性和用户体验。这些技术的合理应用,不仅可以保证代码的健壮性,还能提高代码的可维护性,为开发高质量的 Web 应用程序提供了坚实的基础。
16 6
|
5月前
|
Java Spring 容器
详解java参数校验之:顺序校验、自定义校验、分组校验(@Validated @GroupSequence)
详解java参数校验之:顺序校验、自定义校验、分组校验(@Validated @GroupSequence)
|
JSON 前端开发 Java
SpringMVC之JSON数据返回与异常处理机制---全方面讲解
SpringMVC之JSON数据返回与异常处理机制---全方面讲解
251 0
|
JSON 前端开发 Java
SpringBoot整合【全局异常处理+错误码枚举+JSR303校验】
本文介绍了如何使用Spring Boot整合全局异常处理、错误码枚举和JSR 303校验。全局异常处理通过@ControllerAdvice和@ExceptionHandler注解实现,提供了统一处理异常的机制。错误码枚举用于管理和传递错误信息,将错误信息与错误码进行映射,提高异常情况的定义和管理。JSR 303校验通过注解定义验证规则,并使用@Valid注解进行数据校验,确保请求数据的有效性。通过这些技术的应用,能够提升应用程序的异常处理和数据验证能力,提高应用程序的健壮性和用户体验。
898 2
SpringBoot整合【全局异常处理+错误码枚举+JSR303校验】
|
JSON Java 数据格式
hibernate-validator校验参数(统一异常处理)(下)
hibernate-validator校验参数(统一异常处理)
hibernate-validator校验参数(统一异常处理)(下)
|
Oracle Java 关系型数据库
hibernate-validator校验参数(统一异常处理)(上)
hibernate-validator校验参数(统一异常处理)
hibernate-validator校验参数(统一异常处理)(上)
freemarker中遇到null报错的处理方法
freemarker中遇到null报错的处理方法
259 0
freemarker中遇到null报错的处理方法
|
JSON 搜索推荐 Java
自定义规则异常返回|学习笔记
快速学习自定义规则异常返回
自定义规则异常返回|学习笔记
|
前端开发 Java Spring
基于SpringBoot参数校验器拓展自定义参数校验
想必工作中大家为了保证接口的稳定性与安全性都会对入参进行校验。五花八门的校验写法会让我们的代码不够整洁,本文将介绍如何使用SpringBoot为我们提供的参数校验器,并对其进行扩展,让其能够实现自定义校验。当然在一些互联网项目中,为保证接口的高性能,校验都是放在前端做的,但是在阿里开发规约中是这样说的越是简单的接口越不需要进行参数校验,越是复杂的接口越需要参数校验,因为复杂的接口试错成本很高,校验对接口性能的影响微乎其微。
349 0
|
JSON 前端开发 数据格式