`
3213213333332132
  • 浏览: 79905 次
社区版块
存档分类
最新评论

java解析APK

    博客分类:
  • java
阅读更多
解析apk有两种方法
1、结合安卓提供apktool工具,用java执行cmd解析命令获取apk信息
2、利用相关jar包里的集成方法解析apk

这里只给出第二种方法,因为第一种方法在linux服务器下会出现不在控制范围之内的结果。

public class ApkUtil
{
	/**
	 * 日志对象
	 */
	private static Logger	    log	              = LoggerFactory.getLogger(ApkUtil.class);
	
	private static final float	RADIX_MULTS[]	  = { 0.00390625F, 3.051758E-005F, 1.192093E-007F, 4.656613E-010F };
	
	private static final String	DIMENSION_UNITS[]	= { "px", "dip", "sp", "pt", "in", "mm", "", "" };
	
	private static final String	FRACTION_UNITS[]	= { "%", "%p", "", "", "", "", "", "" };
	
	/**
	 * 获取apk信息
	 * 
	 * @param apkPath
	 * @return
	 */
	public static String[] getApkInfo(String apkName)
	{
		// apk信息的返回结果
		final String[] apkResult = new String[3];
		ZipFile zipFile = null;
		try
		{
			final String apkPath = Toolkit.getTomcatRealPath() + CommonConstant.UPLOAD_SOFTVERSION + apkName;
			// 获得一个解压文件对象
			zipFile = new ZipFile(apkPath);
			// 将解压文件对象转列举对象
			final Enumeration enumeration = zipFile.entries();
			ZipEntry zipEntry = null;
			// 遍历列举对象元素
			while (enumeration.hasMoreElements())
			{
				// 获得一个解压条目对象
				zipEntry = (ZipEntry) enumeration.nextElement();
				if (zipEntry.isDirectory())
				{
					
				}
				else
				{
					// 获得名为AndroidManifest.xml的文件
					if ("AndroidManifest.xml".equals(zipEntry.getName()))
					{
						try
						{
							final AXmlResourceParser parser = new AXmlResourceParser();
							parser.open(zipFile.getInputStream(zipEntry));
							// 遍历文件里的内容
							while (true)
							{
								final int type = parser.next();
								if (type == XmlPullParser.END_DOCUMENT)
								{
									break;
								}
								switch (type)
								{
								// 满足条件开始遍历内容提取需要的信息
									case XmlPullParser.START_TAG: {
										for (int i = 0; i != parser.getAttributeCount(); ++i)
										{
											if ("package".equals(parser.getAttributeName(i)))
											{
												apkResult[0] = ApkUtil.getAttributeValue(parser, i);
											}
											else if ("versionCode".equals(parser.getAttributeName(i)))
											{
												apkResult[1] = ApkUtil.getAttributeValue(parser, i);
											}
											else if ("versionName".equals(parser.getAttributeName(i)))
											{
												apkResult[2] = ApkUtil.getAttributeValue(parser, i);
											}
											
										}
									}
								}
							}
						}
						catch (final Exception e)
						{
							ApkUtil.log.error("get file fail...!", e);
						}
					}
					
				}
			}
		}
		catch (final IOException e)
		{
			ApkUtil.log.error("analyzing fail...", e);
		}
		finally
		{
			if (zipFile != null)
			{
				try
				{
					zipFile.close();
				}
				catch (final IOException e)
				{
					ApkUtil.log.error("Zipfile close fail.", e);
				}
			}
		}
		
		return apkResult;
	}
	
	private static String getAttributeValue(AXmlResourceParser parser, int index)
	{
		final int type = parser.getAttributeValueType(index);
		final int data = parser.getAttributeValueData(index);
		if (type == TypedValue.TYPE_STRING)
		{
			return parser.getAttributeValue(index);
		}
		if (type == TypedValue.TYPE_ATTRIBUTE)
		{
			return String.format("?%s%08X", ApkUtil.getPackage(data), data);
		}
		if (type == TypedValue.TYPE_REFERENCE)
		{
			return String.format("@%s%08X", ApkUtil.getPackage(data), data);
		}
		if (type == TypedValue.TYPE_FLOAT)
		{
			return String.valueOf(Float.intBitsToFloat(data));
		}
		if (type == TypedValue.TYPE_INT_HEX)
		{
			return String.format("0x%08X", data);
		}
		if (type == TypedValue.TYPE_INT_BOOLEAN)
		{
			return data != 0 ? "true" : "false";
		}
		if (type == TypedValue.TYPE_DIMENSION)
		{
			return Float.toString(ApkUtil.complexToFloat(data))
			        + ApkUtil.DIMENSION_UNITS[data & TypedValue.COMPLEX_UNIT_MASK];
		}
		if (type == TypedValue.TYPE_FRACTION)
		{
			return Float.toString(ApkUtil.complexToFloat(data))
			        + ApkUtil.FRACTION_UNITS[data & TypedValue.COMPLEX_UNIT_MASK];
		}
		if (type >= TypedValue.TYPE_FIRST_COLOR_INT && type <= TypedValue.TYPE_LAST_COLOR_INT)
		{
			return String.format("#%08X", data);
		}
		if (type >= TypedValue.TYPE_FIRST_INT && type <= TypedValue.TYPE_LAST_INT)
		{
			return String.valueOf(data);
		}
		return String.format("<0x%X, type 0x%02X>", data, type);
	}
	
	private static String getPackage(int id)
	{
		if (id >>> 24 == 1)
		{
			return "android:";
		}
		return "";
	}
	
	public static float complexToFloat(int complex)
	{
		return (complex & 0xFFFFFF00) * ApkUtil.RADIX_MULTS[complex >> 4 & 3];
	}


jar包在下面下载
0
2
分享到:
评论

相关推荐

    java解析apk文件

    首先,Java解析APK主要依赖于对ZIP文件格式的理解,因为APK本质上就是一个ZIP文件,其结构遵循特定的Android规范。你可以使用Java内置的`java.util.zip`包来读取和解压APK,然后提取所需的元数据。以下是一些关键...

    Java解析apk包

    Java解析APK包是一项常见的技术,主要用于逆向工程、安全分析或者自动化工具的实现。当我们遇到Java解析APK时桌面图标问题提示的问题,这通常涉及到APK的资源解析和AndroidManifest.xml的处理。 首先,我们要理解...

    Java解析apk/ipa读取包名、版本名、版本号等等信息源码

    以上就是关于使用Java解析APK/IPA读取包名、版本名、版本号等信息的详细知识。通过理解这两种文件的结构以及Java的文件处理能力,你可以轻松地实现这些功能,并根据需要扩展到其他元数据的读取。希望这个指南对你...

    Java解析apk文件

    本篇文章将深入探讨如何使用Java解析APK文件,提取其中的关键信息,包括版本号码、版本名称、包名、权限、最低支持的Android平台版本、SDK版本以及应用程序的相关元数据。 首先,我们需要了解APK文件的结构。APK是...

    Java解析apk所需jar包

    Java解析APK所需jar包是Java开发者在处理Android应用程序(APK)时需要用到的一个工具集。这个jar包包含了处理APK文件所必需的类库,它允许开发者通过编程方式读取、分析和修改APK的内容,这对于理解APK的结构、调试...

    java解析apk信息

    这段代码展示了如何利用Java和JDOM库解析APK文件中的`AndroidManifest.xml`,并提取出包名、版本信息以及申请的权限。记得替换`apkPath`为你实际APK文件的路径。`license.txt`文件通常包含软件许可协议信息,与解析...

    java实现解析APK

    本篇将详细介绍如何使用Java和AAPT(Android Asset Packaging Tool)来解析APK,尤其适用于处理加密或加壳的APK。 首先,APK实际上是一个ZIP格式的压缩包,包含了AndroidManifest.xml、资源文件、dex字节码等。传统...

    Java解析Apk信息

    本篇文章将详细探讨如何使用Java解析APK信息,以及相关的核心概念和技术。 首先,我们需要了解APK文件的结构。APK是Android应用的打包格式,它实际上是一个ZIP文件,包含了应用的所有资源、类文件、清单文件...

    Java解析APK, AXMLPrinter2.jar

    当需要对APK进行逆向工程或者分析时,Java解析APK的方法就显得尤为重要。这里我们将深入探讨如何使用AXMLPrinter2.jar工具来提取APK中的versionCode和versionName,这两个属性对于了解应用的版本状态至关重要。 ...

Global site tag (gtag.js) - Google Analytics