2013-03-11 2 views
3

Я бы хотел связать 2 приложения через службу с помощью файла helpl.Удаленная служба с файлом help: ServiceConnection никогда не вызывал

В моем приложении А (с услугой, которая будет доступ):

→ aidl файл (BillingInterface.aidl):

package com.A.service; 
import android.os.Bundle; 

interface BillingInterface { 
    Bundle getServiceDetails(String a, String b); 
} 

интерфейс Java автоматически создается без проблем.

Тогда моя служба, которая будет дистанционно удалены:

public class BillingService extends Service { 

    private static final String TAG = BillingService.class.getName(); 

    @Override 
    public void onCreate() { 
     super.onCreate(); 
    } 

    @Override 
    public void onDestroy() { 
     super.onDestroy(); 
    } 

    @Override 
    public IBinder onBind(Intent arg0) { 

     return new BillingInterface.Stub() {  

      @Override 
      public Bundle getServiceDetails(String a, String b) 
       throws RemoteException { 

       Bundle b = new Bundle(); 
       b.putString("test", "simple test"); 
       return b; 
      }; 
     } 
    } 

} 

В моем файле манифеста:

<service 
     android:name=".service.BillingService" 
     android:enabled="true" 
     android:exported="true" 
     android:process=":remote" 

     <intent-filter> 
      <action android:name=".service.BillingInterface.aidl" /> 
     </intent-filter> 
/> 

В моем приложении B, я пытаюсь подключиться к нему (у меня есть один и тот же файл aidl):

protected void onCreate(Bundle savedInstanceState) { 
... 

    Intent i = new Intent(); 
    i.setClassName("com.A", "com.A.service.BillingService"); 

    try { 

    Boolean ret = bindService(i, mConnection , Context.BIND_DEBUG_UNBIND); 
    Log.d("DEBUG", ret.toString()); // will return "true" 

    } catch (Exception e) { 
    Log.e("DEBUG", "not able to bind ! "); 
    } 


... 


private ServiceConnection mConnection = new ServiceConnection(){ 


    public void onServiceConnected(ComponentName name, IBinder boundService) { 
     service = BillingInterface.Stub.asInterface((IBinder) boundService); 
     Log.d("DEBUG", "onServiceConnected() : OK "); 
    } 

     public void onServiceDisconnected(ComponentName name) { 
      service = null; 
     } 
    }; 



    //When clicking button : 

    public void onclick(View v) { 

     try { 

      // serviceのcheckTransfertメッソードを呼ぶ 
      Bundle response = service.getServiceDetails("test", "test"); 

      Log.d("DEBUG", response.getString("test")); 

     } catch (RemoteException e) { 

      Log.e("DEBUG", "error in RemoteExpcetion" + e.getMessage()); 
     } 

    } 

при привязке к службе (bindService), я получаю логическое "истинный", но метод onServiceConnected в м y serviceConnection никогда не вызывается. Я установил кнопку для вызова метода службы (см. Выше метод «onclick»). Если я нажму, я получу следующее сообщение:

03-11 02:00:32.895: E/AndroidRuntime(3066): FATAL EXCEPTION: main 
03-11 02:00:32.895: E/AndroidRuntime(3066): java.lang.IllegalStateException: Could not execute method of the activity 
03-11 02:00:32.895: E/AndroidRuntime(3066):  at android.view.View$1.onClick(View.java:2072) 
03-11 02:00:32.895: E/AndroidRuntime(3066):  at android.view.View.performClick(View.java:2408) 
03-11 02:00:32.895: E/AndroidRuntime(3066):  at android.view.View$PerformClick.run(View.java:8816) 
03-11 02:00:32.895: E/AndroidRuntime(3066):  at android.os.Handler.handleCallback(Handler.java:587) 
03-11 02:00:32.895: E/AndroidRuntime(3066):  at android.os.Handler.dispatchMessage(Handler.java:92) 
03-11 02:00:32.895: E/AndroidRuntime(3066):  at android.os.Looper.loop(Looper.java:123) 
03-11 02:00:32.895: E/AndroidRuntime(3066):  at android.app.ActivityThread.main(ActivityThread.java:4627) 
03-11 02:00:32.895: E/AndroidRuntime(3066):  at java.lang.reflect.Method.invokeNative(Native Method) 
03-11 02:00:32.895: E/AndroidRuntime(3066):  at java.lang.reflect.Method.invoke(Method.java:521) 
03-11 02:00:32.895: E/AndroidRuntime(3066):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868) 
03-11 02:00:32.895: E/AndroidRuntime(3066):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626) 
03-11 02:00:32.895: E/AndroidRuntime(3066):  at dalvik.system.NativeStart.main(Native Method) 
03-11 02:00:32.895: E/AndroidRuntime(3066): Caused by: java.lang.reflect.InvocationTargetException 
03-11 02:00:32.895: E/AndroidRuntime(3066):  at com.example.testconnection/xxxx.MainActivity.onclick(MainActivity.java:59) 
03-11 02:00:32.895: E/AndroidRuntime(3066):  at java.lang.reflect.Method.invokeNative(Native Method) 
03-11 02:00:32.895: E/AndroidRuntime(3066):  at java.lang.reflect.Method.invoke(Method.java:521) 
03-11 02:00:32.895: E/AndroidRuntime(3066):  at android.view.View$1.onClick(View.java:2067) 
03-11 02:00:32.895: E/AndroidRuntime(3066):  ... 11 more 
03-11 02:00:32.895: E/AndroidRuntime(3066): Caused by: java.lang.NullPointerException 
03-11 02:00:32.895: E/AndroidRuntime(3066):  ... 15 more 

Любые идеи? Спасибо, что прочитали!

ответ

3

изменение

Boolean ret = bindService(i, mConnection , Context.BIND_DEBUG_UNBIND); 

к:

Boolean ret = bindService(i, mConnection , Context.BIND_AUTO_CREATE); 

тогда onServiceConnected будет называться.

+0

Это работает как шарм! Я также изменил имя пакета в своем приложении B, чтобы избежать ошибки безопасности (java.lang.SecurityException: вызов Binder для неправильного интерфейса). Спасибо, Lumos ~ – johann