我需要在Android应用程序上接收令牌。.我在laravel上创建了API,并且我需要接收身份验证令牌,但是我不知道如何在android上进行操作。 我做了一些代码,但是没有用。.
公共类LoginActivity扩展了AppCompatActivity {
PublishDatabaseSettings
}
答案 0 :(得分:0)
好的,您有两个选择:
第一个
第一个是更好的。如果您可以访问Web前端的代码,则可以执行此操作。基本上,您只需添加一个WebAppInterface
。文档really well对此进行了描述。您的android函数应该接受令牌作为参数,并且在用户成功登录并获得令牌后,前端应调用它。
因此您的外观如下:
class WebAppInterface(private val mContext: Context) {
/** Show a toast from the web page */
@JavascriptInterface
fun consumeToken(token: String) {
//do whatever you want to do with the token.
}
}
您必须这样注册:webView.addJavascriptInterface(WebAppInterface(this), "Android")
然后,您的Web前端(JavaScript端)可以调用如下函数:Android.consumeToken(token);
第二个
这个有点复杂。像往常一样和set a WebViewClient to your WebView
加载URL。像这样:
webView.webViewClient = object: WebViewClient() {
override fun onPageFinished(view: WebView?, url: String?) {
super.onPageFinished(view, url)
webView.evaluateJavascript("(function() { return JSON.stringify(localStorage); })();") { s ->
if (s != "\"{}\"") {
var jsonAsStr = s.substring(1, s.length - 1).replace("\\", "")
val obj = JSONObject(jsonAsStr)
val token = obj.getString("token")
}
}
}
}
webView.loadUrl("https://www.google.com/")
因此,在加载新站点时将调用onPageFinished
。这样,您就知道用户已完成登录(是的,如果在该处有其他按钮或其他可以单击的按钮也将触发此功能)。但是,您可以通过检查onPageStarted
中的url来发现这些错误,并查看它是否与用户登录后应该看到的页面匹配。像这样:onPageStarted
被调用->如果该URL与用户登录后应该看到的页面的URL相匹配,则它是正确的页面,您可以调用evaluateJavascript
。但是也许我的简单示例足以满足您的用例。
无论如何,evaluateJavascript
然后将javascript注入客户端,该客户端将读取localStorage
。然后检查它是否为空,然后解析为jsonObject
。然后,只需从jsonified本地存储中检索令牌即可。就是这样:)
与Java相同:
webView.setWebViewClient(new WebViewClient() {
@Override
public void onPageFinished(WebView view, String url) {
super.onPageFinished(view, url);
webView.evaluateJavascript("(function() { return JSON.stringify(localStorage); })();", new ValueCallback<String>() {
@Override
public void onReceiveValue(String s) {
if (s != "\"{}\"") {
String jsonAsStr = s.substring(1, s.length() - 1).replace("\\", "");
try {
JSONObject obj = new JSONObject(jsonAsStr);
String token = obj.getString("token");
} catch (JSONException e) {
}
}
}
});
}
});