web-dev-qa-db-fra.com

Android WebView ne charge pas l'URL

Je veux charger le URL in WebView

J'ai utilisé le code suivant:

webView = (WebView) findViewById(R.id.webview1);
webView.setWebViewClient(new HostsWebClient());
webView.getSettings().setPluginState(PluginState.ON);
webView.getSettings().setJavaScriptEnabled(true);
webView.getSettings().setJavaScriptCanOpenWindowsAutomatically(false);
webView.getSettings().setPluginsEnabled(true);
webView.getSettings().setSupportMultipleWindows(false);
webView.getSettings().setSupportZoom(false);
webView.setVerticalScrollBarEnabled(false);
webView.setHorizontalScrollBarEnabled(false);

webView.loadUrl(URL);

Mais quand je l'exécute, je ne peux pas charger l'URL. Je reçois une page Web non disponible.

Quelqu'un pourrait-il aider?

28
String

Avez-vous ajouté la permission Internet dans votre fichier manifeste? sinon ajoutez la ligne suivante. 

 <uses-permission Android:name="Android.permission.INTERNET"/> 

j'espère que ceci vous aidera.

MODIFIER

Utilisez les lignes ci-dessous. 

public class WebViewDemo extends Activity {


    private WebView webView;


    Activity activity ;
    private ProgressDialog progDailog; 

    @SuppressLint("NewApi")
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        activity = this;

        progDailog = ProgressDialog.show(activity, "Loading","Please wait...", true);
        progDailog.setCancelable(false);



       webView = (WebView) findViewById(R.id.webview_compontent);



       webView.getSettings().setJavaScriptEnabled(true);     
       webView.getSettings().setLoadWithOverviewMode(true);
       webView.getSettings().setUseWideViewPort(true);        
        webView.setWebViewClient(new WebViewClient(){

            @Override
            public boolean shouldOverrideUrlLoading(WebView view, String url) {
                progDailog.show();
                view.loadUrl(url);

                return true;                
            }
            @Override
            public void onPageFinished(WebView view, final String url) {
                progDailog.dismiss();
            }
        });

        webView.loadUrl("http://www.teluguoneradio.com/rssHostDescr.php?hostId=147");

       }
80
itsrajesh4uguys

Ajouter une autorisation Autorisation Internet dans le manifeste.

comme <uses-permission Android:name="Android.permission.INTERNET"/>

Ce code ça marche 

  public class WebActivity extends Activity {
  WebView wv;

 String url="http://www.teluguoneradio.com/rssHostDescr.php?hostId=147";

 @Override
 protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_web);
    wv=(WebView)findViewById(R.id.webUrl_WEB);



WebSettings webSettings = wv.getSettings();
    wv.getSettings().setLoadWithOverviewMode(true);
    wv.getSettings().setUseWideViewPort(true);
    wv.getSettings().setBuiltInZoomControls(true);
    wv.getSettings().setPluginState(PluginState.ON);


    wv.setWebViewClient(new myWebClient());

    wv.loadUrl(url);
}




public class myWebClient extends WebViewClient {
    @Override
    public void onPageStarted(WebView view, String url, Bitmap favicon) {
        // TODO Auto-generated method stub
        super.onPageStarted(view, url, favicon);
    }

    @Override
    public boolean shouldOverrideUrlLoading(WebView view, String url) {
        // TODO Auto-generated method stub

        view.loadUrl(url);
        return true;

    }
}
15
Rank

peut-être SSL 

    @Override
    public void onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) {
        // ignore ssl error
        if (handler != null){
            handler.proceed();
        } else {
            super.onReceivedSslError(view, null, error);
        }
    }
9
wanpen

Utilisez les éléments suivants sur votre vue Web

webview.setWebChromeClient(new WebChromeClient());

puis implémentez les méthodes requises pour la classe WebChromeClient.

4
vinoth

Tout d’abord, vérifiez si vous avez la permission Internet dans le fichier Manifest.

<uses-permission Android:name="Android.permission.INTERNET" />

Vous pouvez ensuite ajouter le code suivant dans la méthode onCreate () ou initialize (). 

final WebView webview = (WebView) rootView.findViewById(R.id.webview);
        webview.setWebViewClient(new MyWebViewClient());
        webview.getSettings().setBuiltInZoomControls(false);
        webview.getSettings().setSupportZoom(false);
        webview.getSettings().setJavaScriptCanOpenWindowsAutomatically(true);
        webview.getSettings().setAllowFileAccess(true);
        webview.getSettings().setDomStorageEnabled(true);
        webview.loadUrl(URL);

Et écrivez une classe pour gérer les rappels de webview - 

public class MyWebViewClient extends WebViewClient {
        @Override
        public boolean shouldOverrideUrlLoading(WebView view, String url) {
                           //your handling...
                return super.shouldOverrideUrlLoading(view, url);
        }
    }

dans la même classe, vous pouvez également utiliser d'autres rappels importants tels que - 

- onPageStarted()
- onPageFinished()
- onReceivedSslError()

En outre, vous pouvez ajouter "SwipeRefreshLayout" pour activer l'actualisation par balayage et la visualisation Web. 

<Android.support.v4.widget.SwipeRefreshLayout
        Android:id="@+id/swipeRefreshLayout"
        Android:layout_width="match_parent"
        Android:layout_height="match_parent">
        <WebView
            Android:id="@+id/webview"
            Android:layout_width="match_parent"
            Android:layout_height="match_parent" />
    </Android.support.v4.widget.SwipeRefreshLayout>

Et actualisez la vue Web lorsque l'utilisateur fait glisser l'écran:

SwipeRefreshLayout mSwipeRefreshLayout = (SwipeRefreshLayout) findViewById(R.id.swipeRefreshLayout);
            mSwipeRefreshLayout.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {
                @Override
                public void onRefresh() {
                    new Handler().postDelayed(new Runnable() {
                        @Override
                        public void run() {
                            mSwipeRefreshLayout.setRefreshing(false);
                            webview.reload();
                        }
                    }, 3000);
                }
            });
2
DsD

Remarque: assurez-vous que la permission Internet est donnée.

Dans Android 9.0,

Webview ou Imageloader ne peuvent pas charger l’URL ou l’image car Android 9 a un problème de sécurité réseau qui doit être activé par fichier manifeste pour tous les sous-domaines. donc vous pouvez ajouter un fichier de configuration de sécurité.

  1. Ajoutez @ xml/network_security_config dans vos ressources:

<network-security-config>
    <domain-config cleartextTrafficPermitted="true">
    <domain includeSubdomains="true">www.google.com</domain>
    </domain-config>
</network-security-config>

  1. Ajoutez cette configuration de sécurité à votre manifeste comme ceci:

<application
   
    Android:networkSecurityConfig="@xml/network_security_config"
    ...>
</application>

si vous voulez autoriser tous les sous-domaines 

<application
   Android:usesCleartextTraffic="true"
    ...>
</application>

1
Yogendra

La solution la plus simple consiste à accéder à votre mise en page XML contenant votre vue Web. Changez votre Android: layout_width et Android: layout_height de "wrap_content" à "match_parent".

  <WebView
        Android:layout_width="match_parent"
        Android:layout_height="match_parent"
        Android:id="@+id/webView"/>
0
Arlene Jusayan

Dans mon cas, l’ajout des fonctions suivantes à WebViewClient a corrigé l’erreur . Les fonctions sont les suivantes: onReceivedSslError et Depricated et les nouvelles versions api de shouldOverrideUrlLoading 

        webView.setWebViewClient(new WebViewClient() {

        @SuppressWarnings("deprecation")
        @Override
        public boolean shouldOverrideUrlLoading(WebView view, String url) {
            view.loadUrl(url);
            Log.i(TAG, "loading: deprecation");
            return  true;
            //return super.shouldOverrideUrlLoading(view, url);
        }

        @Override
        @TargetApi(Build.VERSION_CODES.N)
        public boolean shouldOverrideUrlLoading(WebView view, WebResourceRequest request) {
            view.loadUrl(request.getUrl().toString());
            Log.i(TAG, "loading: build.VERSION_CODES.N");
            return true;
            //return super.shouldOverrideUrlLoading(view, request);
        }

        @Override
        public void onPageStarted(
                WebView view, String url, Bitmap favicon) {
            Log.i(TAG, "page started:"+url);
            super.onPageStarted(view, url, favicon);
        }

        @Override
        public void onPageFinished(WebView view, final String url) {

            Log.i(TAG, "page finished:"+url);

        }

        @Override
        public void onReceivedSslError(WebView view, SslErrorHandler handler, SslError er) {
            handler.proceed();
        }

    });
0
Hamid

Juste comme une solution alternative:

Pour moi, webView.getSettings().setUserAgentString("Android WebView") a fait l'affaire.

J'ai déjà implémenté l'autorisation INTERNET et WebViewClient ainsi que WebChromeClient

0
mad_manny