Ho un sito web con href
in essa che mi ha reindirizzato a HTTPSprogrammatica click in Android WebView
<a id="mA" href="javascript:pLogin(2)" class="login-link__link private-cab-link"><i class="icon-user"></i>Авторизация</a>
Quindi, posso cliccare su di esso da JavaScript. Funziona in console cromata
javascript:(function(){document.getElementById('mA').click();})()
Ora sto cercando di fare lo stesso in WebView facendo clic sul pulsante di mia app.
public class RostelecomLoginActivity extends Activity {
WebView webView;
String url;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
this.getWindow().requestFeature(Window.FEATURE_PROGRESS);
setContentView(R.layout.activity_rostelecom_login);
Intent webIntent = getIntent();
String url = webIntent.getStringExtra("url");
webView = (WebView) findViewById(R.id.webView1);
webView.setWebViewClient(new MeWebViewClient());
webView.getSettings().setJavaScriptEnabled(true);
webView.getSettings().setSaveFormData(true);
webView.getSettings().setSavePassword(true);
webView.loadUrl(url);
Button buttoner = (Button) findViewById(R.id.button1);
buttoner.setOnClickListener(new OnClickListener() {
public void onClick(View v) {
webView.loadUrl("javascript:(function(){document.getElementById('mA').click();})()");
}
});
}
}
sto usando MyWebViewClient per consentire a tutti i certificati
public class MeWebViewClient extends WebViewClient {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
view.loadUrl(url);
return true;
}
@Override
public void onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) {
handler.proceed();
}
}
Il js iniezione non funziona. Se clicco su href in WebView funziona. Cosa può essere sbagliato?
perche a accetta una risposta La soluzione fornita da "deviato" funziona alla grande. L'ho provato Cordiali saluti – Lisitso