java 获取apk版本号_Java 怎么获取 Android APK 版本信息 有没有不使用第三方jar包的方式?...

贴 UNZip 代码给你

package com.rekoe.decode;

import java.io.ByteArrayOutputStream;

import java.io.File;

import java.io.FileFilter;

import java.io.FileInputStream;

import java.util.HashSet;

import java.util.Set;

import java.util.zip.ZipEntry;

import java.util.zip.ZipInputStream;

import org.nutz.lang.Files;

import org.nutz.lang.Lang;

import org.nutz.lang.Streams;

import org.nutz.lang.util.Callback2;

import org.nutz.lang.util.Disks;

import org.nutz.lang.util.FileVisitor;

import org.nutz.log.Log;

import org.nutz.log.Logs;

import android.content.res.AXmlResourceParser;

public abstract class UNZip {

private final static Log log = Logs.get();

private static final ThreadLocal NAME = new ThreadLocal();

private static final float[] RADIX_MULTS = { 0.0039063F, 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", "", "", "", "", "", "" };

public static void getZipInfo(File file, final Callback2 callback, final String filter, String... suffixs) throws Exception {

NAME.set(new StringBuffer());

final Set suffix = new HashSet();

suffix.addAll(Lang.array2list(suffixs));

FileFilter ff = new FileFilter() {

public boolean accept(File pathname) {

if (pathname.isDirectory())

return true;

return suffix.contains(Files.getSuffixName(pathname));

}

};

FileVisitor fv = new FileVisitor() {

public void visit(File file) {

if (file.isDirectory())

return;

byte[] bytes = getInfoFile(file, filter);

if (bytes == null) {

log.errorf("Can not find file %s", filter);

return;

}

callback.invoke(bytes, file);

}

};

Disks.visitFile(file, fv, ff);

}

protected static byte[] getInfoFile(File apkFile, String filter) {

FileInputStream fis = null;

ByteArrayOutputStream fos = null;

ZipInputStream zis = null;

try {

fis = new FileInputStream(apkFile);

zis = new ZipInputStream(fis);

ZipEntry zipEntry = null;

while ((zipEntry = zis.getNextEntry()) != null) {

String name = zipEntry.getName();

if (log.isDebugEnabled()) {

log.debug(name);

}

if (Lang.equals(filter, name)) {

fos = new ByteArrayOutputStream();

byte[] buffer = new byte[1024];

int n = 0;

while ((n = zis.read(buffer, 0, buffer.length)) != -1) {

fos.write(buffer, 0, n);

}

break;

}

}

zis.closeEntry();

zipEntry = null;

return fos.toByteArray();

} catch (Exception e) {

log.error(e);

} finally {

Streams.safeClose(fos);

Streams.safeClose(zis);

Streams.safeClose(fis);

}

return null;

}

public static void getAndroidManifestInfo(byte[] bytes) {

try {

AXmlResourceParser parser = new AXmlResourceParser();

StringBuilder indent = new StringBuilder(10);

parser.open(Streams.wrap(bytes));

while (true) {

int type = parser.next();

if (type == 1) {

return;

}

switch (type) {

case 0:

log("<?xml version=\"1.0\" encoding=\"utf-8\"?>", new String[0]);

break;

case 2:

log("%s

indent.append("\t");

int namespaceCountBefore = parser.getNamespaceCount(parser.getDepth() - 1);

int namespaceCount = parser.getNamespaceCount(parser.getDepth());

for (int i = namespaceCountBefore; i != namespaceCount; ++i) {

log("%sxmlns:%s=\"%s\"", new Object[] { indent, parser.getNamespacePrefix(i), parser.getNamespaceUri(i) });

}

for (int i = 0; i != parser.getAttributeCount(); ++i) {

log("%s%s%s=\"%s\"", new Object[] { indent, getNamespacePrefix(parser.getAttributePrefix(i)), parser.getAttributeName(i), getAttributeValue(parser, i) });

}

log("%s>", new Object[] { indent });

break;

case 3:

indent.setLength(indent.length() - "\t".length());

log("%s%s%s>", new Object[] { indent, getNamespacePrefix(parser.getPrefix()), parser.getName() });

break;

case 4:

case 1:

break;

}

}

} catch (Exception e) {

log.error(e);

}

}

private static String log(String format, Object[] arguments) {

String str = String.format(format, arguments);

NAME.get().append(str).append("\n");

return str;

}

private static String getNamespacePrefix(String prefix) {

if ((prefix == null) || (prefix.length() == 0)) {

return "";

}

return prefix + ":";

}

public static final StringBuffer getName() {

return NAME.get();

}

private static String getAttributeValue(AXmlResourceParser parser, int index) {

int type = parser.getAttributeValueType(index);

int data = parser.getAttributeValueData(index);

if (type == 3) {

return parser.getAttributeValue(index);

}

if (type == 2) {

return String.format("?%s%08X", new Object[] { getPackage(data), Integer.valueOf(data) });

}

if (type == 1) {

return String.format("@%s%08X", new Object[] { getPackage(data), Integer.valueOf(data) });

}

if (type == 4) {

return String.valueOf(Float.intBitsToFloat(data));

}

if (type == 17) {

return String.format("0x%08X", new Object[] { Integer.valueOf(data) });

}

if (type == 18) {

return ((data != 0) ? "true" : "false");

}

if (type == 5) {

return Float.toString(complexToFloat(data)) + DIMENSION_UNITS[(data & 0xF)];

}

if (type == 6) {

return Float.toString(complexToFloat(data)) + FRACTION_UNITS[(data & 0xF)];

}

if ((type >= 28) && (type <= 31)) {

return String.format("#%08X", new Object[] { Integer.valueOf(data) });

}

if ((type >= 16) && (type <= 31)) {

return String.valueOf(data);

}

return String.format("<0x%X, type 0x%02X>", new Object[] { Integer.valueOf(data), Integer.valueOf(type) });

}

private static float complexToFloat(int complex) {

return ((complex & 0xFFFFFF00) * RADIX_MULTS[(complex >> 4 & 0x3)]);

}

private static String getPackage(int id) {

if (id >>> 24 == 1) {

return "android:";

}

return "";

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
APK文件中,主清单属性(Main Manifest Attribute)是指在清单文件(Manifest file)中定义的<manifest>元素。这个元素包含了应用程序的基本信息,如包名、版本号、应用程序图标等。然而,在某些情况下,APK文件可能没有主清单属性。 当APK文件中没有主清单属性时,可能会导致应用程序无法正常运行或被系统识别。这种情况通常发生在以下两种情况下: 1. 清单文件丢失:APK文件中可能没有包含清单文件,或者清单文件被意外删除或损坏。在这种情况下,应用程序将无法找到必要的信息来启动和运行。 2. 清单文件错误:APK文件中的清单文件可能存在错误,导致主清单属性无法正确解析。这可能是由于手动编辑清单文件时出现的错误,或者使用了不兼容的工具生成了错误的清单文件。 为了解决这个问题,可以尝试以下方法: 1. 检查清单文件:确保APK文件中包含正确的清单文件,并且没有被损坏。可以使用APK解压工具(如apktool)来提取APK文件中的清单文件,并检查其中的内容。 2. 修复清单文件:如果清单文件存在错误,可以手动编辑清单文件,确保主清单属性被正确定义。可以参考Android官方文档或其他可靠资源来了解清单文件的正确格式和属性。 3. 重新打包APK:如果以上方法无法解决问题,可以尝试使用APK打包工具重新打包APK文件。这将重新生成清单文件,并确保主清单属性被正确添加。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值