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?
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");
}
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;
}
}
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);
}
}
Utilisez les éléments suivants sur votre vue Web
webview.setWebChromeClient(new WebChromeClient());
puis implémentez les méthodes requises pour la classe WebChromeClient.
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);
}
});
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é.
<network-security-config>
<domain-config cleartextTrafficPermitted="true">
<domain includeSubdomains="true">www.google.com</domain>
</domain-config>
</network-security-config>
<application
Android:networkSecurityConfig="@xml/network_security_config"
...>
</application>
si vous voulez autoriser tous les sous-domaines
<application
Android:usesCleartextTraffic="true"
...>
</application>
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"/>
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();
}
});
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