三星QMG文件格式分析

最近有同事想给自己的三星机器换一个开机动画,

原以为只是换一个bootanimation.zip的问题,结果发现三星用的是自己的动画格式,

后缀名为qmg的文件,在网上找了一下似乎没有现成的工具可以修改。

几乎清一色的都是root后更换开机动画方式为bootanimation的方式。


于是对这个QMG文件产生了点兴趣,分析了一下其文件格式,虽然没有完全分析出来但也写出来我已经完成的分析,以便后来者省点力气。


1. QMG文件的组织结构


QMG文件是由一大堆的子节点组成。每个节点的数据格式一样。


2. QMG文件节点的组织结构


每一个QMG文件节点都是又节点头以及节点主体组成。


3. QMG文件节点的Header结构

每个节点头长度为32字节,结构如下:


其中:

width: 表示屏幕宽度

height: 表示屏幕高度

具体的数值: 如(51 4D 0B 00 80 00) 表示固定数值。

item_length: 表示此节点的长度(包括节点头自己在内)

item_num: 表示此文件内包含的节点总数

item_id: 表示当前节点的节点序号(从1开始,到item_num结束)

Xdata_start: 本节点的特殊数据起始偏移量(相对节点头的偏移量)

Xdata_end: 问节点的特殊数据结束偏移量(相对节点头的偏移量)

起名为Xdata是因为这段数据的具体用途我也不清楚,但通过数据分析,它确实存在。

我的猜想是,Xdata可能是用于解压缩或解密用的字典或密钥之类的数据


下面是几个节点的Header例子:



我尝试过直接将Header之外的主体部分单独抠出来,使用各种图片工具都无法识别。

怀疑其内可能确实存在某些加密或压缩算法。


  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您可以使用以下代码将PEM格式的公钥转换为PublicKey对象: ```java import java.io.BufferedReader; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.io.StringReader; import java.security.KeyFactory; import java.security.PublicKey; import java.security.spec.X509EncodedKeySpec; import javax.security.cert.CertificateException; import javax.security.cert.X509Certificate; public class PEMUtils { /** * 将PEM格式的公钥转换为PublicKey对象 * * @param pemString PEM格式的公钥字符串 * @return PublicKey对象 */ public static PublicKey getPublicKeyFromPem(String pemString) throws Exception { // 移除PEM文件头和尾部 pemString = pemString.replace("-----BEGIN PUBLIC KEY-----\n", ""); pemString = pemString.replace("\n-----END PUBLIC KEY-----", ""); // 解码PEM字符串 byte[] encoded = android.util.Base64.decode(pemString, android.util.Base64.DEFAULT); // 创建X.509证书对象 X509Certificate cert = X509Certificate.getInstance(encoded); // 获取公钥 return cert.getPublicKey(); } } ``` 示例用法: ```java String pemString = "-----BEGIN PUBLIC KEY-----\n" + "MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAx5tZzZiJgZvVZ6ZL9gqJ\n" + "e4tJ1OoebVzUWjDQ2e0J4y0dHkUQv9gJmnzrGdGyj6HKKkOd1gIe0yN6+eagjE4x\n" + "L3zGzQq2fZLcg8lNp8fFzg3jv3sk5J+qzjYtVnWm1PdC+MIqJgOeVrXGxN4m6J5A\n" + "P5q8LdQYkzrFf0zrP2yQ3lmqLXH9BJU4l+Jj/3RvHJztg8sFy3CjzZ5ZQ5aKuUJ8\n" + "xitq8aXHdP6RBsFqjVvY4R5fk5+YI/lxLpJgUJvz8IYqW4ZbVFq6fP5QkUvXJk4q\n" + "1Xm2B0W2uJMWfKJ3e9QmG6wG5NwqfGvF3d4B9/oxnfK1fZS+3W4sV5nKK7dDyEaQ\n" + "IQIDAQAB\n" + "-----END PUBLIC KEY-----\n"; PublicKey publicKey = PEMUtils.getPublicKeyFromPem(pemString); ``` 请注意,此示例代码中使用了Android自带的Base64编码解码方法,您还需要导入`java.security.cert.X509Certificate`类和`javax.security.cert.CertificateException`异常。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值