Фильтр намерений для запуска моей активности при нажатии на пользовательский 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" />