Фильтр намерений для запуска моей активности при нажатии на пользовательский URI

Я пытаюсь разрешить регистрацию URI для открытия в моем приложении. Словно PatternRepository на ежевике и тому CFBundleURLName/CFBundleURLSchemes на айфоне. Как мне добиться таких же результатов на Android?

Система будет отправлять электронные письма со следующей ссылкой: myapp://myapp.mycompany.com/index/customerId/12345, Идея заключается в том, что пользователь должен иметь возможность щелкнуть ссылку, чтобы открыть активность клиента в приложении.

Я перепробовал множество предложений из других постов SO, но не могу заставить ОС распознать шаблон и открыть мое приложение.

В приложении Gmail это выглядит так: myapp: // http://myapp.mycompany.com/index/customerId/12345. Это признает и подчеркивает myapp.mycompany.com/index/customerId/12345 часть ссылки, и она открывается в браузере. myapp:// часть не связана.

Стандартное почтовое приложение обрабатывает всю ссылку как обычный текст.

Что мне здесь не хватает?

PS: я уже посмотрел, как реализовать свою собственную схему URI на Android и как зарегистрировать некоторое пространство имен URL (myapp://app.start/) для доступа к вашей программе, вызывая URL в браузере в ОС Android?

Манифест:

<manifest
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:versionCode="2"
    android:versionName="0.0.8" 
    package="com.mycompany.myapp.client.android">

    <uses-sdk 
        android:minSdkVersion="7" 
        android:targetSdkVersion="7"/>

    <uses-permission android:name="android.permission.INTERNET"/>
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
    <uses-permission android:name="android.permission.READ_PHONE_STATE"/>

    <application 
        android:label="@string/app_name" 
        android:name="myappApplication" 
        android:icon="@drawable/ic_icon_myapp" 
        android:debuggable="true">

        <activity 
            android:label="My App" 
            android:name=".gui.activity.LoginActivity" 
            label="@string/app_name">

            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>

        </activity>

        <activity android:name=".gui.activity.CustomerDetailActivity" > 
            <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="myapp"/> 
            </intent-filter> 
        </activity>

        <activity android:name=".gui.activity.CustomerDetailActivity"/>
        <activity android:name=".gui.activity.CustomerImageViewerActivity" />
        <activity android:name=".gui.activity.CustomerListActivity" android:configChanges="orientation|keyboardHidden"/>
        <activity android:name=".gui.activity.HomeActivity" android:configChanges="orientation|keyboardHidden"/>
        <activity android:name=".gui.activity.AboutActivity" android:configChanges="orientation|keyboardHidden"/>
        <activity android:name=".gui.activity.AccountActivity" android:configChanges="orientation|keyboardHidden" />  
    </application>
</manifest>

7 ответов

Решение

Окончательное решение - хакерский обходной путь, охватывающий все базы. Письмо теперь также содержит вложение с расширением, которое зарегистрировано для открытия в приложении.

Манифест:

        <activity android:name=".gui.activity.CustomerDetailActivity" > 
        <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="https"
                 android:host="myapp.mycompany.com" /> 
        </intent-filter> 
        <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="myapp"
                 android:host="myapp.mycompany.com" /> 
        </intent-filter> 
        <intent-filter>
            <action android:name="android.intent.action.VIEW" />
            <action android:name="android.intent.action.EDIT" />
            <action android:name="android.intent.action.PICK" />
            <category android:name="android.intent.category.DEFAULT" />
            <category android:name="android.intent.category.BROWSABLE" />
            <data android:mimeType="application/myapp" />
        </intent-filter>
    </activity>

Когда я работал над OAuth с Календарем Google, мне пришлось добавить этот фильтр в действие, которое я хотел получить обратный вызов:

<intent-filter>
<action android:name="android.intent.action.VIEW"></action>
<category android:name="android.intent.category.DEFAULT"></category>
<category android:name="android.intent.category.BROWSABLE"></category>
<data android:scheme="yourapp" android:host="goog"></data>
</intent-filter>

Когда браузер вызвал yourapp://goog URL, он вернется к моей активности.

Вы можете обойти проблему, когда GMail не связывает нестандартные протоколы, используя стандартный URL-адрес HTTP с перенаправлением 302. Вы можете настроить его на веб-сервере или сервере приложений своего веб-сайта, или для быстрого и грязного теста вы можете использовать сокращение URL, например http://bit.ly/.

Это решение для меня. Спасибо @DanO

<intent-filter>
        <data android:scheme="yourcustomname"/>
        <data android:host="*"/>
                <action android:name="android.intent.action.VIEW" />
                <category android:name="android.intent.category.DEFAULT" />
                <category android:name="android.intent.category.BROWSABLE" />
  </intent-filter>

Вы всегда можете попробовать отправить свои электронные письма, используя HTML, а затем использовать <a> пометить вокруг, чтобы создать URL. Я не думаю, что есть способ изменить способ синтаксического анализа Gmail или почты, поскольку они, вероятно, используют Linkify учебный класс.

Другой вариант - использовать http://, а затем просто проанализировать конкретный пользовательский поддомен, который предоставит вашим пользователям возможность открывать их в браузере или в вашем приложении.

Я только столкнулся с этим также, но для стандартных http: URL схемы. Похоже, Gmail не добавляет какие-либо категории в намерение. Теперь я проверяю BROWSABLE, но я также включаю проверку для! Intent.hasCategories() и также разрешаю это делать.

Вы уже добавили категорию в свой фильтр намерений:

<category android:name="android.intent.category.BROWSABLE" />
Другие вопросы по тегам