SpringMVC项目bug总结
SpringMVC文件上传大小和类型限制以及超大文件上传bug问题
SpringMVC⽂件上传⼤⼩和类型限制以及超⼤⽂件上传bug问题在上⼀篇⽂章中,主要介绍了Spirng MVC环境下的正常情况下⽂件上传功能实现。
在实际开发的时候,还会涉及到上传⽂件⼤⼩和类型的限制,接下来就会对Spirng MVC环境下⽂件上传⼤⼩和类型的限制进⾏介绍,还会讲解到⽂件上传⼤⼩tomcat服务器bug问题及解决⽅案。
⼀、⽂件上传⼤⼩限制这⾥还是接着上篇⽂章先介绍Spring MVC下的⽂件上传⼤⼩限制,⽂件上传⼤⼩的限制在springmvc-config.xml中配置⽂件解析器CommonsMultipartResolver时即可配置,⽰例如下:<!-- 配置⽂件上传类型解析器 multipartResolver--><bean id="multipartResolver" class="monsMultipartResolver"><!-- 设置上传⽂件最⼤尺⼨,单位为B --><property name="maxUploadSize" value="5242880" /></bean>关于Spring MVC中⽂件上传⼤⼩的限制就这么简单,问题是Spring MVC并没有像Struts2那样的配置,如果单纯配置⼀个限制⽂件上传⼤⼩的配置,当超过上传限制后就会出现异常:所以当在⽂件解析器中配置了⽂件⼤⼩的限制后,必须将抛出的MaxUploadSizeExceededException(上传⽂件过⼤异常)进⾏接收并跳转。
关于异常接收,在Spring MVC官⽅⽂档中介绍了有3种⽅法,这⾥主要介绍其中2种:(1)直接在配置⽂件spring-config.xml中使⽤Spring MVC提供的SimpleMappingExceptionResolver(异常解析映射器)来接收异常信息:<!-- 1.在⽂件上传解析时发现异常,此时还没有进⼊到Controller⽅法中 --><bean id="exceptionResolver" class= "org.springframework.web.servlet.handler.SimpleMappingExceptionResolver"><property name="exceptionMappings"><props><!-- 遇到MaxUploadSizeExceededException异常时,跳转到error.jsp页⾯ --><prop key= "org.springframework.web.multipart.MaxUploadSizeExceededException">/error </prop></props></property></bean>这样当再出现⽂件上传⼤⼩的异常时,配置⽂件会⾃动捕获异常并进⾏匹配,匹配到对应的MaxUploadSizeExceededException异常,就跳转到指定的error.jsp错误页⾯。
对于SpringMVC框架使用的时候出现“警告:NomappingfoundforHTTP。。。
对于SpringMVC框架使⽤的时候出现“警告:
NomappingfoundforHTTP。
今天,在myeclipse上导⼊了前⼏天的⼀个项⽬,但是怎么都运⾏不起来,可是在别⼈的电脑上都可以。
从早上⼀直调到了现在(期间也看了好多关于此类的帖⼦,但是都没能解决我的问题),终于找到了解决⽅案。
⾸先,要确定以前的项⽬是可⾏的,就是最近不能运⾏,这样可以确定⾃⼰的项⽬代码是没有问题的,就没有必要在代码上纠结了。
因为如果你没有扫描到controller包或者没有加⼊注解驱动等原因也可能会出现相同的问题。
既然不是你代码的原因那就是你项⽬编译的问题了,可能因为各种各样的原因导致你项⽬编译失败,试试project ->clean吧。
使eclipse 或myeclipse重新编译(含class⽂件、jsp⽂件、ftl⽂件等等),前提是Java Build Path中配置好了。
这样的再重启服务器项⽬应该就可以运⾏了。
这件事对我有⼀些启发,碰到⼀些问题不⼀定是与这件事有直接关联的问题引起的,它所在的环境等间接因素也可能引起,往往间接因素更难发现。
处理SpringMVC的时间错误:FielderrorinobjectsysDatumed。。。
处理SpringMVC的时间错误:FielderrorinobjectsysDatumed。
错误:⼗⼀⽉ 27, 2017 8:26:11 下午 org.apache.catalina.core.StandardWrapperValve invoke严重: Servlet.service() for servlet [springMvc] in context with path [/PrintingSystem] threw exception [Request processing failed; nested exception is org.springframework.validation.BindException: org.springframework.validation.BeanPropertyBind Field error in object 'sysDatumedetai' on field 'storagetime': rejected value [2017-11-27]; codes [typeMismatch.sysDatumedetai.storagetime,typeMismatch.storagetime,typeMismatch.java.util.Date,typeMismatch]; arguments [org.springframework. org.springframework.validation.BindException: org.springframework.validation.BeanPropertyBindingResult: 1 errorsField error in object 'sysDatumedetai' on field 'storagetime': rejected value [2017-11-27]; codes [typeMismatch.sysDatumedetai.storagetime,typeMismatch.storagetime,typeMismatch.java.util.Date,typeMismatch]; arguments [org.springframework. at org.springframework.web.method.annotation.ModelAttributeMethodProcessor.resolveArgument(ModelAttributeMethodProcessor.java:111)at org.springframework.web.method.support.HandlerMethodArgumentResolverComposite.resolveArgument(HandlerMethodArgumentResolverComposite.java:75)at org.springframework.web.method.support.InvocableHandlerMethod.getMethodArgumentValues(InvocableHandlerMethod.java:156)at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:117)at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:96)at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:617)at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:578)at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:80)at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:923)at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:852)at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:882)at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:778)at javax.servlet.http.HttpServlet.service(HttpServlet.java:620)at javax.servlet.http.HttpServlet.service(HttpServlet.java:727)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88)at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:76)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:220)at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:122)at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:501)at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:170)at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98)at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:950)at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116)at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:408)at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1040)at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:607)at .AprEndpoint$SocketProcessor.doRun(AprEndpoint.java:2441)at .AprEndpoint$SocketProcessor.run(AprEndpoint.java:2430)at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)at ng.Thread.run(Thread.java:745)因为菜鸟所以这个问题弄了挺久的,这个是时间的问题。
MyBatis+spring遇到的问题
MyBatis+spring遇到的问题1.PropertyPlaceholderConfigurer⽆效昨天⽩天就遇到了这个问题,applicationContext⾥的dataSource使⽤PropertyPlaceholder,如<property name="driverClassName"value="${jdbc.driver}" />,然后启动spring⼀直报[${jdbc.driver}]⽆法加载,这⾥⽤到了spring 3.0的新特性profiles,起先还以为profiles设置问题,后来把profiles撤掉问题依旧。
不⽤占位符,直接填实际值是可以的。
⽽且就算<property name="ignoreResourceNotFound"value="false" />这样设置也不会报错,这是不应该的。
以前⼀直⽤占位符⽅式也都没出现过问题,然后就下班了。
回家玩了会⼉游戏,打得爽了,⼼情好就想再看看这个问题。
我把MyBatis有关的配置全撤掉,⼀个⼀个加上去,当加到MapperScannerConfigurer的时候就出现问题,没加的时候properties⽂件不存在也会报错,那问题肯定就在这⾥了。
⽤google搜了⼀把,官⽹有⼈说MapperScannerConfigurer会在PropertyPlaceholderConfigurer之前进⾏扫描,所以它或它依赖的BEAN如果有⽤到Placeholder的都不会被替换掉。
他没有提到这也会导致ignoreResourceNotFound=false失效。
没办法,只好将配置属性直接写在applicationContext⾥了,总⽐注⼊到系统变量⾥强吧。
.ibatis.sqlmap.engine.type.BaseTypeHandler ClassNotFoundException接下来就是这个异常了,我反复仔细查看mybatis包和mybatis-spring包,就是没找到com.ibatis.sqlmap.*包,起初以为版本问题,换mybatis-3.1.0和mybatis-spring-1.1.0,问题依旧,⼯程只有⼀个Mapper.xml,这个Mapper.xml去掉就不报错,加上就报错,当时我就陷⼊了泥沼,犯迷糊了。
项目使用中常见问题解决方法全解析
项目使用中常见问题解决方法全解析在项目开发和使用过程中,常常会遇到各种各样的问题。
这些问题可能是技术上的困难,也可能是操作上的难题。
为了更好地解决这些问题,本文将全面解析项目使用中常见问题的解决方法,帮助读者更好地应对各种挑战。
一、技术问题解决方法1. 编程语言错误在项目开发中,我们经常会遇到编程语言错误。
这些错误可能是语法错误、逻辑错误或者是运行时错误。
解决这些问题的关键是对编程语言有深入的了解和熟练的技能。
首先,我们需要仔细检查代码,查找可能存在的语法错误。
可以使用编程语言提供的调试工具来定位错误所在。
其次,我们需要仔细分析代码逻辑,确保逻辑的正确性。
最后,我们可以使用日志记录技术来追踪运行时错误,以便更好地定位和解决问题。
2. 数据库连接问题在项目开发中,数据库连接问题是比较常见的。
这些问题可能是由于数据库配置错误、网络连接问题或者是权限设置不当导致的。
解决数据库连接问题的方法是首先检查数据库配置文件,确保配置信息正确无误。
其次,我们可以使用ping命令来测试网络连接是否正常。
如果网络连接正常,但仍无法连接数据库,那么可能是权限设置不当。
我们需要检查数据库用户的权限,并确保其具有足够的权限来访问数据库。
3. 性能优化问题在项目开发中,性能优化是一个非常重要的问题。
如果项目的性能不佳,可能会导致用户体验差,甚至无法正常运行。
解决性能优化问题的方法是首先进行性能测试,找出性能瓶颈所在。
然后,我们可以使用一些性能优化技术来提高项目的性能,比如缓存技术、异步处理等。
另外,我们还可以对项目进行代码优化,减少不必要的计算和数据传输,以提高项目的响应速度。
二、操作问题解决方法1. 安装和配置问题在项目使用过程中,安装和配置问题是比较常见的。
这些问题可能是由于操作系统不兼容、依赖库缺失或者配置文件错误导致的。
解决安装和配置问题的方法是首先仔细阅读项目的安装和配置文档,确保按照要求进行安装和配置。
如果仍然遇到问题,可以尝试重新安装项目,并确保操作系统和依赖库的版本兼容。
MVC缺点总结
MVC缺点总结
MVC的缺点:
1.完全理解MVC⽐较复杂。
由于MVC模式提出的时间不长,加上同学们的实践经验不⾜,所以完全理解并掌握MVC不是⼀个很容易的过程。
2.调试困难。
因为模型和视图要严格的分离,这样也给调试应⽤程序带来了⼀定的困难,每个构件在使⽤之前都需要经过彻底的测试。
3.不适合⼩型,中等规模的应⽤程序
在⼀个中⼩型的应⽤程序中,强制性的使⽤MVC进⾏开发,往往会花费⼤量时间,并且不能体现MVC的优势,同时会使开发变得繁琐。
4.增加系统结构和实现的复杂性
对于简单的界⾯,严格遵循MVC,使模型、视图与控制器分离,会增加结构的复杂性,并可能产⽣过多的更新操作,降低运⾏效率。
5.视图与控制器间的过于紧密的连接并且降低了视图对模型数据的访问
视图与控制器是相互分离,但却是联系紧密的部件,视图没有控制器的存在,其应⽤是很有限的,反之亦然,这样就妨碍了他们的独⽴重⽤。
依据模型操作接⼝的不同,视图可能需要多次调⽤才能获得⾜够的显⽰数据。
对未变化数据的不必要的频繁访问,也将损害操作性能。
bug总结
bug总结Bug总结在软件开发过程中,经常会遇到各种各样的错误和问题,这些错误和问题被统称为“bug”。
解决这些bug是开发人员的重要任务之一。
在过去的几个月里,我积累了一些bug总结,现在我想将这些bug总结分享给大家。
一、界面显示问题1. 文字显示错位:在开发过程中,有时候会遇到文字错位的问题。
这可能是由于界面设计不合理导致的,也可能是代码逻辑有误。
解决这个bug的方法是仔细检查代码和界面设计,确保元素的位置和大小正确。
2. 图片无法加载:当某个图片无法正确加载时,用户可能会看到一个空白的方块或者一个红色的叉叉。
这可能是由于图片路径错误、网络问题或者图片格式有误导致的。
解决这个问题的方法是检查图片路径和格式,确保网络连接正常。
二、功能问题1. 上传文件失败:在某个功能中,用户可以上传文件,但是有时候会出现上传失败的情况。
这可能是由于文件大小超出限制、文件类型不正确或者服务器问题导致的。
解决这个bug的方法是增加文件大小和类型的限制,并检查服务器配置。
2. 用户登录错误:用户在登录时会输入账号和密码,但是有时候会遇到登录错误的问题。
这可能是由于数据库中账号和密码不匹配、密码加密算法有误或者登录接口的逻辑出错导致的。
解决这个问题的方法是检查数据库中的账号和密码、确认加密算法的正确性,并仔细检查登录接口的代码。
三、性能问题1. 系统崩溃:系统在运行一段时间后可能会发生崩溃。
这可能是由于内存泄漏、循环引用、线程阻塞或者资源耗尽导致的。
解决这个问题的方法是使用合理的内存管理、检查循环引用的问题、优化线程逻辑,以及增加对资源的释放。
2. 响应时间过长:用户在使用系统时可能会遇到响应时间过长的问题,这会影响用户体验。
这可能是由于数据库查询慢、算法复杂度高或者网络传输过程中的延迟导致的。
解决这个问题的方法是优化数据库查询语句、简化算法逻辑,并检查网络连接是否正常。
四、兼容性问题1. 在某些浏览器上显示异常:不同的浏览器对网页的解析有差异,可能会导致页面显示异常。
spring mvc 面试知识点
Spring MVC 面试知识点Spring MVC 是一个轻量级的基于 Java 的Web开发框架,它是 Spring 框架的一部分。
在面试中,掌握 Spring MVC 的知识是非常重要的。
本文将介绍一些关于Spring MVC 的面试知识点,以帮助你更好地准备面试。
1. 什么是 Spring MVC?Spring MVC 是基于 Model-View-Controller(模型-视图-控制器)设计模式的Web框架。
它通过将应用程序分为模型、视图和控制器来实现应用程序的松耦合,使得开发人员能够更好地管理和组织代码。
Spring MVC 提供了一个强大的基于注解的方式来处理请求和响应。
2. Spring MVC 的核心组件是什么?Spring MVC 的核心组件包括以下几个:•DispatcherServlet:它是整个 Spring MVC 的前端控制器,负责将请求分发给不同的处理器进行处理。
•HandlerMapping:它负责将请求映射到对应的处理器。
•Controller:它是处理请求的组件,通常使用注解或实现特定接口来标识。
•ViewResolver:它负责解析视图的逻辑名称并返回具体的视图对象。
•View:它负责将模型数据渲染成具体的HTML、JSON 等形式的响应。
3. Spring MVC 的请求处理流程是怎样的?Spring MVC 的请求处理流程如下:1.客户端发送请求到服务器。
2.请求被 DispatcherServlet 拦截。
3.DispatcherServlet 根据请求的 URL 调用合适的 HandlerMapping 来确定请求的处理器。
4.处理器处理请求,并将处理结果存储在一个 ModelAndView 对象中。
5.DispatcherServlet 根据 HandlerMapping 返回的处理器和ModelAndView,选择一个合适的 ViewResolver 来解析视图逻辑名称。
Java Web开发中的常见问题汇总与解决方案
Java Web开发中的常见问题汇总与解决方案Java Web开发是现在互联网行业中非常热门的技术方向之一,它的发展势头也是越来越迅猛。
然而,在开发Java Web应用程序的过程中,总会遇到各种各样的问题,有的是因为技术不够熟练导致的,有的是由于环境不同而产生的。
为了让大家更好地掌握Java Web开发,本文将为您汇总整理了一些Java Web开发中常见的问题,并提供相应的解决方案。
一、数据访问异常在Java Web开发中,我们经常会遇到与数据库相关的异常。
尤其是在开发大型系统时,访问数据库的错误可能会成倍地影响系统的性能和可靠性。
以下列举一些常见的数据访问异常和解决方案。
1、连接池过期连接池过期是一个非常常见的问题,尤其是在系统高并发的情况下,会造成系统性能的明显下降。
解决方法是通过合理的配置和优化连接池的使用,提高系统的吞吐量和稳定性。
2、防止数据库死锁死锁是在高并发系统中经常遇到的问题之一。
如果多个线程并发访问数据库的同一个资源,就有可能导致死锁的产生。
要解决这个问题,可以通过使用数据库的锁机制来避免死锁的产生。
3、被动连接关闭一些数据库和Java ORM框架对于空闲连接资源的回收策略不同,可能会导致被动关闭连接的情况发生。
解决方案是做好连接池的配置和优化,避免过度的空闲连接资源占用。
二、Web服务器异常Java Web开发中的Web服务器异常也是非常常见的问题。
以下列举一些常见的Web服务器异常和解决方案。
1、多线程并发处理异常在高并发的情况下,Web服务器可能会产生并发处理异常,这种情况下就需要通过合理的代码设计和服务器配置来保证系统的性能和稳定性。
2、内存溢出和内存泄漏内存溢出和内存泄漏是很多Java Web开发者常常碰到的问题。
要解决这个问题,可以通过调整JVM内存参数,优化代码的编写和设计,避免无意中创建了对象并长时间占用内存资源。
3、负载均衡异常Java Web应用程序在高并发的情况下,可能会导致负载均衡的异常。
SpringMVC错题合集
SpringMVC错题合集1、在SpringMVC中,Spr ingMVC默认采⽤的HandlerMapping实现类是A: BeanNameUr1HandlerMapping2、在SpringMVC中,DispatcherServlet中使⽤的特殊的Bean包括A: ControllerB: ViewResolverC: HandlerExcepti onResolver3、在SpringMVC中,以下关于拦截器的使⽤说法正确的是A: SpringMVC的拦截器,是属于HandlerMapping级别的B: SpringMVC的拦截器可以有多个HandlerMapping,每个HandlerMapping可以有⾃⼰的拦截器。
C:⼀⼀个请求交给⼀个HandlerMapping时,这个HandlerMapping先找有没有处理器来处理这个请求,如果找到了,就执⾏拦截器,执⾏完拦截后,交给⽬标处理器4、在SpringMVC中,以下关于多个HandlerMapping的执⾏顺序说法正确的是A: Def aultAnnotati onHandl erMapping的order属性值是: 1D: <mvc:resources/ >⾃动注册的Simp1eUr 1Handler Mapping的order属性值是: -214748364 .5、在Spr ingMVC中,关于BaseCommandController提供的功能,说法中包含的是A:将请求参数转换为Command对象B:对数据进⾏验证。
在转换和验证时发⽣错误时,需要在handle (request,response, commanderrors)中进⾏处理C:绑定⽤户类型6、在SpringMVC中,描述正确的是A: DisPatcherServlet是SpringMVC的前端Servlet,和任何的servlet-样,必须在web. xml中配置后,才能起作⽤B:在web. xm1中,根据servlet-mapping的URL不同,可以配置多个DisPatcherServletC: ModelAndView中的view是逻辑视图名,⽽⾮真正的视图对象7、在SpringMVC中,关于SpringMVC核⼼组件说法正确的是A: SpringMVC所有请求都提交给DisptacherServlet, DispatcherServlet查询⼀个或多个HandlerMapping找到处理请求的Controller,将请求提交到ControllerB: Controller进⾏业务逻辑处理后可以返回- -个ModelAndView对象C: Controller查询-⼀个或多个ViewResolver视图解析器,找到ModelAndView对象指定的视图对象8、有关MVC的处理过程,描述正确的是( )A:⾸先控制器接收⽤户的请求,决定调⽤那个模型来进⾏处理B:模型处理⽤户的请求并返回数据C:视图将模型返回的数据呈现给⽤户9、在Spr ingMVC中,SpringMVC是⼀个基于DispatcherServlet的MVC框架,每⼀个请求最先访问的都是Di spatcherServlet, DispatcherServlet负责转发每⼀个Request请求给相应的()。
java 容易发生bug的代码
Java作为一种常见的编程语言,在软件开发中被广泛应用。
然而,由于Java语言本身的复杂性和灵活性,以及开发人员的编码习惯等原因,容易导致代码中出现各种各样的bug。
本文将就Java程序中容易发生bug的代码进行探讨,从而帮助开发人员避免在编码过程中犯下一些常见的错误。
一、空指针异常1.1 未对对象进行空值检查在Java中,当一个对象为null时,若再对该对象进行操作就会导致空指针异常。
在编码过程中,需要特别注意对对象进行空值检查,避免出现空指针异常。
1.2 引用对象为空时的操作在编写代码时,需要时刻注意操作的对象是否为空,避免在引用对象为空的情况下进行操作,从而引发空指针异常。
二、数组越界异常2.1 未对数组进行边界检查在使用数组时,需要时刻注意数组的长度和索引的范围,避免出现数组越界异常。
特别是在循环中,需要谨慎判断循环的边界条件,避免出现索引越界的情况。
2.2 循环条件不当在编写循环时,需要特别注意循环条件的合理性,避免出现因为循环条件不当而导致数组越界异常的情况。
三、逻辑错误3.1 未对条件进行全面考虑在编写条件判断语句时,需要考虑全面,确保覆盖所有可能的情况,避免出现逻辑错误。
特别是在多条件判断的情况下,需要仔细思考每种情况的处理方法。
3.2 逻辑判断错误在编写逻辑判断语句时,需要谨慎思考,避免因为逻辑判断错误而导致程序出现逻辑错误的情况。
四、并发问题4.1 线程安全性问题在多线程环境中,需要特别注意共享资源的线程安全性,避免因为多线程操作而引发数据竞争、死锁等并发问题。
4.2 未加锁导致的并发问题在编写多线程程序时,需要考虑对共享资源进行合适的加锁操作,确保在并发情况下共享资源的正确访问。
五、性能问题5.1 未使用合适的数据结构在编写代码时,需要根据实际情况选择合适的数据结构,避免出现性能问题。
选择合适的数据结构能够提高程序的执行效率。
5.2 未考虑算法复杂度在编写算法时,需要考虑算法的时间复杂度和空间复杂度,避免因为未考虑算法复杂度而引发性能问题。
springmvc请求参数异常统一处理
springmvc请求参数异常统⼀处理 1、ExceptionHandlerControllerpackage com.oy.controller;import java.text.MessageFormat;import org.springframework.beans.TypeMismatchException;import org.springframework.http.HttpStatus;import org.springframework.http.converter.HttpMessageNotReadableException;import org.springframework.web.HttpRequestMethodNotSupportedException;import org.springframework.web.bind.MissingServletRequestParameterException;import org.springframework.web.bind.annotation.ControllerAdvice;import org.springframework.web.bind.annotation.ExceptionHandler;import org.springframework.web.bind.annotation.ResponseBody;import org.springframework.web.bind.annotation.ResponseStatus;import org.springframework.web.servlet.mvc.multiaction.NoSuchRequestHandlingMethodException;import com.alibaba.fastjson.JSONObject;import com.oy.exception.ForbiddenException;import com.oy.utils.UtilFunctions;@ControllerAdvicepublic class ExceptionHandlerController {@ExceptionHandler(RuntimeException.class)@ResponseStatus(HttpStatus.INTERNAL_SERVER_ERROR)@ResponseBodypublic JSONObject runtimeExceptionHandler(RuntimeException ex) {UtilFunctions.log.error("runtimeExceptionHandler, msg:{}, exception:{}", ex.toString(), ex);JSONObject response = new JSONObject();response.put("message", "Internal Server Error");return response;}@ExceptionHandler(NullPointerException.class)@ResponseStatus(HttpStatus.INTERNAL_SERVER_ERROR)@ResponseBodypublic JSONObject nullPointerExceptionHandler(NullPointerException ex) {UtilFunctions.log.error("nullPointerExceptionHandler, msg:{}, exception:{}", ex.toString(), ex);JSONObject response = new JSONObject();response.put("message", "Internal Server Error");return response;}/*----- REQUEST ERROR -----*/@ExceptionHandler({ ForbiddenException.class })@ResponseStatus(HttpStatus.FORBIDDEN)@ResponseBodypublic JSONObject requestForbidden(ForbiddenException ex) {UtilFunctions.log.error("ForbiddenExceptionHandler, msg:{}, exception:{}", ex.toString(), ex);JSONObject response = new JSONObject();response.put("message", ex.getMessage());return response;}@ExceptionHandler({ TypeMismatchException.class })@ResponseStatus(HttpStatus.BAD_REQUEST)@ResponseBodypublic JSONObject requestTypeMismatch(TypeMismatchException ex) {UtilFunctions.log.error("TypeMismatchExceptionHandler, msg:{}, exception:{}", ex.toString(), ex);JSONObject response = new JSONObject();// response.put("message", "Bad Request");// response.put("message", "Bad Request, parameter type of " + ex.getPropertyName() + " need be " + ex.getRequiredType());if (Double.class.equals(ex.getRequiredType()) || Integer.class.equals(ex.getRequiredType())) {response.put("message", "Bad Request, " + ex.getValue() + " not a number");} else {String strTemplate = "Bad Request, {0} is invalid, a type of {1} is needed";response.put("message", MessageFormat.format(strTemplate, ex.getValue(), ex.getRequiredType().getName()));}return response;}@ExceptionHandler({ MissingServletRequestParameterException.class })@ResponseStatus(HttpStatus.BAD_REQUEST)@ResponseBodypublic JSONObject requestMissingServletRequest(MissingServletRequestParameterException ex) {UtilFunctions.log.error("MissingServletRequestParameterExceptionHandler, msg:{}, exception:{}", ex.toString(), ex);JSONObject response = new JSONObject();// response.put("message", "Bad Request");String strTemplate = "Bad Request, param:{0} is required, type:{1}";response.put("message", MessageFormat.format(strTemplate, ex.getParameterName(), ex.getParameterType()));return response;}@ExceptionHandler({ NoSuchRequestHandlingMethodException.class })@ResponseStatus(HttpStatus.BAD_REQUEST)@ResponseBodypublic JSONObject NoSuchRequestHandlingMethodExceptionHandler(NoSuchRequestHandlingMethodException ex) { UtilFunctions.log.error("NoSuchRequestHandlingMethodExceptionHandler, msg:{}, exception:{}", ex.toString(), ex); JSONObject response = new JSONObject();response.put("message", "Not Found");return response;}/*----- REQUEST ERROR -----*/@ExceptionHandler({ HttpMessageNotReadableException.class })@ResponseStatus(HttpStatus.BAD_REQUEST)@ResponseBodypublic JSONObject requestNotReadable(HttpMessageNotReadableException ex) {UtilFunctions.log.error("HttpMessageNotReadableExceptionHandler, msg:{}, exception:{}", ex.toString(), ex);JSONObject response = new JSONObject();response.put("message", "Bad Request");return response;}@ExceptionHandler({ HttpRequestMethodNotSupportedException.class })@ResponseStatus(HttpStatus.METHOD_NOT_ALLOWED)@ResponseBodypublic JSONObject request405(HttpRequestMethodNotSupportedException ex) {UtilFunctions.log.error("HttpRequestMethodNotSupportedExceptionHandler, msg:{}, exception:{}", ex.toString(), ex); JSONObject response = new JSONObject();// response.put("message", "Method Not Allowed");response.put("message", ex.getMessage());return response;}}2、postman测试3、异常增强类型: NullPointerException,RunTimeException,ClassCastException, NoSuchMethodException,IOException,IndexOutOfBoundsException 以及springmvc⾃定义异常等,如下: SpringMVC⾃定义异常对应的status codeException HTTP Status CodeConversionNotSupportedException 500 (Internal Server Error)HttpMessageNotWritableException 500 (Internal Server Error)HttpMediaTypeNotSupportedException 415 (Unsupported Media Type) HttpMediaTypeNotAcceptableException 406 (Not Acceptable) HttpRequestMethodNotSupportedException 405 (Method Not Allowed) NoSuchRequestHandlingMethodException 404 (Not Found)TypeMismatchException 400 (Bad Request)HttpMessageNotReadableException 400 (Bad Request)MissingServletRequestParameterException 400 (Bad Request)参考资料: (1) (2) (3)。
springmvccontroller返回json出错解决
springmvccontroller返回json出错解决1、出错的地方:@RequestMapping(value = "/query")@JsonSerialize(include=JsonSerialize.Inclusion.NON_NULL)public @ResponseBodyJSONObject query(@RequestParam("startTime") String startTime,@RequestParam("endTime") String endTime,@RequestParam("oid") String oid, @RequestParam("cid") Integer cid, @RequestParam("pay_channel") String payChannel,@RequestParam("device_type") String deviceType,@RequestParam("phone") Integer phone,@RequestParam("perPage") Integer pageSize,@RequestParam("skipIndex") Integer startIndex) throws Exception {LogInfo info = populateQueryParam(startTime, endTime, oid, cid, payChannel, deviceType, phone, pageSize, startIndex);// 总记录数Long totalCount = logMoniterService.queryLogInfoCount(info);if (totalCount == null) {totalCount = 0L;}List<LogInfo> list = logMoniterService.queryLogInfo(info);JSONObject retData = new JSONObject();retData.put("success", true);retData.put("data", list);retData.put("error", "");retData.put("totalRecords", totalCount);return retData;}2、结果报错:<html><head><title>Apache Tomcat/7.0.42 - Errorreport</title><style><!--H1{font-family:Tahoma,Arial,sans-serif;color:white;background-color:#52 5D76;font-size:22px;} H2{font-family:Tahoma,Arial,sans-serif;color:white;background-color:#52 5D76;font-size:16px;} H3{font-family:Tahoma,Arial,sans-serif;color:white;background-color:#52 5D76;font-size:14px;} BODY{font-family:Tahoma,Arial,sans-serif;color:black;background-color:whi te;} B{font-family:Tahoma,Arial,sans-serif;color:white;background-color:#52 5D76;} P{font-family:Tahoma,Arial,sans-serif;background:white;color:black;fon t-size:12px;}A {color : black;} {color : black;}HR {color :#525D76;}--></style> </head><body><h1>HTTP Status 500 - Could not write JSON: Object is null (through reference chain:net.sf.json.JSONObject["data"]->net.sf.json.JSONArray[0] ->net.sf.json.JSONObject["createTime"]->net.sf.json.J SONNull["empty"]); nested exception isorg.codehaus.jackson.map.JsonMappingException: Object is null (through reference chain:net.sf.json.JSONObject["data"]->net.sf.json.JSONArray[0] ->net.sf.json.JSONObject["createTime"]->net.sf.json.J SONNull["empty"])</h1><HR size="1"noshade="noshade"><p><b>type</b> Exception report</p><p><b>message</b> <u>Could not write JSON: Object is null (through reference chain: net.sf.json.JSONObject["data"]->net.sf.json.JSONArray[0] ->net.sf.json.JSONObject["createTime"]->net.sf.json.J SONNull["empty"]); nested exception isorg.codehaus.jackson.map.JsonMappingException: Object is null (through reference chain:net.sf.json.JSONObject["data"]->net.sf.json.JSONArray[0] ->net.sf.json.JSONObject["createTime"]->net.sf.json.J SONNull["empty"])</u></p><p><b>description</b> <u>The server encountered an internal error that prevented it from fulfilling this request.</u></p><p><b>exception</b><pre>org.springframework.http.converter.HttpMessageNotWritableExcepti on: Could not write JSON: Object is null (through reference chain: net.sf.json.JSONObject["data"]->net.sf.json.JSONArray[0] ->net.sf.json.JSONObject["createTime"]->net.sf.json.J SONNull["empty"]); nested exception isorg.codehaus.jackson.map.JsonMappingException: Object is null (through reference chain:net.sf.json.JSONObject["data"]->net.sf.json.JSONArray[0] ->net.sf.json.JSONObject["createTime"]->net.sf.json.J SONNull["empty"])org.springframework.http.converter.json.MappingJacksonHttpMessageConv erter.writeInternal(MappingJacksonHttpMessageConverter.java:203)org.springframework.http.converter.AbstractHttpMessageConverter.write (AbstractHttpMessageConverter.java:179)org.springframework.web.servlet.mvc.method.annotation.AbstractMessage ConverterMethodProcessor.writeWithMessageConverters(AbstractMessageCo nverterMethodProcessor.java:148)org.springframework.web.servlet.mvc.method.annotation.AbstractMessage ConverterMethodProcessor.writeWithMessageConverters(AbstractMessageCo nverterMethodProcessor.java:90)org.springframework.web.servlet.mvc.method.annotation.RequestResponse BodyMethodProcessor.handleReturnValue(RequestResponseBodyMethodProces sor.java:189)org.springframework.web.method.support.HandlerMethodReturnValueHandle rComposite.handleReturnValue(HandlerMethodReturnValueHandlerComposite .java:69)org.springframework.web.servlet.mvc.method.annotation.ServletInvocabl eHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:122 )org.springframework.web.servlet.mvc.method.annotation.RequestMappingH andlerAdapter.invokeHandleMethod(RequestMappingHandlerAdapter.java:74 5)org.springframework.web.servlet.mvc.method.annotation.RequestMappingH andlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:686)org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapt er.handle(AbstractHandlerMethodAdapter.java:80)org.springframework.web.servlet.DispatcherServlet.doDispatch(Dispatch erServlet.java:925)org.springframework.web.servlet.DispatcherServlet.doService(Dispatche rServlet.java:856)org.springframework.web.servlet.FrameworkServlet.processRequest(Frame workServlet.java:936)org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServ let.java:838)javax.servlet.http.HttpServlet.service(HttpServlet.java:647)org.springframework.web.servlet.FrameworkServlet.service(FrameworkSer vlet.java:812)javax.servlet.http.HttpServlet.service(HttpServlet.java:728)org.apache.shiro.web.servlet.ProxiedFilterChain.doFilter(ProxiedFilte rChain.java:61)org.apache.shiro.web.servlet.AdviceFilter.executeChain(AdviceFilter.j ava:108)org.apache.shiro.web.servlet.AdviceFilter.doFilterInternal(AdviceFilt er.java:137)org.apache.shiro.web.servlet.OncePerRequestFilter.doFilter(OncePerReq uestFilter.java:125)org.apache.shiro.web.servlet.ProxiedFilterChain.doFilter(ProxiedFilte rChain.java:66)org.apache.shiro.web.servlet.AbstractShiroFilter.executeChain(Abstrac tShiroFilter.java:449)org.apache.shiro.web.servlet.AbstractShiroFilter$1.call(AbstractShiro Filter.java:365)org.apache.shiro.subject.support.SubjectCallable.doCall(SubjectCallab le.java:90)org.apache.shiro.subject.support.SubjectCallable.call(SubjectCallable .java:83)org.apache.shiro.subject.support.DelegatingSubject.execute(Delegating Subject.java:383)org.apache.shiro.web.servlet.AbstractShiroFilter.doFilterInternal(Abs tractShiroFilter.java:362)org.apache.shiro.web.servlet.OncePerRequestFilter.doFilter(OncePerReq uestFilter.java:125)org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(D elegatingFilterProxy.java:343)org.springframework.web.filter.DelegatingFilterProxy.doFilter(Delegat ingFilterProxy.java:260)org.springframework.web.filter.CharacterEncodingFilter.doFilterIntern al(CharacterEncodingFilter.java:88)org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerR equestFilter.java:107)</pre></p><p><b>root cause</b><pre>org.codehaus.jackson.map.JsonMappingException: Object is null (through reference chain:net.sf.json.JSONObject["data"]->net.sf.json.JSONArray[0] ->net.sf.json.JSONObject["createTime"]->net.sf.json.J SONNull["empty"])org.codehaus.jackson.map.JsonMappingException.wrapWithPath(JsonMappin gException.java:218)org.codehaus.jackson.map.JsonMappingException.wrapWithPath(JsonMappin gException.java:183)org.codehaus.jackson.map.ser.std.SerializerBase.wrapAndThrow(Serializ erBase.java:140)3原因分析:可能是json序列化的问题代码修改为@RequestMapping(value = "/query")public @ResponseBodyMap<String, Object> query(@RequestParam("startTime") String startTime, @RequestParam("endTime") String endTime,@RequestParam("oid") String oid, @RequestParam("cid") Integer cid,@RequestParam("pay_channel") String payChannel,@RequestParam("device_type") String deviceType,@RequestParam("phone") Integer phone,@RequestParam("perPage") Integer pageSize,@RequestParam("skipIndex") Integer startIndex) throws Exception {LogInfo info = populateQueryParam(startTime, endTime, oid, cid, payChannel, deviceType, phone, pageSize, startIndex);// 总记录数Long totalCount = logMoniterService.queryLogInfoCount(info);if (totalCount == null) {totalCount = 0L;}List<LogInfo> list = logMoniterService.queryLogInfo(info); Map<String, Object> result = new HashMap<String, Object>();result.put("success", true);result.put("data", list);result.put("error", "");result.put("totalRecords", totalCount);return result;}4、问题解决。
java记一次线上bug排查过程及总结
java记一次线上bug排查过程及总结Java 记一次线上Bug排查过程及总结导语在软件开发过程中,线上Bug的出现是无法避免的。
作为一名Java开发者,我们需要掌握一定的Bug排查技巧,以便在遇到问题时能够迅速定位并解决问题。
本文将分享一次线上Bug排查的过程及总结,希望对大家有所帮助。
一、问题现象近日,我们团队负责的一款Java Web应用在上线后出现了以下问题:1.部分用户反馈页面加载缓慢,甚至出现卡顿现象。
2.应用服务器CPU占用率较高,且频繁出现Full GC。
二、排查过程1.分析日志首先,我们查看了应用服务器的日志,发现了一些异常堆栈信息。
通过分析,我们初步判断是某个接口的调用链路存在问题。
2.定位问题接口通过查看接口调用日志,我们发现了一个接口的调用时间明显较长。
进一步分析代码,我们发现该接口在处理请求时,需要进行大量的计算,且计算过程中存在一个递归调用。
3.代码优化针对上述问题,我们对相关代码进行了以下优化:(1)将递归调用改为循环,减少函数调用栈深度。
(2)优化计算逻辑,减少不必要的计算。
(3)使用缓存技术,避免重复计算。
4.部署优化后的代码将优化后的代码部署到线上环境,观察了一段时间,发现页面加载速度有所提升,CPU占用率降低,Full GC次数减少。
三、总结1.日志分析是排查线上问题的重要手段,要善于利用日志定位问题。
2.对于性能瓶颈,要找到关键点进行优化。
在本例中,我们将递归调用改为循环,减少了函数调用栈深度,从而降低了CPU占用率。
3.优化计算逻辑,避免不必要的计算,可以有效提高应用性能。
4.合理使用缓存技术,可以减少重复计算,提高接口响应速度。
5.线上问题排查需要团队协作,共同解决问题。
通过本次线上Bug排查,我们不仅解决了问题,还积累了宝贵的经验。
SpringBoot项目中遇到的BUG问题及解决方法
SpringBoot项⽬中遇到的BUG问题及解决⽅法1.启动项⽬的时候报错1.Error starting ApplicationContext.To display the auto-configuration report re-run your application with 'debug' enabled.解决⽅法:在yml配置⽂件中加⼊debug: true,因为默认的话是false2.在集成mybatis时mapper包中的类没被扫描org.springframework.beans.factory.NoSuchBeanDefinitionException:No qualifying bean of type 'erMapper' available:expected at least 1 bean which qualifies as autowire candidate. Dependency annotations: {}解决⽅法:在springboot的启动类中加⼊@MapperScan("mapper类的路径")或者直接在Mapper类上⾯添加注解@Mapper,建议使⽤上⾯那种,不然每个mapper加个注解也挺⿇烦的3.在向数据库插⼊数据时报错"\r\n### Error updating database. Cause:com.mysql.jdbc.MysqlDataTruncation:Data truncation: Data too long for column 'password' at row 1\r\n###数据库表password这个字段太短了,应该设长点ng.ClassCastException:er cannot be cast to ng.Integer4.⽤mybatis查询时报错org.mybatis.spring.MyBatisSystemException:nested exception is org.apache.ibatis.binding.BindingException:Parameter 'user_type' not found. Available parameters are [2, 1, 0, param1, param2, param3]原因:@Param注解缺失,当只有⼀个参数时,Mapper接⼝中可以不使⽤public User getUser(String name);有多个参数时就必须使⽤public User getUser(@Param("name") String name,@Param("password") String password);5.Mybatis查询传⼊⼀个字符串传参数报错mapper接⼝:PkRecord findByPkStudentNumber(String pkStudentNumber);对应的mapper配置⽂件<select id="findByPkStudentNumber" resultMap="recordMap" >SELECT * FROM pk_record<where><if test="pkStudentNumber!=null">pk_student_number=#{pkStudentNumber}</if></where></select>然后就会报如下错误There is no getter for property named 'XXX' in 'class ng.String'原因:Mybatis默认采⽤ONGL解析参数,所以会⾃动采⽤对象树的形式取string.num值,引起报错。
项目中遇到的bug、问题总结
项⽬中遇到的bug、问题总结1. Cannot set property 'captcha' of undefined在node项⽬中使⽤svg-captcha⽣成验证码报错captcha的代码,这⾥有⼀个session.captcha,检查app.js,发现session没设置exports.captcha = async(req, res, next) => {// 创建验证码const captcha = svgCaptcha.create()// 验证码⽂本req.session.captcha = captcha.text// 设置响应内容类型res.type('svg') // 使⽤ejs等模块时如果报错 res.type('html)res.status(200).send(captcha.data)}在app.js中加⼊session就可以了const express = require('express')const app = express()const session = require('express-session')e(session({secret: 'keyboard cat',resave: false,saveUninitialized: true}))这种错误⼀般是没定义属性引起的,检查⼀下使⽤的变量是否都有引⼊2.Module build failed: Error: ENOENT: no such file or directory, open 'xxxxxxxxx'切换分⽀后报找不到⽂件的错误这种情况⼀般是你切换分⽀后你的⼩伙伴修改了代码提交,你切回来之后就有可能读不出修改的⽂件这时候强制使⽤远程分⽀覆盖本地分⽀就可以了git fetch --allgit reset --hard origin/master这⾥是写你⽤来覆盖的分⽀名称,⼀般就是你当前所在的分⽀git pull3../node_modules/_css-loader@0.28.11@css-loader??ref--11-1!./node_modules/_postcss-loader@2.1.6@postcss-loader/lib??ref--11-2!./node_modules/_sass-loader@7.1.0@sass-loader/lib/loader.js??ref--11-3!./src/components/main/financingManagement/financing/creditFrom/from.scss Module build failed: undefined ^ Media query expression must begin with '(' in E:\Project\F2B_v3.0\src\components\main\financingManagement\financing\creditFrom\from.scss (line 3, column 3)在项⽬中引⼊scss⽂件报错,.financingManaFinancingForm_box {// 引⼊的时候没有加;号,css⾥⾯结尾⼀定要写;号@import 'src/assets/css/document.scss';.authfile_title {text-align: center;}}4.(function (exports, require, module, __filename, __dirname) { import { check, validationResult } from '_express-validator@5.3.1@express-validator/check';在项⽬中引⼊资源错误 ,在项⽬中是这样写的,这样会报错import { check, validationResult } from '_express-validator@5.3.1@express-validator/check';如果引⼊多个资源, 必须使⽤const + requireconst { check, validationResult } = require('express-validator/check')5.TypeError: e() requires a middleware function启动项⽬报错在项⽬中多写了⼀个路由没有导出,启动时没有找到router的中间件const express = require('express')const questionCtrl = require('../controller/question.js')const router = express.Router()router.get('/questions/new', questionCtrl.showNew)module.exports = router //router需要导出6.Refused to apply style from '<URL>' because its MIME type ('text/html') is not a supported stylesheet MIME type, and strict MIME checking is enabled..在node项⽬中打开页⾯报错这是因为解析静态资源错误,检查⼀下静态资源的引⼊路径是否正确,然后重启⼀下项⽬,有时候不重启项⽬,这些解析资源的⼯作不会更改7.Cannot destructure property `user` of 'undefined' or 'null'页⾯报错这种是把⼀个对象结构赋值时报错的,原因是req.cookies没有值,let { user: cookieUser } = req.cookieslet { user: cookieUser } = undefind // 这样会报错,对象的结构赋值需要确定是⼀个对象8.$ vue -Vbash: vue: command not found找不到vue模块解决: npm install -g vuenpm install -g vue-clinpm install -g vue-clinpm WARN deprecated coffee-script@1.12.7: CoffeeScript on NPM has moved to "coffeescript" (no hyphen)安装vue-cli报错j解决: npm i -g coffeescriptnpm install -g vue-cli运⾏效果:$ vue -V2.9.6完成!9.vue create vuex-apivue create is a Vue CLI 3 only command and you are using Vue CLI 2.9.6.You may want to run the following to upgrade to Vue CLI 3:npm uninstall -g vue-clinpm install -g @vue/cli使⽤vue创建项⽬报错,create只⽀持vue cli 3版本,按照提⽰,卸载姐版本,npm uninstall -g vue-cli安装新版本 npm install -g @vue/cli npm install -g @vue/clinpm WARN deprecated cross-spawn-async@2.2.5: cross-spawn no longer requires a build toolchain, use it instead安装新版本vue-cli报错,解决⽅法: cnpm install -g @vue/cli重新运⾏$ vue create vuex-api? Your connection to the default yarn registry seems to be slow.Use https:// for faster installation? (Y/n)创建项⽬成功!。
Springmvc使用@RequestBody500错误
Springmvc使⽤@RequestBody500错误今天在使⽤@RequestBody的时候,遇到⼀个http500错误,记录⼀下让我们来看看我是怎么样错的,贴上代码@PostMapping("/User")public User AddUser(@RequestBody User user) {System.out.println(user);return user;}public class User {public User(String name, int age) { = name;this.age = age;}private String name;private int age;public String getName() {return name;}public void setName(String name) { = name;}public int getAge() {return age;}@Overridepublic String toString() {return "User{" +"name='" + name + '\'' +", age=" + age +'}';}public void setAge(int age) {this.age = age;}}使⽤postMan测试⼀下能不能打印出user居然500了⼀脸莫名其妙,为什么?其实原因很简单很低级,因为创建实例的时候,⾛的是User的⽆参构造⽅法,然后再⼀个⼀个set属性,我只写了有参构造,只要写上了有参构造,JDK是不会⾃动给你加上⽆参构造的,spring去找你的⽆参构造的时候发现没有,所以报错, 现在加上⽆参构造就OK了,看来以后还是得lombok。
SpringMVC报异常:org.springframework.web.util.Nes。。。
SpringMVC报异常:org.springframework.web.util.Nes。
在使⽤SpringMVC绑定基本类型(如String,Integer等)参数时,应通过@RequestParam注解指定具体的参数名称,否则,当源代码在⾮debug模式下编译后,运⾏时会引发HandlerMethodInvocationException异常,这是因为只有在debug模式下编译,其参数名称才存储在编译好的代码中。
譬如下⾯的代码会引发异常:Java代码@RequestMapping(value = "/security/login", method = RequestMethod.POST)public ModelAndView login(@RequestParam String userName, @RequestParam String password,HttpServletRequest request) {......................如果使⽤Eclipse编译不会在运⾏时出现异常,这是因为Eclipse默认是采⽤debug模式编译的,但是如果使⽤Ant通过javac任务编译的话就会出现异常,除⾮指定debug=”true”。
出现的异常如同:org.springframework.web.util.NestedServletException: Request processing failed; nested exception isorg.springframework.web.bind.annotation.support.HandlerMethodInvocationException:Failed to invoke handler method [public org.springframework.web.servlet.ModelAndViewcom.mypackage.security.controller.LoginController.login(ng.String,ng.String,javax.servlet.http.HttpServletRequest)]; nested exception isng.IllegalStateException: No parameter name specified for argument of type [ng.String], and no parameter name information found in class file either.org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:659)..........org.springframework.web.bind.annotation.support.HandlerMethodInvocationException: Failed to invoke handler method [publicorg.springframework.web.servlet.ModelAndViewcom.mypackage.security.controller.LoginController.login(ng.String,ng.String,javax.servlet.http.HttpServletRequest)]; nested exception isng.IllegalStateException: No parameter name specified for argument of type [ng.String], and no parameter name information found in class file either.org.springframework.web.bind.annotation.support.HandlerMethodInvoker.invokeHandlerMethod(HandlerMethodInvoker.java:171)..........ng.IllegalStateException: No parameter name specified for argument of type [ng.String], and no parameter name information found in class file either.org.springframework.web.bind.annotation.support.HandlerMethodInvoker.getRequiredParameterName(HandlerMethodInvoker.java:618) ..........最好的做法是通过@RequestParam注解指定具体的参数名称,如,上⾯的代码应该如此编写(注意@RequestParam部分):Java代码@RequestMapping(value = "/security/login", method = RequestMethod.POST)public ModelAndView login(@RequestParam("userName") String userName, @RequestParam("password") String password, HttpServletRequest request) { ......................。
解决SpringMVC使用@RequestBody注解报400错误的问题
解决SpringMVC使⽤@RequestBody注解报400错误的问题⼀般使⽤@RequestBody接收的时候报400都是传⼊的json字符串和对应封装的对象不对应造成的⾸先要注意封装的对象中的字段类型有没有Date类型或者int等类型的,如果有的话,在set⽅法中统⼀将传⼊的参数要调整为String类型在set⽅法中进⾏参数的转换⽐如有⼀个Date类型的字段private Date startTime;public Date getStartTime() {return startTime;}public void setStartTime(String startTime) {// 这⾥根据你的时间格式选择SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");try {this.startTime = dateFormat.parse(startTime);} catch (ParseException e) {this.startTime = null;}}这样写就可以了,不要将形参的类型写成Date类型,所以这⾥建议对实体类构建⼀个DTO,使⽤DTO进⾏封装前台的ajax发送如下:$.ajax({type : "POST",contentType : "application/json",url : xxxxx,// 请求路径data : JSON.stringify(data),// 将data的JSON对象转换为字符串{name:'value'}的格式success : function(msg) {},error : function() {}});后台的接受⽅法很简单@RequestMapping(value = "XXXXX.do", method = RequestMethod.POST)@ResponseBodypublic String saveInstCorNotice(@RequestBody EntityDTO entityDTO) {}以前总被坑,这⾥记录⼀下!补充知识:SpringMVC在拦截器中做权限控制,解决RequestBody获取问题做接⼝的权限控制,接⼝请求结构是JSON串,⽐较为难的是@RequestBody的获取⽹上的资料是先⼿动读出来,再使⽤⾃定义的封装将JSON串写回去感觉有点⿇烦,使⽤了新的思路在拦截器中,拦截需要做权限验证的请求,使⽤下⾯的⽅式,将权限校验跳转到Controller层中做String uri = request.getRequestURI();request.setAttribute("referenceUrl", uri);request.getRequestDispatcher(checkerUrl).forward(request, response);url是⽤来校验权限的Controller路径在Controller中可以使⽤@RequestBody注解拿到请求body,之后可以使⽤获取到的body信息校验权限,校验通过的,获取uri再次通过如下⽅式,跳转到真正要请求的Controller层request.getRequestDispatcher(uri).forward(request, response);注意,这⾥会有拦截器死循环的问题,当然因为@RequestBody只能读⼀次的特性,在第⼆次被拦截器拦截时就会因为请求Body为空抛异常。
SpringCloudGateway拦截器遇到的小坑汇总
SpringCloudGateway拦截器遇到的小坑汇总Spring Cloud Gateway是一个基于Spring Framework 5,Spring Boot 2和Project Reactor构建的API网关。
它可以实现请求路由、限流、熔断等功能,是构建微服务架构的重要组件之一、在使用Spring Cloud Gateway进行开发时,可能会遇到一些坑,下面将列举一些方便开发者了解和解决。
1.配置顺序问题在使用Spring Cloud Gateway配置路由时,需要注意配置顺序的问题。
如果两个路由规则的匹配条件相似,而且顺序错乱,可能会导致路由规则无法正确匹配。
因此,需要将具体的路由规则放在前面,而将通用的路由规则放在后面,以免匹配错误。
2.路由配置端口问题3.添加全局过滤器在使用Spring Cloud Gateway进行开发时,可以通过添加全局过滤器来实现一些通用的功能。
例如,可以添加一个全局日志过滤器来记录请求日志。
可以通过实现GatewayFilterFactory接口来创建自定义的全局过滤器。
4.转发请求头问题在进行请求转发时,如果需要将原始请求的一些请求头传递到目标URL,可以通过添加以下配置来实现:spring.cloud.gateway.forward-headers-strategy=native5.缓存问题当使用Gateway进行请求转发时,如果目标URL的响应结果有缓存,需要注意在缓存配置中添加适当的Cache-Control或ETag响应头,避免返回缓存结果。
6.限流问题在进行请求限流时,可以使用Spring Cloud Gateway的限流过滤器来实现。
可以通过添加以下配置来启用限流:spring.cloud.gateway.filter.headers.enabled=truespring.cloud.gateway.filter.headers.header-name=x-countspring.cloud.gateway.filter.headers.quota=107.自定义路由规则问题如果希望使用复杂的逻辑来配置路由规则,可以使用自定义的Predicate实现来实现。