在 Android 中,处理 FileChooser 的回调需要使用 WebChromeClient 类
import androidx.appcompat.app.AppCompatActivity;
import android.webkit.WebChromeClient;
import android.webkit.WebView;
public class MainActivity extends AppCompatActivity {
// ...
}
android:id="@+id/webview"
android:layout_width="match_parent"
android:layout_height="match_parent" />
import android.webkit.WebView;
import android.webkit.WebSettings;
import android.webkit.ValueCallback;
private WebView webView;
private ValueCallback<Uri[]> filePathCallback;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
webView = findViewById(R.id.webview);
WebSettings webSettings = webView.getSettings();
webSettings.setJavaScriptEnabled(true);
webSettings.setLoadsImagesAutomatically(true);
webView.setWebChromeClient(new WebChromeClient() {
@Override
public boolean onShowFileChooser(WebView webView, ValueCallback<Uri[]> filePathCallback, FileChooserParams fileChooserParams) {
// 保存 filePathCallback 以便稍后使用
MainActivity.this.filePathCallback = filePathCallback;
// 创建一个 Intent 用于选择文件
Intent intent = new Intent(Intent.ACTION_GET_CONTENT);
intent.addCategory(Intent.CATEGORY_OPENABLE);
intent.setType("*/*");
intent.putExtra(Intent.EXTRA_ALLOW_MULTIPLE, true);
// 启动文件选择器
startActivityForResult(Intent.createChooser(intent, "选择文件"), FILECHOOSER_RESULTCODE);
return true;
}
});
}
import android.content.Intent;
import android.net.Uri;
private static final int FILECHOOSER_RESULTCODE = 1;
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == FILECHOOSER_RESULTCODE && resultCode == RESULT_OK && data != null) {
Uri[] results = null;
if (data.getData() != null) {
// 单个文件选择
results = new Uri[]{data.getData()};
} else if (data.getClipData() != null) {
// 多个文件选择
ClipData clipData = data.getClipData();
results = new Uri[clipData.getItemCount()];
for (int i = 0; i< clipData.getItemCount(); i++) {
results[i] = clipData.getItemAt(i).getUri();
}
}
// 将结果传递给 filePathCallback
if (filePathCallback != null) {
filePathCallback.onReceiveValue(results);
filePathCallback = null;
}
}
}
现在,当你的 WebView 中的 JavaScript 代码调用 input
标签的 click()
方法时,应用程序将显示文件选择器。选定的文件将通过回调传递给 WebView。