Устранение неполадок приложения Android WebView WebRT C - PullRequest
0 голосов
/ 16 июня 2020

Я пытаюсь создать приложение WebRT C для видеоконференцсвязи, которое можно будет распространять через Google Play и Apple Store.

В настоящее время у меня есть веб-приложение, которое делает именно это, и оно работает так, как я хочу это пока. Я пытался загрузить это в Android WebView, как я делал это с множеством других приложений (не связанных с WebRT C) в прошлом, но у меня возникают ошибки.

Logcat с устройства :

2020-06-16 16:10:28.022 28364-28364/? I/art: Late-enabling -Xcheck:jni
2020-06-16 16:10:28.022 28364-28364/? I/art: Reinit property: dalvik.vm.checkjni= false
2020-06-16 16:10:28.096 28364-28364/gr.cretanmedicare.iasis W/System: ClassLoader referenced unknown path: /data/app/gr.cretanmedicare.iasis-1/lib/arm64
2020-06-16 16:10:28.114 28364-28364/gr.cretanmedicare.iasis I/HwCust: Constructor found for class android.app.HwCustActivityImpl
2020-06-16 16:10:28.122 28364-28364/gr.cretanmedicare.iasis I/HwCust: Constructor found for class android.app.HwCustHwWallpaperManagerImpl
2020-06-16 16:10:28.137 28364-28364/gr.cretanmedicare.iasis W/art: Before Android 4.1, method android.graphics.PorterDuffColorFilter android.support.graphics.drawable.VectorDrawableCompat.updateTintFilter(android.graphics.PorterDuffColorFilter, android.content.res.ColorStateList, android.graphics.PorterDuff$Mode) would have incorrectly overridden the package-private method in android.graphics.drawable.Drawable
2020-06-16 16:10:28.235 28364-28364/gr.cretanmedicare.iasis I/WebViewFactory: Loading com.android.chrome version 78.0.3904.90 (code 390409037)
2020-06-16 16:10:28.528 28364-28364/gr.cretanmedicare.iasis I/cr_LibraryLoader: Time to load native libraries: 3 ms
2020-06-16 16:10:28.575 28364-28364/gr.cretanmedicare.iasis I/chromium: [INFO:library_loader_hooks.cc(51)] Chromium logging enabled: level = 0, default verbosity = 0
2020-06-16 16:10:28.575 28364-28364/gr.cretanmedicare.iasis I/cr_LibraryLoader: Expected native library version number "78.0.3904.90", actual native library version number "78.0.3904.90"
2020-06-16 16:10:28.607 28364-28364/gr.cretanmedicare.iasis E/cr_VariationsSeedLoader: Failed loading variations seed. Variations disabled.
2020-06-16 16:10:28.712 28364-28364/gr.cretanmedicare.iasis I/cr_BrowserStartup: Initializing chromium process, singleProcess=true
2020-06-16 16:10:28.723 28364-28364/gr.cretanmedicare.iasis W/ResourceType: Failure getting entry for 0x7f130537 (t=18 e=1335) (error -2147483647)
2020-06-16 16:10:28.772 28364-28428/gr.cretanmedicare.iasis W/chromium: [WARNING:dns_config_service_posix.cc(341)] Failed to read DnsConfig.
2020-06-16 16:10:29.016 28364-28451/gr.cretanmedicare.iasis E/libEGL: validate_display:99 error 3008 (EGL_BAD_DISPLAY)
2020-06-16 16:10:29.021 28364-28364/gr.cretanmedicare.iasis I/HwSecImmHelper: mSecurityInputMethodService is null
2020-06-16 16:10:29.056 28364-28364/gr.cretanmedicare.iasis I/HwPointEventFilter: do not support AFT because of no config
2020-06-16 16:10:29.110 28364-28451/gr.cretanmedicare.iasis W/VideoCapabilities: Unrecognized profile/level 1/32 for video/mp4v-es
2020-06-16 16:10:29.110 28364-28451/gr.cretanmedicare.iasis I/VideoCapabilities: Unsupported profile 16384 for video/mp4v-es
2020-06-16 16:10:29.110 28364-28451/gr.cretanmedicare.iasis I/VideoCapabilities: Unsupported profile 16384 for video/mp4v-es
2020-06-16 16:10:29.115 28364-28451/gr.cretanmedicare.iasis W/VideoCapabilities: Unsupported mime video/x-pn-realvideo
2020-06-16 16:10:29.116 28364-28451/gr.cretanmedicare.iasis W/VideoCapabilities: Unsupported mime video/mpeg
2020-06-16 16:10:29.118 28364-28451/gr.cretanmedicare.iasis W/VideoCapabilities: Unrecognized profile/level 0/0 for video/mpeg2
2020-06-16 16:10:29.118 28364-28451/gr.cretanmedicare.iasis W/VideoCapabilities: Unrecognized profile/level 0/2 for video/mpeg2
2020-06-16 16:10:29.118 28364-28451/gr.cretanmedicare.iasis W/VideoCapabilities: Unrecognized profile/level 0/3 for video/mpeg2
2020-06-16 16:10:29.120 28364-28451/gr.cretanmedicare.iasis W/VideoCapabilities: Unrecognized profile/level 32768/2 for video/mp4v-es
2020-06-16 16:10:29.124 28364-28451/gr.cretanmedicare.iasis W/VideoCapabilities: Unsupported mime video/vc1
2020-06-16 16:10:29.128 28364-28451/gr.cretanmedicare.iasis W/VideoCapabilities: Unsupported mime video/x-flv
2020-06-16 16:10:29.148 28364-28451/gr.cretanmedicare.iasis I/VideoCapabilities: Unsupported profile 4 for video/mp4v-es
2020-06-16 16:10:29.153 28364-28451/gr.cretanmedicare.iasis W/cr_MediaCodecUtil: HW encoder for video/avc is not available on this device.
2020-06-16 16:10:30.727 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:30.727 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:31.281 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:31.281 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:31.311 28364-28364/gr.cretanmedicare.iasis I/Choreographer: Skipped 33 frames!  The application may be doing too much work on its main thread.
2020-06-16 16:10:31.467 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:31.467 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:31.743 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:31.744 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:31.952 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:31.952 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:32.143 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:32.143 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:32.412 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:32.413 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:32.620 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:32.621 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:33.789 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:33.789 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:34.052 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:34.052 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:34.053 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:34.060 28364-28364/gr.cretanmedicare.iasis I/chromium: [INFO:CONSOLE(1)] "loadButton", source: https://cretanmedicare.gr/webchat/js/widget.js (1)
2020-06-16 16:10:34.187 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:34.187 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:34.188 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:34.200 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:34.201 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:34.645 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:34.645 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:35.204 28364-28628/gr.cretanmedicare.iasis W/chromium: [WARNING:stun_port.cc(450)] Port[3db4c200:0:1:0:local:Net[any:0:0:0:x:x:x:x:x/0:Wildcard:id=0]]: StunPort: stun host lookup received error 0
2020-06-16 16:10:35.238 28364-28634/gr.cretanmedicare.iasis W/VideoCapabilities: Unrecognized profile/level 1/32 for video/mp4v-es
2020-06-16 16:10:35.238 28364-28634/gr.cretanmedicare.iasis I/VideoCapabilities: Unsupported profile 16384 for video/mp4v-es
2020-06-16 16:10:35.238 28364-28634/gr.cretanmedicare.iasis I/VideoCapabilities: Unsupported profile 16384 for video/mp4v-es
2020-06-16 16:10:35.241 28364-28634/gr.cretanmedicare.iasis W/VideoCapabilities: Unsupported mime video/x-pn-realvideo
2020-06-16 16:10:35.242 28364-28634/gr.cretanmedicare.iasis W/VideoCapabilities: Unsupported mime video/mpeg
2020-06-16 16:10:35.243 28364-28634/gr.cretanmedicare.iasis W/VideoCapabilities: Unrecognized profile/level 0/0 for video/mpeg2
2020-06-16 16:10:35.243 28364-28634/gr.cretanmedicare.iasis W/VideoCapabilities: Unrecognized profile/level 0/2 for video/mpeg2
2020-06-16 16:10:35.243 28364-28634/gr.cretanmedicare.iasis W/VideoCapabilities: Unrecognized profile/level 0/3 for video/mpeg2
2020-06-16 16:10:35.244 28364-28628/gr.cretanmedicare.iasis W/chromium: [WARNING:turn_port.cc(815)] Port[3dd2b000:0:1:0:relay:Net[any:0:0:0:x:x:x:x:x/0:Wildcard:id=0]]: TURN host lookup received error 0
2020-06-16 16:10:35.245 28364-28634/gr.cretanmedicare.iasis W/VideoCapabilities: Unrecognized profile/level 32768/2 for video/mp4v-es
2020-06-16 16:10:35.247 28364-28634/gr.cretanmedicare.iasis W/VideoCapabilities: Unsupported mime video/vc1
2020-06-16 16:10:35.250 28364-28634/gr.cretanmedicare.iasis W/VideoCapabilities: Unsupported mime video/x-flv
2020-06-16 16:10:35.260 28364-28634/gr.cretanmedicare.iasis I/VideoCapabilities: Unsupported profile 4 for video/mp4v-es
2020-06-16 16:10:35.366 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:35.366 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:35.377 28364-28628/gr.cretanmedicare.iasis W/chromium: [WARNING:basic_port_allocator.cc(977)] Discarding candidate because port is already done gathering.
2020-06-16 16:10:35.380 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:35.381 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:35.801 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:35.802 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:37.465 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:37.466 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:37.786 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:37.786 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:48.571 28364-28364/gr.cretanmedicare.iasis I/hwaps: JNI_OnLoad
2020-06-16 16:10:48.721 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:48.731 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:48.860 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:48.861 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:49.245 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:49.246 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:49.432 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:49.433 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:49.435 28364-28364/gr.cretanmedicare.iasis I/HwSecImmHelper: mSecurityInputMethodService is null
2020-06-16 16:10:49.578 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:49.579 28364-28473/gr.cretanmedicare.iasis E/chromium: [ERROR:tile_manager.cc(779)] WARNING: tile memory limits exceeded, some content may not draw
2020-06-16 16:10:49.652 28364-28364/gr.cretanmedicare.iasis I/HwSecImmHelper: mSecurityInputMethodService is null

Больше всего мне выделяются строки 2020-06-16 16:10:29.110 28364-28451/gr.cretanmedicare.iasis W/VideoCapabilities: Unrecognized profile/level 1/32 for video/mp4v-es и все аналогичные, и 2020-06-16 16:10:35.204 28364-28628/gr.cretanmedicare.iasis W/chromium: [WARNING:stun_port.cc(450)] Port[3db4c200:0:1:0:local:Net[any:0:0:0:x:x:x:x:x/0:Wildcard:id=0]]: StunPort: stun host lookup received error 0 вместе со строкой сервера TURN.

И снова приложение работает отлично работает в обычном браузере, а сервер TURN настроен и протестирован правильно.

Мой код MainActivity основан на Google WebRT C образец

package iasis.cretanmedicare.gr;

import android.annotation.TargetApi;
import android.app.Activity;
import android.app.Fragment;
import android.net.http.SslCertificate;
import android.net.http.SslError;
import android.os.Build;
import android.os.Bundle;
import android.support.v4.app.FragmentManager;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.webkit.CookieManager;
import android.webkit.PermissionRequest;
import android.webkit.SslErrorHandler;
import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;

public class MainActivity extends AppCompatActivity {

    private static final String TAG = MainActivity.class.getSimpleName();

    private CharSequence mTitle;

    @TargetApi(Build.VERSION_CODES.HONEYCOMB)
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mTitle = getTitle();
        FragmentManager fragmentManager = getSupportFragmentManager();
        fragmentManager.beginTransaction()
                .replace(R.id.container, PlaceholderFragment.newInstance(1))
                .commit();
    }

    @TargetApi(Build.VERSION_CODES.HONEYCOMB)
    public static class PlaceholderFragment extends android.support.v4.app.Fragment {

        private static final String ARG_SECTION_NUMBER = "section_number";

        public static android.support.v4.app.Fragment newInstance(int sectionNumber) {
            PlaceholderFragment fragment = new PlaceholderFragment();
            Bundle args = new Bundle();
            args.putInt(ARG_SECTION_NUMBER, sectionNumber);
            fragment.setArguments(args);
            return fragment;
        }

        private WebView mWebRTCWebView;

        @Override
        public View onCreateView(LayoutInflater inflater, ViewGroup container,
                                 Bundle savedInstanceState) {
            View rootView = inflater.inflate(R.layout.fragment_main, container, false);
            mWebRTCWebView = (WebView) rootView.findViewById(R.id.fragment_main_webview);

            setUpWebViewDefaults(mWebRTCWebView);

            mWebRTCWebView.loadUrl("https://cretanmedicare.gr/webchat/index.php");

            mWebRTCWebView.setWebChromeClient(new WebChromeClient() {

                @Override
                public void onPermissionRequest(final PermissionRequest request) {
                    Log.d(TAG, "onPermissionRequest");
                    getActivity().runOnUiThread(new Runnable() {
                        @TargetApi(Build.VERSION_CODES.LOLLIPOP)
                        @Override
                        public void run() {
                            if(request.getOrigin().toString().equals("https://cretanmedicare.gr/webchat/index.php")) {
                                request.grant(request.getResources());
                            } else {
                                request.deny();
                            }
                        }
                    });
                }

            });

            return rootView;
        }

        @TargetApi(Build.VERSION_CODES.KITKAT)
        @Override
        public void onStop() {
            super.onStop();

        mWebRTCWebView.evaluateJavascript("if(window.localStream){window.localStream.stop();}", null);
        }

        @Override
        public void onAttach(Activity activity) {
            super.onAttach(activity);
        }

        @TargetApi(Build.VERSION_CODES.LOLLIPOP)
        private void setUpWebViewDefaults(WebView webView) {
            WebSettings settings = webView.getSettings();

            // Enable Javascript
            settings.setJavaScriptEnabled(true);

            // Use WideViewport and Zoom out if there is no viewport defined
            settings.setUseWideViewPort(true);
            settings.setLoadWithOverviewMode(true);

            // Enable pinch to zoom without the zoom buttons
            settings.setBuiltInZoomControls(true);

            // Allow use of Local Storage
            settings.setDomStorageEnabled(true);

            if(Build.VERSION.SDK_INT > Build.VERSION_CODES.HONEYCOMB) {
                // Hide the zoom controls for HONEYCOMB+
                settings.setDisplayZoomControls(false);
            }

            // Enable remote debugging via chrome://inspect
            if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
                WebView.setWebContentsDebuggingEnabled(true);
            }

            webView.setWebViewClient(new WebViewClient(){
                @Override
                public void onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) {
                    SslCertificate serverCertificate = error.getCertificate();
                    Log.i("SSLError", error.toString());
                    handler.proceed();
                }
                @Override
                public boolean shouldOverrideUrlLoading(WebView view, String url) {
                    view.loadUrl(url);
                    return false;
                }
            });

            // AppRTC requires third party cookies to work
            CookieManager cookieManager = CookieManager.getInstance();
            cookieManager.setAcceptThirdPartyCookies(mWebRTCWebView, true);

        }
    }

}

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

Любая помощь будет принята с благодарностью, и я могу предоставить любую дополнительную информацию, которая может помочь в устранении неполадок.

...