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

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

Для справки, вот вопросы, на которые я смотрел:

Запустите пользовательское приложение для Android из браузера AndroidСделать ссылку в браузере Android Запустите мое приложениеURL-адрес Android Dev Callback не работаетФильтры Intent для Android: как вы правильно просматриваете категорию Intent

В конечном счете, я хочу использовать это для перезапуска моего приложения, когда пользователь выполнил запрос аутентификации OAuth. Тем не менее, мое реальное приложение слишком велико, чтобы публиковать здесь. Для этого вопроса я собрал простое приложение, чтобы показать вам, что я сделал. У меня есть два занятия. Это происходит главным образом потому, что каждый пример, который я видел, использует действие, использующее действие VIEW. Я бы предпочел использовать действие MAIN, но я использовал оба здесь, чтобы показать, что я пробовал оба.

AndroidManifest.xml (оригинал; см. Отредактированную версию ниже)

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
      package="org.example" android:versionCode="1" android:versionName="1.0-SNAPSHOT">
<application android:icon="@drawable/icon" android:label="@string/app_name" android:debuggable="true">
    <activity android:name=".HelloAndroidActivity">
        <intent-filter>
            <data android:scheme="ex1"/>
            <action android:name="android.intent.action.MAIN"/>
            <category android:name="android.intent.category.LAUNCHER"/>
        </intent-filter>
    </activity>
    <activity android:name=".CallbackActivity">
        <intent-filter>
            <data android:scheme="ex2"/>
            <action android:name="android.intent.action.VIEW"/>
        </intent-filter>
    </activity>
</application>

AndroidManifest.xml (отредактировано в ответ на комментарий)

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
      package="org.example" android:versionCode="1" android:versionName="1.0-SNAPSHOT">
<application android:icon="@drawable/icon" android:label="@string/app_name" android:debuggable="true">
    <activity android:name=".HelloAndroidActivity">
        <intent-filter>
            <action android:name="android.intent.action.MAIN"/>
            <category android:name="android.intent.category.LAUNCHER"/>
        </intent-filter>
    </activity>
    <activity android:name=".CallbackActivity">
        <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:host="www.this-so-does-not-exist.com" android:scheme="http" />
        </intent-filter>
    </activity>
</application>

main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
>

HelloAndroidActivity.java

package org.example;

import android.app.Activity;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.widget.TextView;

public class HelloAndroidActivity extends Activity {

    private TextView textView;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        textView = (TextView) findViewById(R.id.textView);
    }

    @Override
    public void onResume() {
        super.onResume();
        Intent intent = getIntent();
        Uri data = intent.getData();
        if (data != null) {
            textView.setText("Hello Web!");
        }
    }

}

CallbackActivity.java

package org.example;

import android.app.Activity;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.widget.TextView;

public class CallbackActivity extends Activity {

    private TextView textView;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        textView = (TextView) findViewById(R.id.textView);
    }

    @Override
    public void onResume() {
        super.onResume();
        Intent intent = getIntent();
        Uri data = intent.getData();
        if (data != null) {
            textView.setText("Hello Web!");
        }
    }

}

Это строит достаточно счастливо. Затем, внутри браузера, если я ввожу ex1: // helloworld или ex2: // helloworld, я получаю разные результаты в зависимости от того, как это делается. Если я ввожу его в строке URL, я получаю в Google поиск ex1: // helloworld. Если я делаю это через перенаправление, я получаю «Веб-страница недоступна». Если я попытаюсь начать намерение непосредственно с чего-то похожего на:

    Intent intent = new Intent(Intent.ACTION_MAIN);
    ComponentName componentName = new ComponentName(
            "org.example",
            "org.example.HelloAndroidActivity");
    intent.setComponent(componentName);
    intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
    intent.setData(Uri.parse("ex1://helloworld"));
    intent.addCategory(Intent.CATEGORY_BROWSABLE);
    startActivity(intent);

Я получаю значение по умолчанию «Hello my-example!». Я не уверен, что я делаю неправильно. Есть идеи?

Ответы на вопрос(2)

Ваш ответ на вопрос