2016-04-20 3 views
1

Ich möchte, dass meine App die folgende benutzerdefinierte URL myscheme://product?id=123 behandelt. Dies funktioniert wie erwartet. Die folgende URL wird jedoch ebenfalls verarbeitet: myscheme://product/something/else?id=123 Wie verhindere ich, dass die zweite URL von der App verarbeitet wird?Intent-Filter pathPattern für benutzerdefiniertes Schema

I Setup der Intent-Filter, die wie folgt in dem Manifest

<intent-filter> 
    <action android:name="android.intent.action.VIEW"/> 

    <category android:name="android.intent.category.DEFAULT"/> 
    <category android:name="android.intent.category.BROWSABLE"/> 

    <data android:scheme="myscheme"/> 
    <data android:host="product"/> 
    <data android:pathPattern=".*"/> 
</intent-filter> 

ich mit DeepLinking spielen nur die tiefe Verbindung Griffe gestartet, so wäre jede Hilfe sehr dankbar!

Antwort

2

Versuchen Sie, die zu ersetzen. * Mit .product? * Das den Filter ausrichten sollte das Produkt Abfragezeichenfolgeflag mit nur und nicht das Produkt URL-Pfad (/ product/etwas/else? Id)

<intent-filter> 
<action android:name="android.intent.action.VIEW"/> 

<category android:name="android.intent.category.DEFAULT"/> 
<category android:name="android.intent.category.BROWSABLE"/> 

<data android:scheme="myscheme"/> 
<data android:host="product"/> 
<data android:pathPattern=".product?*"/> 

wäre eine weitere Option sein, zwei Absicht Filter zu erstellen und sie in der Reihenfolge des Eingangs der Absicht setzen:

Intent 1: product/something/else 
Intent 2: product?id=1 

UPDATE: der Schlüssel hier getData wird mit() nicht Extras erhalten(). Gelernt, dass die harte Weise :)

@Override 
public void onNewIntent(Intent i) { 
    super.onNewIntent(i); 
    Bundle b = i.getExtras(); 
    if (i != null && i.getData() != null) { 
    try { 
      Uri data = i.getData(); 
      Map<String, String> a = splitQuery(data); 
      if (a.containsKey("Product") && a.containsKey("SOMETHINGELSE")){ 
       //todo:something that takes care of something else: 
      }else if (a.containsKey("Product")){ 
       mItemNumber = a.get("ID"); 
       setUpFragmentForItem(mItemNumber); 
      } 
     } catch (UnsupportedEncodingException e) { 
      e.printStackTrace(); 
     } 
    } 
} 

Split URI in Segmente:

public static Map<String, String> splitQuery(Uri url) throws UnsupportedEncodingException { 
    try { 
     Map<String, String> query_pairs = new LinkedHashMap<String, String>(); 
     String query = url.getQuery(); 
     String[] pairs = query.split("/"); 
     for (String pair : pairs) { 
      int idx = pair.indexOf("="); 
      query_pairs.put(URLDecoder.decode(pair.substring(0, idx), "UTF-8"), URLDecoder.decode(pair.substring(idx + 1), "UTF-8")); 
     } 
     return query_pairs; 
    } catch (Exception e) { 
     throw new UnsupportedEncodingException(e.getMessage()); 
    } 
} 

UPDATE: eine Bibliothek gefunden, die das gleiche tut, erwähnenswert, haben sie nicht benutzt, aber ich kann geben es ein Versuch: https://android-arsenal.com/details/1/2072

+0

Danke für die Eingabe, aber das hat nicht funktioniert. –

+0

Meinst du, dass es das Problem nicht behoben hat oder die Funktion überhaupt nicht funktioniert hat? – DoctorD

+0

Es verursachte die Funktion nicht zu arbeiten. Der Link 'Produkt? Id = 1 'führt immer zu Play Store, anstatt in der App behandelt werden –