
以微博为例:
1、打开浏览器-查看-查看源代码,在代码中找到['oid'] =或者['uid'] = ,后面的数字就是如果是你自己的微博代码。
2、如果查看的是别人微博的UID,那么上面显示的UID还是你自己的微博UID代码,而OID才你要找的别人微博的微博代码。
3、所以如果查看微博源码的方式获取UID,那么只要右键打开源码页面然后找到第19行的OID就可以了,OID后面的数字就是你要找的微博的UID我就是用这种方法查看到的。
一般android系统会自动为应用生成一个uid,并且每个应用会被分配不同的UID ,用于管理各个应用的权限以及数据共享。。。其次我查了一些资料。在AndroidMenifestxml中 在<manifest>标签里面增加 android:sharedUserId="xxxx",“xxxx”就是你自定义的uid了。。
第一个方法简单点,不过需要在Android系统源码的环境下用make来编译:
1 在应用程序的AndroidManifestxml中的manifest节点中加入android:sharedUserId="androiduidsystem"这个属性。
2 修改Androidmk文件,加入LOCAL_CERTIFICATE := platform这一行
3 使用mm命令来编译,生成的apk就有修改系统时间的权限了。()
第二个方法
1 同上,加入android:sharedUserId="androiduidsystem"这个属性。
2 使用eclipse编译出未签名apk文件,
3 用google带的签名来签名
最最后还说下,这个android:sharedUserId属性不只可以把apk放到系统进程中,也可以配置多个APK运行在一个进程中,这样可以共享数据,应该会很有用的。如何使Android应用程序获取系统权限
Android 里的 UID 是 跟随着「软件」(例如 Android 应用程序)。 由于每个应用程序都有个 UID,只有带着此 UID,才能存取该 UID 所涵盖的有关资料。就跟安装软件的附件一样吧。
android中有时候需要获取应用的签名信息,签名信息一般有:公钥,算法名,MD5值,序列号。要想获取这些信息首先该APK应用要有系统权限。
1 在配置文件里添加系统权限:android:sharedUserId="androiduidsystem"
2 获取签名信息的字符信息:
String signature_key = "";
try{
PackageInfo packageInfo = contextgetPackageManager()getPackageInfo(pkgName,
PackageManagerGET_SIGNATURES);
Signature[] signatures =
packageInfosignatures;
SignatureKeyparseSignature(signatures[0]toByteArray());
} catch (NameNotFoundException e) {
eprintStackTrace();
} catch (NullPointerException e) {
eprintStackTrace();
}
(1)其中packageInfo 得到的是指定包名的签名信息的字符串。另提及多说一句:在程序中我们一般使用
List list =
mPackageManagergetInstalledPackages(0);来得到所有的安装包的信息,这其中包括应用名,包名,大小
(2)
其中[]signatures里是存放的签名的字符串数组。我们一般取用第一个signatures[0]来做为该应用的签名信息。这里有一个疑惑就是为什么得到的是一个字符串的数组列表,而不是一个字符串,也有的开发者采用:
StringBuilder builder = new StringBuilder();
for(Signature sign: signatures
){
builderappend(signtoCharsString());
builderappend("/n");
}来得到所有的签名信息。在这里我验证过,signatures
的长度为1,所以指定apk的签名信息就为signatures[0]。
至于第二种方法有待发现。
3 获取签名的MD5值
public static final String getMD5String(byte[] paramArrayOfByte)
{
char[] asciiTable = { 48, 49, 50, 51, 52, 53, 54, 55, 56, 57,
97, 98, 99, 100, 101, 102 }; // ascii表对应的数字和字符的编码
try
{
MessageDigest md5MessageDigest =
MessageDigestgetInstance("MD5");
md5MessageDigestupdate(paramArrayOfByte);//
byte[]
tempByte = md5MessageDigestdigest();
int i =
tempBytelength;
char[] tempChar = new char[i
2];
int j = 0;
int k =
0;
while (true) { //
将二进制数组转换成字符串
if (j >= i)
{
return new
String(tempChar);
}
int m
= tempByte[j];
int n = k +
1;
tempChar[k] = asciiTable[(0xF & m >>>
4)];
k = n +
1;
tempChar[n] = asciiTable[(m &
0xF)];
j++;
}
}
catch (Exception e)
{
eprintStackTrace();
}
return
null;
}
(1) 其中参数就是上一步得到的签名的byte数组。
4 获取公钥,签名算法,签名序列号
public static void parseSignature(byte[] signature)
{
try
{
CertificateFactory
certFactory =
CertificateFactorygetInstance("X509");
X509Certificate cert = (X509Certificate) certFactorygenerateCertificate(new
ByteArrayInputStream(signature));
String pubKey =
certgetPublicKey()toString(); //公钥
String signNumber =
certgetSerialNumber()toString();
Systemoutprintln("signName:" +
certgetSigAlgName());//算法名
Systemoutprintln("pubKey:" +
pubKey);
Systemoutprintln("signNumber:" +
signNumber);//证书序列编号
Systemoutprintln("subjectDN:"+certgetSubjectDN()toString());
} catch (CertificateException e)
{
eprintStackTrace();
}
}
5 电脑查看APK签名信息
查看三方应用或是系统应用签名
用winrar打开待查看的apk,将其中META-INF文件夹解压出来,得到其中的CERTRSA文件
1keytool
-printcert -file META-INF/CERTRSA
命令是:keytool -printcert -file
<签名文件RSA的路径>
2jarsigner -verify -verbose -certs Superuserapk
此条未验证成功
android怎么在代码里获得系统文件的读写权限
1、必须是Android系统开发人员,否则你无法修改initrc等文件。
2、你的应用程序必须要获得system权限。
在应用层 你要想用代码获得系统文件权限,除非你手机root了
要么你自己做rom。 自己修改 init,rc
本来以为就没有办法在应用程序这一层改系统时间了,后来在网上搜了好久,知道这个目的还是可以达到的。
第一个方法简单点,不过需要在Android系统源码的环境下用make来编译:
1 在应用程序的AndroidManifestxml中的manifest节点中加入
android:sharedUserId="androiduidsystem"这个属性。
2 修改Androidmk文件,加入LOCAL_CERTIFICATE := platform这一行
3 使用mm命令来编译,生成的apk就有修改系统时间的权限了。
第二个办法麻烦点,不过不用开虚拟机跑到源码环境下用make来编译:
1 同上,加入android:sharedUserId="androiduidsystem"这个属性。
2 使用eclipse编译出apk文件,但是这个apk文件是不能用的。
3 用压缩软件打开apk文件,删掉META-INF目录下的CERTSF和CERTRSA两个文件。
4 使用目标系统的platform密钥来重新给apk文件签名。这步比较麻烦,
首先找到密钥文件,在我的Android源码目录中的位置
是"build argetproductsecurity",下面的platformpk8和platformx509pem
两个文件。
然后用Android提供的Signapk工具来签名,signapk的源代码是
在"build oolssignapk"下,
用法为"signapk platformx509pem platformpk8 inputapk outputapk",
文件名最好使用绝对路径防止找不到,也可以修改源代码直接使用。
这样最后得到的apk和第一个方法是一样的。
最后解释一下原理,首先加入android:sharedUserId="androiduidsystem"这个属性。通过Shared User id,拥有同一个User id的多个APK可以配置成运行在同一个进程中。那么把程序的UID配成androiduidsystem,也就是要让程序运行在系统进程中,这样就有权限来修改系统时间了。
只是加入UID还不够,如果这时候安装APK的话发现无法安装,提示签名不符,原因是程序想要运行在系统进程中还要有目标系统的platform
key,就是上面第二个方法提到的platformpk8和platformx509pem两个文件。用这两个key签名后apk才真正可以放入系统进程中。第一个方法中加入LOCAL_CERTIFICATE := platform其实就是用这两个key来签名。这也有一个问题,就是这样生成的程序只有在原始的Android系统或者是自己编译的系统中才可以用,因为这样的系统才可以拿到 platformpk8和platformx509pem两个文件。要是别家公司做的Android上连安装都安装不了。试试原始的Android 中的key来签名,程序在模拟器上运行OK,不过放到G3上安装直接提示"Package has no signatures that match those in shared user androiduidsystem",这样也是保护了系统的安全。
Java代码
1、必须是Android系统开发人员,否则你无法修改initrc等文件。 2、你的应用程序必须要获得system权限。
在应用层 你要想用代码获得系统文件权限,除非你手机root了
要么你自己坐rom。。。。 自己修改 init,rc
1、必须是Android系统开发人员,否则你无法修改initrc等文件。 2、你的应用程序必须要获得system权限。 在应用层 你要想用代码获得系统文件权限,除非你手机root了 要么你自己坐rom。。。。 自己修改 init,rc
支持原作者 : >
以上就是关于uid在哪看 怎么查看UID全部的内容,包括:uid在哪看 怎么查看UID、android中如何生成uid、android中 获取一个应用程序的所用权限的方法等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)