java,反序列化的时候修改了类的包

数据库存了一些老框架序列化的字节码,由于代码迁移到新框架,所以修改了一些类的路径(即就是包名被修改了),导致反序列化这些字节码的时候抛ClassNotFound异常(如果包名一致不存在反序列化抛异常)。

byte[] dataBytes = getBytes();

ByteArrayInputStream in = new ByteArrayInputStream( dataBytes );
ObjectInputStream objIn = new ObjectInputStream( in );
objIn.readObject();  // 这里会抛NotFoundException

现在可以通过重写ObjectInputStream中方法的方式解决这个问题,代码如下:

新建一个类继承ObjectInputStream, 并重写resolveClass()方法

public class MyObjectInputStream extends ObjectInputStream
{
  private static Logger logger = LoggerFactory.getLogger( MyObjectInputStream .class );
  private static final String OLD_PACKAGE = "com.abc.test";
  private static final String NEW_PACKAGE = "com.test";
  public MyObjectInputStream ( InputStream arg0 ) throws IOException
  {
    super( arg0 );
  }
  
  @Override
  public Class< ? > resolveClass( ObjectStreamClass desc ) throws IOException, ClassNotFoundException
  {
    String name = desc.getName();
    try
    {
      if ( name.startsWith( OLD_VISION_PACKAGE ) )
      {
        name = name.replace( OLD_VISION_PACKAGE, NEW_VISION_PACKAGE );
        return Class.forName( name );
      }
    }
    catch ( ClassNotFoundException ex )
    {
      logger.warn( ex.getMessage() );
    }

    return super.resolveClass( desc );
  }
}

调用的时候替换ObjectInputStream 为这个MyObjectInputStream就行

byte[] dataBytes = getBytes();

ByteArrayInputStream in = new ByteArrayInputStream( dataBytes );
MyObjectInputStream objIn = new MyObjectInputStream( in );
objIn.readObject(); 

猜你喜欢

转载自blog.csdn.net/wessiyear/article/details/81302739