From 3c3c9ed121346f11743d5850b245f322542b2a32 Mon Sep 17 00:00:00 2001 From: lo1nt Date: Fri, 8 Mar 2024 17:02:01 +0800 Subject: [PATCH 1/2] fix: roll back previous throwable and stack trace element ser for compatibility --- .../io/StackTraceElementDeserializer.java | 59 +++++++++++++ .../hessian/io/ThrowableSerializer.java | 61 +++++++++++++ .../throwable/ReflectThrowableSerializer.java | 2 +- .../StackTraceElementDeserializer.java | 9 +- .../com/caucho/hessian/io/CompatibleTest.java | 86 +++++++++++++++++++ 5 files changed, 211 insertions(+), 6 deletions(-) create mode 100644 src/main/java/com/caucho/hessian/io/StackTraceElementDeserializer.java create mode 100644 src/main/java/com/caucho/hessian/io/ThrowableSerializer.java create mode 100644 src/test/java/com/caucho/hessian/io/CompatibleTest.java diff --git a/src/main/java/com/caucho/hessian/io/StackTraceElementDeserializer.java b/src/main/java/com/caucho/hessian/io/StackTraceElementDeserializer.java new file mode 100644 index 0000000..a8fc6b9 --- /dev/null +++ b/src/main/java/com/caucho/hessian/io/StackTraceElementDeserializer.java @@ -0,0 +1,59 @@ +/* + * Copyright (c) 2001-2004 Caucho Technology, Inc. All rights reserved. + * + * The Apache Software License, Version 1.1 + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in + * the documentation and/or other materials provided with the + * distribution. + * + * 3. The end-user documentation included with the redistribution, if + * any, must include the following acknowlegement: + * "This product includes software developed by the + * Caucho Technology (http://www.caucho.com/)." + * Alternately, this acknowlegement may appear in the software itself, + * if and wherever such third-party acknowlegements normally appear. + * + * 4. The names "Hessian", "Resin", and "Caucho" must not be used to + * endorse or promote products derived from this software without prior + * written permission. For written permission, please contact + * info@caucho.com. + * + * 5. Products derived from this software may not be called "Resin" + * nor may "Resin" appear in their names without prior written + * permission of Caucho Technology. + * + * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED + * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL CAUCHO TECHNOLOGY OR ITS CONTRIBUTORS + * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, + * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT + * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR + * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, + * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE + * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN + * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + * + * @author Scott Ferguson + */ + +package com.caucho.hessian.io; + +/** + * + * @author lo1nt + * @version StackTraceElementDeserializer.java, v 0.1 2024-03-08 16:46 lo1nt Exp $ + */ +@Deprecated +public class StackTraceElementDeserializer extends + com.caucho.hessian.io.throwable.StackTraceElementDeserializer { +} diff --git a/src/main/java/com/caucho/hessian/io/ThrowableSerializer.java b/src/main/java/com/caucho/hessian/io/ThrowableSerializer.java new file mode 100644 index 0000000..eef3ff1 --- /dev/null +++ b/src/main/java/com/caucho/hessian/io/ThrowableSerializer.java @@ -0,0 +1,61 @@ +/* + * Copyright (c) 2001-2004 Caucho Technology, Inc. All rights reserved. + * + * The Apache Software License, Version 1.1 + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in + * the documentation and/or other materials provided with the + * distribution. + * + * 3. The end-user documentation included with the redistribution, if + * any, must include the following acknowlegement: + * "This product includes software developed by the + * Caucho Technology (http://www.caucho.com/)." + * Alternately, this acknowlegement may appear in the software itself, + * if and wherever such third-party acknowlegements normally appear. + * + * 4. The names "Burlap", "Resin", and "Caucho" must not be used to + * endorse or promote products derived from this software without prior + * written permission. For written permission, please contact + * info@caucho.com. + * + * 5. Products derived from this software may not be called "Resin" + * nor may "Resin" appear in their names without prior written + * permission of Caucho Technology. + * + * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED + * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL CAUCHO TECHNOLOGY OR ITS CONTRIBUTORS + * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, + * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT + * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR + * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, + * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE + * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN + * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + * + * @author Scott Ferguson + */ + +package com.caucho.hessian.io; + +/** + * + * @author lo1nt + * @version ThrowableSerializer.java, v 0.1 2024-03-08 16:46 lo1nt Exp $ + */ +@Deprecated +public class ThrowableSerializer extends com.caucho.hessian.io.throwable.ReflectThrowableSerializer { + public ThrowableSerializer(Class clazz) { + super(clazz); + } +} diff --git a/src/main/java/com/caucho/hessian/io/throwable/ReflectThrowableSerializer.java b/src/main/java/com/caucho/hessian/io/throwable/ReflectThrowableSerializer.java index 048ffbb..921966d 100644 --- a/src/main/java/com/caucho/hessian/io/throwable/ReflectThrowableSerializer.java +++ b/src/main/java/com/caucho/hessian/io/throwable/ReflectThrowableSerializer.java @@ -10,7 +10,7 @@ import java.io.IOException; /** - * use under jdk 17 + * use under jdk < 17 * @author junyuan * @version ReflectThrowableSerializer.java, v 0.1 2023年05月06日 10:46 junyuan Exp $ */ diff --git a/src/main/java/com/caucho/hessian/io/throwable/StackTraceElementDeserializer.java b/src/main/java/com/caucho/hessian/io/throwable/StackTraceElementDeserializer.java index ab286d1..f1dfe53 100644 --- a/src/main/java/com/caucho/hessian/io/throwable/StackTraceElementDeserializer.java +++ b/src/main/java/com/caucho/hessian/io/throwable/StackTraceElementDeserializer.java @@ -82,15 +82,14 @@ public StackTraceElementDeserializer() { super(StackTraceElement.class); try { + // default, only read class, method, file and line + _defaultConstructor = StackTraceElement.class.getDeclaredConstructor(String.class, String.class, + String.class, int.class); if (_fields.size() > 4) { // available since java 9 _constructorJdk9 = StackTraceElement.class.getDeclaredConstructor(String.class, String.class, - String.class, String.class, - String.class, String.class, int.class); + String.class, String.class, String.class, String.class, int.class); } - // default, only read class, method, file and line - _defaultConstructor = StackTraceElement.class.getDeclaredConstructor(String.class, String.class, - String.class, int.class); } catch (Exception e) { log.log(Level.FINE, e.toString(), e); } diff --git a/src/test/java/com/caucho/hessian/io/CompatibleTest.java b/src/test/java/com/caucho/hessian/io/CompatibleTest.java new file mode 100644 index 0000000..0921c45 --- /dev/null +++ b/src/test/java/com/caucho/hessian/io/CompatibleTest.java @@ -0,0 +1,86 @@ +/* + * Ant Group + * Copyright (c) 2004-2024 All Rights Reserved. + */ +package com.caucho.hessian.io; + +import org.junit.Assert; +import org.junit.BeforeClass; +import org.junit.Test; + +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.IOException; + +/** + * + * @author lo1nt + * @version CompatibleTest.java, v 0.1 2024-03-08 16:58 lo1nt Exp $ + */ +public class CompatibleTest { + + Throwable t = null; + private static ByteArrayOutputStream os; + private static SerializerFactory factory; + + @BeforeClass + public static void setUp() { + factory = new TestSerializeFactory(); + os = new ByteArrayOutputStream(); + } + + { + Throwable x = null; + try { + x.getStackTrace(); + } catch (NullPointerException e) { + t = e; + } + } + + @Test + public void TestCreateCompatibleClass() { + try { + ThrowableSerializer ct = new ThrowableSerializer(RuntimeException.class); + StackTraceElementDeserializer cs = new StackTraceElementDeserializer(); + } catch (Throwable t) { + Assert.fail("should be no error"); + } + } + + @Test + public void TestSerialize() throws IOException { + os.reset(); + Hessian2Output output = new Hessian2Output(os); + + output.setSerializerFactory(factory); + output.writeObject(t); + output.flush(); + + ByteArrayInputStream is = new ByteArrayInputStream(os.toByteArray()); + Hessian2Input input = new Hessian2Input(is); + input.setSerializerFactory(factory); + Throwable actual = (Throwable) input.readObject(); + Assert.assertEquals(t.getStackTrace().length, actual.getStackTrace().length); + Assert.assertEquals(t.getMessage(), actual.getMessage()); + } + + private static class TestSerializeFactory extends SerializerFactory { + @Override + public Serializer getSerializer(Class cl) throws HessianProtocolException { + if (Throwable.class.isAssignableFrom(cl)) { + return new ThrowableSerializer(cl); + } + + return super.getSerializer(cl); + } + + @Override + public Deserializer getDeserializer(Class cl) throws HessianProtocolException { + if (StackTraceElement.class.isAssignableFrom(cl)) { + return new StackTraceElementDeserializer(); + } + return super.getDeserializer(cl); + } + } +} From 80307c1d2679e54a88aee8fab0bdb38f121efcb7 Mon Sep 17 00:00:00 2001 From: lo1nt Date: Fri, 8 Mar 2024 17:38:51 +0800 Subject: [PATCH 2/2] chore: format --- .../com/caucho/hessian/io/CompatibleTest.java | 20 +++++++++++++++---- 1 file changed, 16 insertions(+), 4 deletions(-) diff --git a/src/test/java/com/caucho/hessian/io/CompatibleTest.java b/src/test/java/com/caucho/hessian/io/CompatibleTest.java index 0921c45..b02244f 100644 --- a/src/test/java/com/caucho/hessian/io/CompatibleTest.java +++ b/src/test/java/com/caucho/hessian/io/CompatibleTest.java @@ -1,6 +1,18 @@ /* - * Ant Group - * Copyright (c) 2004-2024 All Rights Reserved. + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to You under the Apache License, Version 2.0 + * (the "License"); you may not use this file except in compliance with + * the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. */ package com.caucho.hessian.io; @@ -19,9 +31,9 @@ */ public class CompatibleTest { - Throwable t = null; + Throwable t = null; private static ByteArrayOutputStream os; - private static SerializerFactory factory; + private static SerializerFactory factory; @BeforeClass public static void setUp() {