Gururaju Hiddenx Gururaju Hiddenx - 1 year ago 229
HTML Question

Android webview input type file

I'm trying to build web project using android, from webview. I have a input field of type file

<input type="file" >
to let user upload files to server, but it seem not to work on android webview, when I tap on the browse button, nothing happens.

package com.gururaju.bbmp;

import android.os.Bundle;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.webkit.WebChromeClient;

public class Comp extends Activity {
WebView comp;
protected void onCreate(Bundle savedInstanceState) {

WebView myWebView = (WebView) findViewById(;
myWebView.setWebChromeClient(new WebChromeClient());



<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android=""
android:orientation="vertical" android:layout_width="match_parent"



comp.html (in assets folder)

<!DOCTYPE html>
<html lang="en">
<link rel="stylesheet" type="text/css" href="comp.css">
<meta charset="UTF-8">
<h2 align="center">Post your Complaints here</h2>
<form enctype="multipart/form-data" action="" name="complaints" method="POST">
<input class="title" type="text" name="title" placeholder="Enter the Complaint Title" /><br />

<div class="spacer-welcome"></div>
<textarea name="desc" class="desc" placeholder="Your complaint description here..."></textarea><br />
<div class="spacer-welcome1"></div>

<input id="center" type="file" name="image" ><br />
<input class="upload" type="submit" name="submit" value="Submit" >

Any help would be appreciated.

Answer Source

The answer by Riad points into the right direction, but that single callback is not enough to implement.

There are, in total, four hidden API methods that you have to implement. Their usage depends on the Android version. These methods are:

public void openFileChooser(ValueCallback<Uri> uploadMsg)
public void openFileChooser(ValueCallback<Uri> uploadMsg, String acceptType)
public void openFileChooser(ValueCallback<Uri> uploadMsg, String acceptType, String capture)
public boolean onShowFileChooser(WebView webView, ValueCallback<Uri[]> filePathCallback, WebChromeClient.FileChooserParams fileChooserParams)

You can use the following library which does all these things for you:

Alternatively, you may take a look at the source code to see how it's done: