前端表单字符串日期转换为日期类型

博客介绍了在控制器中使用注解为当前控制器注册属性编辑器,完成参数绑定,如对String和Date类型参数的处理。还说明了让属性编辑器全局生效的方法,以及配置全局属性编辑器的其他方式,同时提及了处理异常和绑定键值对到Model的相关内容。

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

@InitBinder用于在@Controller中标注于方法上,表示为当前控制器注册一个属性编辑器,只对当前的Controller有效。@InitBinder标注的方法必须有一个参数WebDataBinder。所谓的属性编辑器可以理解就是帮助我们完成参数绑定。

    @ResponseBody
    @RequestMapping(value = "/test")
    public String test(@RequestParam String name,@RequestParam Date date) throws Exception {
        System.out.println(name);
        System.out.println(date);
        return name;
    }

    @InitBinder
    public void initBinder(WebDataBinder binder){
        binder.registerCustomEditor(String.class,
                new StringTrimmerEditor(true));

        binder.registerCustomEditor(Date.class,
                new CustomDateEditor(new SimpleDateFormat("yyyy-MM-dd"), false));

    }

  上面例子中,@InitBinder方法会帮助我们把String类型的参数先trim再绑定,而对于Date类型的参数会先格式化在绑定。例如当请求是/test?name=%20zero%20&date=2018-05-22时,会把zero绑定到name,再把时间串格式化为Date类型,再绑定到date。

  这里的@InitBinder方法只对当前Controller生效,要想全局生效,可以使用@ControllerAdvice。通过@ControllerAdvice可以将对于控制器的全局配置放置在同一个位置,注解了@ControllerAdvice的类的方法可以使用@ExceptionHandler@InitBinder@ModelAttribute注解到方法上,这对所有注解了@RequestMapping的控制器内的方法有效。

@ControllerAdvice
public class GlobalControllerAdvice {

    @InitBinder
    public void initBinder(WebDataBinder binder) {
        binder.registerCustomEditor(String.class,
                new StringTrimmerEditor(true));

        binder.registerCustomEditor(Date.class,
                new CustomDateEditor(new SimpleDateFormat("yyyy-MM-dd"), false));

    }
}

  除了使用@ControllerAdvice来配置全局的WebDataBinder,还可以使用RequestMappingHandlerAdapter

    @Bean
    public RequestMappingHandlerAdapter webBindingInitializer() {
        RequestMappingHandlerAdapter adapter = new RequestMappingHandlerAdapter();
        adapter.setWebBindingInitializer(new WebBindingInitializer(){

            @Override
            public void initBinder(WebDataBinder binder, WebRequest request) {
                binder.registerCustomEditor(Date.class, new CustomDateEditor(new SimpleDateFormat("yyyy-MM-dd"), false));

            }
        });
        return adapter;
    }

   如上示例,可以实现同样的效果。


  @ControllerAdvice中除了配置@InitBinder,还可以有@ExceptionHandler用于全局处理控制器里面的异常;@ModelAttribute作用是绑定键值对到Model里,让全局的@RequestMapping都能获得在此处设置的键值对。

  补充:如果 @ExceptionHandler注解中未声明要处理的异常类型,则默认为方法参数列表中的异常类型。示例:

@ControllerAdvice
public class GlobalExceptionHandler {

    @ExceptionHandler(Exception.class)
    @ResponseBody
    String handleException(Exception e){
        return "Exception Deal! " + e.getMessage();
    }
}
### 将表单数据字符串转换为Map结构 在处理Web开发中的请求时,通常会遇到将URL查询参数或POST提交的表单数据解析为键值对的需求。以下是几种常见的方法来实现这一功能。 #### Java 实现方式 Java 提供了多种工具可以用来完成此操作。如果输入是一个标准的 `application/x-www-form-urlencoded` 格式的字符串,则可以通过以下方式进行解析: ```java import java.util.HashMap; import java.util.Map; public class FormDataParser { public static Map<String, String> parseFormData(String formData) throws Exception { Map<String, String> result = new HashMap<>(); if (formData != null && !formData.isEmpty()) { for (String param : formData.split("&")) { // 使用 & 符号分隔不同的字段 String[] entry = param.split("="); // 使用 = 符号区分键和值 if (entry.length > 1) { String key = java.net.URLDecoder.decode(entry[0], "UTF-8"); // 解码键名 String value = java.net.URLDecoder.decode(entry[1], "UTF-8"); // 解码键值 result.put(key, value); } else { throw new IllegalArgumentException("Invalid form data format"); } } } return result; } public static void main(String[] args) throws Exception { String formData = "name=John&age=25"; Map<String, String> resultMap = parseFormData(formData); System.out.println(resultMap.toString()); } } ``` 上述代码通过手动拆解字符串并利用 `split()` 方法[^1] 来分离键与值,并使用 `URLDecoder.decode` 对可能被编码的内容进行解码。 #### JavaScript 实现方式 对于前端开发者来说,在JavaScript环境中也可以轻松地将表单数据字符串化为对象或者 `Map` 结构: ```javascript function stringToMap(formStr) { const map = new Map(); if (!formStr || typeof formStr !== 'string') return map; formStr.split('&').forEach(pair => { let [key, value] = pair.split('=').map(decodeURIComponent); // 同样需要解码 map.set(key, value); }); return map; } // 测试函数 const formData = "name=John%20Doe&age=25"; console.log(stringToMap(formData)); ``` 这里同样采用了 `split()` 函数 和额外一层映射逻辑以支持 URL 编码字符的自动还原。 #### XML 转换至 Map 的情况 当涉及到更复杂的XML文档而非简单的键值对形式时,可采用专门设计用于此类任务的功能库。例如下面展示了一个基于第三方依赖(如Dom4j)的例子[^2]: ```java import org.dom4j.Document; import org.dom4j.Element; import org.dom4j.io.SAXReader; import java.util.HashMap; import java.util.List; import java.util.Map; public class XmlToMapConverter { public static Map<String, Object> xmlToMap(String xmlContent) throws Exception{ SAXReader reader = new SAXReader(); Document document = reader.read(new java.io.StringReader(xmlContent)); Element rootElement = document.getRootElement(); return convertElement(rootElement); } private static Map<String, Object> convertElement(Element element){ Map<String, Object> resultMap = new HashMap<>(); List<Element> childrenElements = element.elements(); if(childrenElements.size()==0){ resultMap.put(element.getName(),element.getTextTrim()); }else{ for(Element child:childrenElements){ resultMap.put(child.getName(),convertElement(child)); } } return resultMap; } } ``` 以上展示了如何递归遍历整个DOM树并将节点及其属性存储到嵌套字典之中。 #### HTML 页面字符串 MAP 针对HTML片段的情况则相对复杂一些因为其标签层次关系更加自由多变。不过仍然存在通用解决方案比如借助正则表达式匹配特定模式下的内容项再逐一加入目标容器当中去[^3]. ```javascript let htmlSnippet='...'; // 假设这是你的原始HTML文本 var tempDiv=document.createElement('div'); tempDiv.innerHTML=htmlSnippet; let keyValuePairs={}; Array.from(tempDiv.querySelectorAll('[id],[class],[data-*]')).forEach(el=>{ Array.from(el.attributes).filter(attr=>['id','class'].includes(attr.name)||attr.name.startsWith('data-')) .forEach(attr=>keyValuePairs[attr.name]=attr.value); }); console.log(keyValuePairs); ``` 这种方法主要适用于那些带有明确语义化标记(如ID/Class/Data Attributes)的信息抽取场合下比较适用. ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值