<mvc:default-servlet-handler /> <!-- 解决静态页面加载问题 --> <!-- 解决静态页面加载问题 --> <!-- 启动Springmvc注解驱动 --> <!-- 返回json 方法一 需要导入 fastjson.jar包 --> <!--RequestMappingHandlerAdapter--> <mvc:annotation-driven> <mvc:message-converters register-defaults="true"> <ref bean="fastJsonHttpMessageConverter" /> </mvc:message-converters> </mvc:annotation-driven> <!-- 配置Fastjson支持 --> <bean id="fastJsonHttpMessageConverter" class="com.alibaba.fastjson.support.spring.FastJsonHttpMessageConverter"> <property name="supportedMediaTypes"> <list> <value>application/json;charset=UTF-8</value> <value>text/plain;charset=UTF-8</value> <value>text/html;charset=UTF-8</value> </list> </property> <!-- 一下可以不配 --> <property name="features"> <list> <value>WriteMapNullValue</value> <value>QuoteFieldNames</value> </list> </property> </bean>
package com.dongly.fanshe; import com.alibaba.fastjson.annotation.JSONType; @JSONType(orders={"status","msg","result"}) public class ResultVo { private Integer status; private String msg; private Object result; public Integer getStatus() { return status; } public void setStatus(Integer status) { this.status = status; } public String getMsg() { return msg; } public void setMsg(String msg) { this.msg = msg; } public Object getResult() { return result; } public void setResult(Object result) { this.result = result; } public ResultVo() { super(); } public ResultVo(Integer status, String msg, Object result) { super(); this.status = status; this.msg = msg; this.result = result; } @Override public String toString() { return "ResultVo [status=" + status + ", msg=" + msg + ", result=" + result + "]"; } }
package com.dongly.fanshe; import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; import javax.servlet.http.HttpServletResponse; import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.math.NumberUtils; import com.alibaba.fastjson.JSON; /** * 解析异常和返回结果信息 * @author bashen */ public class ParseResult { public static ResultVo parseException(Exception e) { String runtimeExcetion = e.getMessage(); ResultVo vo = new ResultVo(); if (runtimeExcetion != null) { String[] excetion = runtimeExcetion.split(":"); if (excetion.length == 2 && excetion[0] != null && excetion[0].startsWith("5")) { vo.setStatus(NumberUtils.toInt(excetion[0], 501)); vo.setMsg(excetion[1]); return vo; } } vo.setStatus(501); vo.setMsg("服务器内部错误"); return vo; } public static String parseResult(ResultVo rv, HttpServletResponse response) { if (null == rv.getStatus()) { rv.setStatus(500); if (response != null) response.setStatus(500); } if (response != null) response.setStatus(rv.getStatus()); if (null == rv.getMsg() || "".equals(rv.getMsg())) { rv.setMsg("unknow message"); } if (null == rv.getResult() || "".equals(rv.getResult())) { rv.setResult("{}"); } return JSON.toJSONString(rv); } }
package com.dongly.fanshe; import java.lang.reflect.Method; import java.util.Map; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.springframework.http.MediaType; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestHeader; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.ResponseBody; @RequestMapping("/reg") @Controller public class ReflectTest { @ResponseBody @RequestMapping(value = "/{method:[a-zA-Z_]{3,10}}",consumes=MediaType.APPLICATION_JSON_VALUE,produces = MediaType.APPLICATION_JSON_VALUE) public String select(@PathVariable("method") String method,@RequestBody(required=false) Map<String,Object> body,@RequestHeader Map<String,Object> headers,HttpServletResponse response) { String result = null; ResultVo vo = null; try { String className = "com.dongly.fanshe" + ".User"; Class<?> clazz = this.getClass().getClassLoader().loadClass(className); Method m = clazz.getDeclaredMethod(method, Map.class, Map.class); Object invoke = m.invoke(clazz.newInstance(), body,headers); vo = new ResultVo(200, "请求成功", invoke); } catch (Exception e) { vo = ParseResult.parseException(e); } finally { result = ParseResult.parseResult(vo, response); } return result; } }
相关推荐
通过aop拦截获取json请求数据,对数据进行处理判断,如果不合法则抛出异常,配置全局异常处理类,在异常处理类中直接将处理结果返回调用处,减少每次在方法中解析json数据然后在判断,减少代码冗余
在Java编程中,全局异常处理和统一返回结果是构建健壮、可维护的Web应用程序的重要组成部分。这个压缩包文件“全局异常类和统一返回结果代码”显然是一个个人实践项目,旨在帮助初学者或开发者理解如何在IDEA环境下...
2. **结果获取函数**:从命令执行后的返回值中提取结果,可能涉及错误检查和异常处理。 3. **结果解析函数**:对获取的结果进行解析,可能包括对文本的分割、过滤、格式化等操作。 4. **错误处理**:处理命令执行...
记得处理可能出现的异常,如`MalformedURLException`和`IOException`。 3. **读取XML响应**:成功连接后,可以通过`InputStream`获取服务器返回的XML数据: ```java InputStream is = connection.getInputStream();...
结果工具类是用来快速构造和返回Result对象的,简化了编码过程,同时也便于统一返回格式。可能包含的方法有: - **构造方法**:提供不同参数组合的构造方法,如根据状态码、消息和数据创建Result对象。 - **...
在Oracle数据库中,存储过程是预编译的SQL和PL/SQL代码集合,它们可以接收输入参数、执行复杂的业务逻辑并返回结果。当需要返回的数据不仅仅是单行单列时,可以使用结构化数组来实现多行多列的结果。Java作为常用的...
4. **异常处理**:在执行DNS查询时,务必捕获并处理可能出现的异常,如`UnknownHostException`和`NamingException`。 总结,Java中的地址解析和反向地址解析是网络编程中不可或缺的部分。了解并熟练掌握这些技术...
9. **错误检查**:在每次关键操作后检查错误状态,以便于调试和异常处理。 压缩包中的“VehiclesPeccancyAcquireSystem”可能是指一个与交通违章获取系统相关的项目。在这个项目中,可能需要通过HTTP请求从服务器...
当解析不成功时,"生成结果_失败"可能会返回错误信息或异常;反之,"生成结果_成功"则会返回解析后的结构或值;"生成结果_合并结果"可能是用来整合多个解析结果,例如处理嵌套的语法结构。 "解析2"可能是指一个优化...
这种机制可以捕获到所有类型的异常,包括运行时异常和检查异常,并将其统一处理和返回给用户。 那么,何时使用try catch语句,何时使用Springboot全局异常捕获机制呢?try catch语句通常用于捕获和处理特定的业务...
ESP8266 DNS域名解析异常问题主要出现在物联网设备,如ESP8266 WiFi模块在尝试连接云端服务时。当设备无法正常解析域名,导致无法连接到正确的服务器,可能会出现数据上报失败、设备离线等状况。这种情况在不稳定的...
总结来说,对于ESP8266的DNS解析异常问题,关键在于识别和应对网络环境的不稳定因素,以及合理利用设备的存储资源来保存和管理服务器IP。此解决方案提供了一个实用的思路,不仅适用于ESP8266,也对其他类似情况的...
- `parseXML(InputStream inputStream)`: 从输入流解析XML,返回解析结果对象。 - `parseXML(String xmlString)`: 从XML字符串解析,返回对象。 - `toXML(Object object)`: 将对象转换为XML字符串。 - `...
本篇将详细介绍如何使用Java解析XML,将数据存入MongoDB,并返回org.json JSON包。 首先,解析XML通常有两种主要方法:DOM(Document Object Model)和SAX(Simple API for XML)。DOM一次性加载整个XML文档到内存...
7. **历史记录**:保存和管理多个ATR解析结果,方便对比不同SIM卡或同一SIM卡在不同状态下的信息。 8. **报告导出**:提供将解析结果导出为文本、CSV或其他格式的功能,以便进一步分析或分享。 9. **用户界面**:...
**IO和异常处理解析** 异常处理是编程中用于处理程序运行时出现错误的重要机制。它允许程序员优雅地处理错误情况,而不是让程序无控制地崩溃。在本文中,我们将深入探讨异常处理的概念、其在C++中的应用以及与IO...
STM32是一个高性能的微控制器,广泛应用于各种嵌入式系统,因为它具有丰富的外设接口和强大的处理能力,非常适合处理AT指令的解析和执行。 在实现AT指令解析时,你需要考虑以下几个关键点: 1. **串口通信**:STM...
在专业指导部分,教师可以设计实践环节,让学生通过编写简单的中断处理程序和异常返回代码,加深对异常返回机制的理解。这可能涉及到汇编语言编程,学生需要学会如何在汇编代码中设置和恢复寄存器,以及如何正确地...
可以重写`DefaultHandler`的`error()`和`warning()`方法来捕获并处理解析过程中的异常。 6. **性能优化**: 虽然SAX解析本身已经很高效,但可以通过预处理XML文件(如去除不必要的空白字符、压缩文件等)进一步提高...