在 Android 中,处理 FileChooser 的回调需要使用 WebChromeClient 类
首先,确保你的 Activity 继承自 AppCompatActivity,并实现 WebChromeClient.FileChooserParams 接口。import androidx.appcompat.app.AppCompatActivity;import android.webkit.WebChromeClient;import android.webkit.WebView;public class MainActivity extends AppCompatActivity { // ...}在你的布局文件中添加一个 WebView。 android:id="@+id/webview" android:layout_width="match_parent" android:layout_height="match_parent" />初始化 WebView 并设置 WebChromeClient。import android.webkit.WebView;import android.webkit.WebSettings;import android.webkit.ValueCallback;private WebView webView;private ValueCallback<Uri[]> filePathCallback;@Overrideprotected 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; } });}重写 onActivityResult 方法以处理文件选择结果。import android.content.Intent;import android.net.Uri;private static final int FILECHOOSER_RESULTCODE = 1;@Overrideprotected 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。