Unsupported major.minor version 52.0Exception in thread "main" java.lang.UnsupportedClassVersionError: jodd/http/HttpRequest : Unsupported major.minor version 52.0 at java.lang.ClassLoader.defineClass1(Native Method)上jar包jvm版本高于jdk编译器版本,替换成旧jar或者更换高版本jdkhttps://zhidao.baidu.com/question/757441798969760124.htmlNoClassDefFoundError - jodd / exception / UncheckedExceptionjodd-lagarto模块依赖于jodd-core缺少类的模块修改了jdk在环境变量中的路径怎么cmd中的jdk版本没有变把path路径下的jdk配置放在前面即可%JAVA_HOME%\bin;%JAVA_HOME%\jre\bin;%SystemRoot%\system32;%SystemRoot%;%SystemRoot%\System32\Wbem;%SYSTEMROOT%\System32\WindowsPowerShell\v1.0\;
JSONObject response=new new JSONObject(); //括号内加true可以对内部进行排序response.clear(); //清除内容//将map转换成jsonobject,其中map为map类型:JSONObject records=new JSONObject(map);//JSON形式字符串转nutmapString result = testFeignRemote.queryResult(requestStr);map = new NutMap(result); 或者 map=JSON.parseObject(result ,NutMap.class); //map先转json串再转成json对象NutMap responseMap = changeResponse(map);String jsonString = JSON.toJSONString(responseMap);response = JSONObject.parseObject(jsonString);Map<String, Object> messageMap = JSON.parseObject(String.valueOf(message), Map.class);有不同的json解析包,但用法大同小异,注意其中方法的写法区别。例如:fastjson与sf.json,sf.json依赖时注意事项:<dependency> <groupId>net.sf.json-lib</groupId> <artifactId>json-lib</artifactId> <version>2.4</version> <classifier>jdk15</classifier></dependency>如果classifier不写的话可能会出错。intValue()方法可用来获取BigInt值的int值科普向:JSONObject-lib包是一个beans,collections,maps,java arrays和xml和JSON互相转换的包。构造方法如下:JSONObject();创建一个空的JSONObject对象JSONObject(boolean isNull);创建一个是否为空的JSONObject对象普通方法如下:fromBean(Object bean);静态方法,通过一个pojo对象创建一个JSONObject对象fromJSONObject(JSONObject object);静态方法,通过另外一个JSONObject对象构造一个JSONObject对象fromJSONString(JSONString string);静态方法,通过一个JSONString创建一个JSONObject对象toString();把JSONObject对象转换为json格式的字符串iterator();返回一个Iterator对象来遍历元素接下来就是一些put/get方法,需要普通的get方法和pot方法做一下强调说明,API中是这样描述的:A get method returns a value if one can be found, and throws an exception if one cannot be found. An opt method returns a default value instead of throwing an exception, and so is useful for obtaining optional values. JSONArray:A JSONArray is an ordered sequence of values.是一个final类,继承了Object,实现了JSON接口构造方法如下:JSONArray();构造一个空的JSONArray对象普通方法如下:fromArray(Object[] array);静态方法,通过一个java数组创建一个JSONArray对象fromCollection(Collection collection);静态方法,通过collection集合对象创建一个JSONArray对象fromString(String string);静态方法,通过一个json格式的字符串构造一个JSONArray对象toString();把JSONArray对象转换为json格式的字符串iterator();返回一个Iterator对象来遍历元素接下来同样是put/get方法……XMLSerializer:Utility class for transforming JSON to XML an back.一个继承自Object的类构造方法如下:XMLSerializer();创建一个XMLSerializer对象普通方法如下:setRootName(String rootName);设置转换的xml的根元素名称setTypeHintsEnabled(boolean typeHintsEnabled);设置每个元素是否显示type属性write(JSON json);把json对象转换为xml,默认的字符编码是UTF-8,需要设置编码可以用write(JSON json, String encoding)
/*五、分析以下需求,并用代码实现: (1)打印由7,8,9三个数组成的三位数,要求该三位数中任意两位数字不能相同; (2)打印格式最后的三位数字以空格分隔,如789 798 879 897 978 987。 注:要求使用StringBuilder来完成*/public class HomeWork05 { public static void main(String[] args) throws IOException {// 输入值并简单处理 Scanner sc = new Scanner(System.in); System.out.println("请输入起始值(0~9):"); int start=sc.nextInt(); System.out.println("请输入结束值(0~9):"); int end=sc.nextInt(); int bound=end-start+1; StringBuilder stringBuilder = new StringBuilder(); HashSet<String> set = new HashSet<>(); int cout=0; Random r = new Random(); long bCount=boundCount(bound); if (bCount>10000){ System.out.println("结果数超过10000为"+bCount+"计算会很慢,请按任意键继续"); System.in.read(); }// 穷举各种可能,小于正确结果个数持续执行 直到达到正确个数 while (set.size()<bCount) { int number = r.nextInt(bound) + start; if (!stringBuilder.toString().contains(String.valueOf(number))&&stringBuilder.toString().length()<bound){ stringBuilder.append(number); }else if (stringBuilder.toString().length()==bound){ set.add(stringBuilder.toString()); stringBuilder=new StringBuilder(); } } List ts = new ArrayList<>(set); Collections.sort(ts); //排序 System.out.println("结果数:"+ts.size()); System.out.println(ts.toString().replace("[","") .replace("]","") .replace(","," ")); } /** * 计算笛卡尔积运算去重后个数 * @param bound * @return */ public static long boundCount(int bound){ int sum=1; for (int i = 1; i <= bound; i++) { sum*=i; } return sum; }}
https://solo.b3log.org/
做几天代码重构,将A框架代码写成B框架,这就要打开两个窗口项目吧,如何让两个项目窗口各占屏幕一半呢?首先我是Windows10系统,介绍下强大快键键。点击其中一个idea窗口按 Windows键+←左箭头键(如果窗口没有半屏显示继续按←左箭头键直到半屏显示),同理点击另一个窗口按 Windows键+→右箭头键(有时左半屏成功后右半屏会显示目前开启的所有窗口供你选择,直接选择即可)。另外在idea中也可以开启两个代码文件代码左右分屏或上下分屏显示,具体操作见下图,只需将鼠标放在代码窗口的文件名上鼠标右击即可。例如下图鼠标光标放在了“DataGrid5.js”这个文件名上右击。图片来源于网络。(图片源于网络)
假如要编辑的代码窗口很多,默认tab上文件名超过一定数目会自动隐藏而只能点击下拉按钮下拉查找,这就比较麻烦了,如何让其全部显示呢?可参考下面:打开idea如图界面,点击Settings,打开Settings窗口,找到Editor Tabs(可利用搜索功能),取消勾选的 Show tabs in single row即可。
mybatis中出现这样错误,Could not set parameters for mapping: ParameterMapping{property='param'问题原来出在xml中,由于#号修饰的变量加了引号所致,问题如下:select code from sys_code where codename = '#{area}'解决方法也很简单,将引号去掉或者改为$,#{area}自带引号
err是运行期异常和错误反馈的输出流的方向System.err.println只能在屏幕上实现打印,即使你重定向了也一样用err打印出的 字符串,再eclipse的console会显示成红色标准输出往往是带缓存的,而标准出错没有缓存(默认设置,可以改)System.out.println("1");System.out.println("2");System.err.println("3");上述输出1、2顺序输出,3输出顺序不定
系统对异常的处理使用统一的异常处理流程:1、自定义异常类型。2、自定义错误代码及错误信息。3、对于可预知的异常由程序员在代码中主动抛出,由SpringMVC统一捕获。 可预知异常是程序员在代码中手动抛出本系统定义的特定异常类型,由于是程序员抛出的异常,通常异常信息比较齐全,程序员在抛出时会指定错误代码及错误信息,获取异常信息也比较方便。4、对于不可预知的异常(运行时异常)由SpringMVC统一捕获Exception类型的异常。 不可预知异常通常是由于系统出现bug、或一些不要抗拒的错误(比如网络中断、服务器宕机等),异常类型为RuntimeException类型(运行时异常)。5、可预知的异常及不可预知的运行时异常最终会采用统一的信息格式(错误代码+错误信息)来表示,最终也会随请求响应给客户端。1、在controller、service、dao中程序员抛出自定义异常;springMVC框架抛出框架异常类型2、统一由异常捕获类捕获异常,并进行处理3、捕获到自定义异常则直接取出错误代码及错误信息,响应给用户。4、捕获到非自定义异常类型首先从Map中找该异常类型是否对应具体的错误代码,如果有则取出错误代码和错误信息并响应给用户,如果从Map中找不到异常类型所对应的错误代码则统一为99999错误代码并响应给用户。5、将错误代码及错误信息以Json格式响应给用户。错误处理实战在共有项目中common中建exception包专门来存错误处理类.CustomExceptionpublic class CustomException extends RuntimeException { private ResultCode resultCode; public CustomException(ResultCode resultCode){ //异常信息 错误代码+异常信息 super("错误代码:"+resultCode.code()+"错误信息:"+resultCode.message()); this.resultCode=resultCode; } public ResultCode getResultCode(){ return this.resultCode; }}其中作为响应的结果的ResultCode接口为 定义了基础信息:public interface ResultCode { //操作是否成功,true为成功,false操作失败 boolean success(); //操作代码 int code(); //提示信息 String message();}ExceptionCastpublic class ExceptionCast { //使用静态方法抛出自定义异常 public static void cast(ResultCode resultCode){ throw new CustomException(resultCode); }}ExceptionCatch@ControllerAdvicepublic class ExceptionCatch { private static final Logger LOGGER = LoggerFactory.getLogger(ExceptionCatch.class); //使用EXCEPTIONS存放异常类型和错误代码的映射,ImmutableMap的特点的一旦创建不可改变,并且线程安全 private static ImmutableMap<Class<? extends Throwable>,ResultCode> EXCEPTIONS; //使用builder来构建一个异常类型和错误代码的异常 protected static ImmutableMap.Builder<Class<? extends Throwable>,ResultCode> builder = ImmutableMap.builder(); @ExceptionHandler(Exception.class) @ResponseBody public ResponseResult exception(Exception e){ LOGGER.error("catch exception : {}\r\nexception: ",e.getMessage(), e); if(EXCEPTIONS == null) EXCEPTIONS = builder.build(); ResultCode resultCode = EXCEPTIONS.get(e.getClass()); ResponseResult responseResult; if (resultCode != null) { responseResult = new ResponseResult(resultCode); } else { responseResult = new ResponseResult(CommonCode.SERVER_ERROR); } return responseResult; } //捕获CustomEcception异常 @ExceptionHandler(CustomException.class) @ResponseBody public ResponseResult customException(CustomException e) { LOGGER.error("catch exception : {}\\r\\nexception: ", e.getMessage(), e); ResultCode resultCode = e.getResultCode(); ResponseResult responseResult = new ResponseResult(resultCode); return responseResult; } static{ //在这里加入一些基础的异常类型判断 builder.put(HttpMessageNotReadableException.class,CommonCode.INVALID_PARAM); }}CommonCodeimport lombok.ToString;@ToStringpublic enum CommonCode implements ResultCode{ INVALID_PARAM(false,10003,"非法参数!"), SUCCESS(true,10000,"操作成功!"), FAIL(false,11111,"操作失败!"), UNAUTHENTICATED(false,10001,"此操作需要登陆系统!"), UNAUTHORISE(false,10002,"权限不足,无权操作!"), SERVER_ERROR(false,99999,"抱歉,系统繁忙,请稍后重试!");// private static ImmutableMap<Integer, CommonCode> codes ; //操作是否成功 boolean success; //操作代码 int code; //提示信息 String message; private CommonCode(boolean success,int code, String message){ this.success = success; this.code = code; this.message = message; } @Override public boolean success() { return success; } @Override public int code() { return code; } @Override public String message() { return message; }}CmsCodeimport lombok.ToString;@ToStringpublic enum CmsCode implements ResultCode { CMS_ADDPAGE_EXISTSNAME(false,24001,"页面名称已存在!"), CMS_GENERATEHTML_DATAURLISNULL(false,24002,"从页面信息中找不到获取数据的url!"), CMS_GENERATEHTML_DATAISNULL(false,24003,"根据页面的数据url获取不到数据!"), CMS_GENERATEHTML_TEMPLATEISNULL(false,24004,"页面模板为空!"), CMS_GENERATEHTML_HTMLISNULL(false,24005,"生成的静态html为空!"), CMS_GENERATEHTML_SAVEHTMLERROR(false,24006,"保存静态html出错!"), CMS_COURSE_PERVIEWISNULL(false,24007,"预览页面为空!"); //操作代码 boolean success; //操作代码 int code; //提示信息 String message; private CmsCode(boolean success, int code, String message){ this.success = success; this.code = code; this.message = message; } @Override public boolean success() { return success; } @Override public int code() { return code; } @Override public String message() { return message; }}服务层add方法添加错误处理public CmsPageResult add(CmsPage cmsPage) { if (cmsPage==null) ExceptionCast.cast(CommonCode.INVALID_PARAM);//抛出通用错误类中的无效参数 //检验页面是否存在 根据页面名称 站点id 页面path查询 CmsPage cmsPage1 = cmsPageRepository.findByPageNameAndSiteIdAndPageWebPath(cmsPage.getPageName(), cmsPage.getSiteId(), cmsPage.getPageWebPath()); /*if (cmsPage1 == null) { cmsPage.setPageId(null);//添加页面主键由spring data自动生成 cmsPageRepository.save(cmsPage); //返回结果 CmsPageResult cmsPageResult = new CmsPageResult(CommonCode.SUCCESS, cmsPage); return cmsPageResult; }else { //如果不等于null就是有页面 添加失败抛出已存在页面异常 ExceptionCast.cast(CmsCode.CMS_ADDPAGE_EXISTSNAME); } return new CmsPageResult(CommonCode.FAIL, null);//如果存在则返回null 失败信息*/ //先列出所有错误再执行正确执行结果 if (cmsPage1!=null){ ExceptionCast.cast(CmsCode.CMS_ADDPAGE_EXISTSNAME); } cmsPage.setPageId(null);//添加页面主键由spring data自动生成 cmsPageRepository.save(cmsPage); //返回结果 return new CmsPageResult(CommonCode.SUCCESS, cmsPage);}注意:启动类上要加上扫描异常处理类所在位置的包,例如:@ComponentScan(basePackages={"com.xuecheng.framework"})