首页 >数据库 >mysql教程 >如何给Service添加access permission

如何给Service添加access permission

WBOY
WBOY原创
2016-06-07 15:50:131250浏览

//首先定义Service的接口,IMyService.aidl package com.xxxx; import android.os.IBinder; import android.os.ParcelFileDescriptor; interface IMyService { void doService(int id); } //实现service类,MyService.java public class MyService extends IM

//首先定义Service的接口,IMyService.aidl
package com.xxxx;

import android.os.IBinder;
import android.os.ParcelFileDescriptor;

interface IMyService {
    void doService(int id);
}
//实现service类,MyService.java
public class MyService extends IMyService.Stub {
    public static final String MY_SERVICE = "myservice";
    private static MyService sService = null;
    static String PERMISSION = "com.xxxx.permission.ACCESS_MYSERVICE";

    /*
     * The entry called by system server to create service.
     */
    public static MyService main(Context context) {
        if (sService != null) {
            return sService;
        }
        sService = new MyService(context);
        try {
            Slog.d(TAG, "created service");
            ServiceManager.addService(MY_SERVICE, sService);
            Slog.d(TAG, "added service " + MY_SERVICE);
        } catch (Throwable e) {
                Slog.e(TAG, "Failure starting MyService", e);
        }
        return sService;
    }

    private MyService(Context context) {
        mContext = context;
    }

    /*
     * Called from Client App to retrieve interface
     */
    public static IMyService getService() {
        IBinder b = ServiceManager.getService(MY_SERVICE);
        if ( b == null) {
            return null;
        }
        return IMyService.Stub.asInterface(b);
    }

    @Override

    public long openSession(IBinder clientToken, int sensorType) throws RemoteException {

        //添加访问权限

        if (mContext.checkCallingPermission(PERMISSION) != PackageManager.PERMISSION_GRANTED) {
            throw new RemoteException("Permission not granted for MyService");
        }
        //做实际的工作

    }

}

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn