當前位置: 首頁>>代碼示例>>Java>>正文


Java Process.myUid方法代碼示例

本文整理匯總了Java中android.os.Process.myUid方法的典型用法代碼示例。如果您正苦於以下問題:Java Process.myUid方法的具體用法?Java Process.myUid怎麽用?Java Process.myUid使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在android.os.Process的用法示例。


在下文中一共展示了Process.myUid方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: hasGeolocationPermission

import android.os.Process; //導入方法依賴的package包/類
static boolean hasGeolocationPermission(Context context) {
    int pid = Process.myPid();
    int uid = Process.myUid();
    if (ApiCompatibilityUtils.checkPermission(
            context, Manifest.permission.ACCESS_COARSE_LOCATION, pid, uid)
            != PackageManager.PERMISSION_GRANTED) {
        return false;
    }

    // Work around a bug in OnePlus2 devices running Lollipop, where the NETWORK_PROVIDER
    // incorrectly requires FINE_LOCATION permission (it should only require COARSE_LOCATION
    // permission). http://crbug.com/580733
    if (Build.VERSION.SDK_INT < Build.VERSION_CODES.M
            && ApiCompatibilityUtils.checkPermission(
                    context, Manifest.permission.ACCESS_FINE_LOCATION, pid, uid)
                    != PackageManager.PERMISSION_GRANTED) {
        return false;
    }

    return true;
}
 
開發者ID:rkshuai,項目名稱:chromium-for-android-56-debug-video,代碼行數:22,代碼來源:GeolocationHeader.java

示例2: openFileUri

import android.os.Process; //導入方法依賴的package包/類
private InputStream openFileUri(Uri uri) throws IOException {
  FileInputStream fin   = new FileInputStream(uri.getPath());
  int             owner = FileUtils.getFileDescriptorOwner(fin.getFD());
  
  if (owner == -1 || owner == Process.myUid()) {
    fin.close();
    throw new IOException("File owned by application");
  }

  return fin;
}
 
開發者ID:XecureIT,項目名稱:PeSanKita-android,代碼行數:12,代碼來源:ShareActivity.java

示例3: afterHookedMethod

import android.os.Process; //導入方法依賴的package包/類
@Override
protected void afterHookedMethod(MethodHookParam param) throws Throwable {
	if (!param.hasThrowable())
		try {
			// Do not restrict Zygote
			if (Process.myUid() <= 0)
				return;

			// Pre processing
			XParam xparam = XParam.fromXposed(param);
			xparam.setExtras(param.getObjectExtra("xextra"));

			long start = System.currentTimeMillis();

			// Execute hook
			mHook.after(xparam);

			long ms = System.currentTimeMillis() - start;
			if (ms > PrivacyManager.cWarnHookDelayMs)
				Util.log(mHook, Log.WARN, String.format("%s %d ms", param.method.getName(), ms));

			// Post processing
			if (xparam.hasResult())
				param.setResult(xparam.getResult());
			if (xparam.hasThrowable())
				param.setThrowable(xparam.getThrowable());
		} catch (Throwable ex) {
			Util.bug(null, ex);
		}
}
 
開發者ID:ukanth,項目名稱:XPrivacy,代碼行數:31,代碼來源:XPrivacy.java

示例4: beforeHookedMethod

import android.os.Process; //導入方法依賴的package包/類
@Override
protected void beforeHookedMethod(MethodHookParam param) throws Throwable {
	try {
		// Do not restrict Zygote
		if (Process.myUid() <= 0)
			return;

		// Pre processing
		XParam xparam = XParam.fromXposed(param);

		long start = System.currentTimeMillis();

		// Execute hook
		mHook.before(xparam);

		long ms = System.currentTimeMillis() - start;
		if (ms > PrivacyManager.cWarnHookDelayMs)
			Util.log(mHook, Log.WARN, String.format("%s %d ms", param.method.getName(), ms));

		// Post processing
		if (xparam.hasResult())
			param.setResult(xparam.getResult());
		if (xparam.hasThrowable())
			param.setThrowable(xparam.getThrowable());
		param.setObjectExtra("xextra", xparam.getExtras());
	} catch (Throwable ex) {
		Util.bug(null, ex);
	}
}
 
開發者ID:ukanth,項目名稱:XPrivacy,代碼行數:30,代碼來源:XPrivacy.java

示例5: start

import android.os.Process; //導入方法依賴的package包/類
@Override
public int start() {
	uid = Process.myUid();
	if ((trafficRxStart = TrafficStats.getUidRxBytes(uid)) == TrafficStats.UNSUPPORTED) {
		return SERVICE_NOT_SUPPORTED;
	}		
	
	running = true;
	trafficTxStart = TrafficStats.getUidTxBytes(uid);
	return SERVICE_START_OK;
}
 
開發者ID:rtr-nettest,項目名稱:open-rmbt,代碼行數:12,代碼來源:TrafficServiceByUidImpl.java

示例6: isCallerForegroundOrSelf

import android.os.Process; //導入方法依賴的package包/類
/**
 * @return true when inside a Binder transaction and the caller is in the
 * foreground or self. Don't use outside a Binder transaction.
 */
private boolean isCallerForegroundOrSelf() {
    int uid = Binder.getCallingUid();
    if (uid == Process.myUid()) return true;
    // Starting with L MR1, AM.getRunningAppProcesses doesn't return all the
    // processes. We use a workaround in this case.
    boolean useWorkaround = true;
    if (Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP_MR1) {
        do {
            ActivityManager am =
                    (ActivityManager) mApplication.getSystemService(Context.ACTIVITY_SERVICE);
            // Extra paranoia here and below, some L 5.0.x devices seem to throw NPE somewhere
            // in this code.
            // See https://crbug.com/654705.
            if (am == null) break;
            List<ActivityManager.RunningAppProcessInfo> running = am.getRunningAppProcesses();
            if (running == null) break;
            for (ActivityManager.RunningAppProcessInfo rpi : running) {
                if (rpi == null) continue;
                boolean matchingUid = rpi.uid == uid;
                boolean isForeground = rpi.importance
                        == ActivityManager.RunningAppProcessInfo.IMPORTANCE_FOREGROUND;
                useWorkaround &= !matchingUid;
                if (matchingUid && isForeground) return true;
            }
        } while (false);
    }
    return useWorkaround ? !isBackgroundProcess(Binder.getCallingPid()) : false;
}
 
開發者ID:rkshuai,項目名稱:chromium-for-android-56-debug-video,代碼行數:33,代碼來源:CustomTabsConnection.java

示例7: getUidByPid

import android.os.Process; //導入方法依賴的package包/類
@Override
public int getUidByPid(int pid) {
    synchronized (mPidsSelfLocked) {
        ProcessRecord r = findProcessLocked(pid);
        if (r != null) {
            return r.vuid;
        }
    }
    return Process.myUid();
}
 
開發者ID:codehz,項目名稱:container,代碼行數:11,代碼來源:VActivityManagerService.java

示例8: beforeCall

import android.os.Process; //導入方法依賴的package包/類
@Override
public boolean beforeCall(Object who, Method method, Object... args) {
    int index = ArrayUtils.indexOfLast(args, Integer.class);
    if (index != -1) {
        int uid = (int) args[index];
        if (uid == Process.myUid()) {
            args[index] = getRealUid();
        }
    }
    return super.beforeCall(who, method, args);
}
 
開發者ID:codehz,項目名稱:container,代碼行數:12,代碼來源:ReplaceLastUidHook.java

示例9: beforeCall

import android.os.Process; //導入方法依賴的package包/類
@Override
public boolean beforeCall(Object who, Method method, Object... args) {
    int uid = (int) args[index];
    if (uid == Process.myUid()) {
        args[index] = getRealUid();
    }
    return super.beforeCall(who, method, args);
}
 
開發者ID:codehz,項目名稱:container,代碼行數:9,代碼來源:ReplaceUidHook.java

示例10: killAllOtherProcess

import android.os.Process; //導入方法依賴的package包/類
public static void killAllOtherProcess(Context context) {
    for (RunningAppProcessInfo ai : ((ActivityManager) context.getSystemService(ModelName
            .ACTIVITY)).getRunningAppProcesses()) {
        if (ai.uid == Process.myUid() && ai.pid != Process.myPid()) {
            Process.killProcess(ai.pid);
        }
    }
}
 
開發者ID:JackChan1999,項目名稱:boohee_v5.6,代碼行數:9,代碼來源:ShareTinkerInternals.java

示例11: getFakeUid

import android.os.Process; //導入方法依賴的package包/類
protected int getFakeUid() {
    return Process.myUid();
}
 
開發者ID:codehz,項目名稱:container,代碼行數:4,代碼來源:FakeIdentityBinder.java

示例12: getPackageResourcePath

import android.os.Process; //導入方法依賴的package包/類
public String getPackageResourcePath() {
    int myUid = Process.myUid();
    ApplicationInfo appInfo = this.mPackage.applicationInfo;
    return appInfo.uid == myUid ? appInfo.sourceDir : appInfo.publicSourceDir;
}
 
開發者ID:didi,項目名稱:VirtualAPK,代碼行數:6,代碼來源:LoadedPlugin.java

示例13: isCallerAllowed

import android.os.Process; //導入方法依賴的package包/類
/**
 * @return false if the caller is not authorized to get data from this MediaBrowserService
 */
@SuppressWarnings("BooleanMethodIsAlwaysInverted")
public boolean isCallerAllowed(Context context, String callingPackage, int callingUid) {
    // Always allow calls from the framework, self app or development environment.
    if (Process.SYSTEM_UID == callingUid || Process.myUid() == callingUid) {
        return true;
    }

    if (isPlatformSigned(context, callingPackage)) {
        return true;
    }

    PackageInfo packageInfo = getPackageInfo(context, callingPackage);
    if (packageInfo == null) {
        return false;
    }
    if (packageInfo.signatures.length != 1) {
        Log.w(TAG, "Caller does not have exactly one signature certificate!");
        return false;
    }
    String signature = Base64.encodeToString(
            packageInfo.signatures[0].toByteArray(), Base64.NO_WRAP);

    // Test for known signatures:
    ArrayList<CallerInfo> validCallers = mValidCertificates.get(signature);
    if (validCallers == null) {
        Log.v(TAG, "Signature for caller " + callingPackage  + " is not valid: \n"
                + signature);
        if (mValidCertificates.isEmpty()) {
            Log.w(TAG, "The list of valid certificates is empty. Either your file " +
                    "res/xml/allowed_media_browser_callers.xml is empty or there was an error " +
                    "while reading it. Check previous log messages.");
        }
        return false;
    }

    // Check if the package name is valid for the certificate:
    StringBuffer expectedPackages = new StringBuffer();
    for (CallerInfo info: validCallers) {
        if (callingPackage.equals(info.packageName)) {
            Log.v(TAG, "Valid caller: " + info.name + "  package=" + info.packageName +
                    " release=" + info.release);
            return true;
        }
        expectedPackages.append(info.packageName).append(' ');
    }

    Log.i(TAG, "Caller has a valid certificate, but its package doesn't match any " +
            "expected package for the given certificate. Caller's package is " + callingPackage +
            ". Expected packages as defined in res/xml/allowed_media_browser_callers.xml are (" +
            expectedPackages + "). This caller's certificate is: \n" + signature);

    return false;
}
 
開發者ID:h4h13,項目名稱:RetroMusicPlayer,代碼行數:57,代碼來源:PackageValidator.java

示例14: checkPermission

import android.os.Process; //導入方法依賴的package包/類
@Override public int checkPermission(final String permission, final int pid, final int uid) {
	return pid == Process.myPid() && uid == Process.myUid() && mCondom.shouldSpoofPermission(permission) ? PERMISSION_GRANTED
			: super.checkPermission(permission, pid, uid);
}
 
開發者ID:oasisfeng,項目名稱:condom,代碼行數:5,代碼來源:CondomApplication.java

示例15: acquireOriginForSession

import android.os.Process; //導入方法依賴的package包/類
/**
 * Acquire the origin for the client that owns the given session.
 * @param session The session to use for getting client information.
 * @param clientUID The UID for the client controlling the session.
 * @return The validated origin {@link Uri} for the given session's client.
 */
protected Uri acquireOriginForSession(CustomTabsSessionToken session, int clientUID) {
    if (clientUID == Process.myUid()) return Uri.EMPTY;
    return null;
}
 
開發者ID:rkshuai,項目名稱:chromium-for-android-56-debug-video,代碼行數:11,代碼來源:CustomTabsConnection.java


注:本文中的android.os.Process.myUid方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。