Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

copy to clipboard using navigator.clipboard.writetext not working in android WebView

I have a simple android WebView application which is displaying a website featuring 'copy' buttons using the following code:-

navigator.clipboard.writeText('Text to be copied')
  .then(() => {
    console.log('Text copied to clipboard');
  })
  .catch(err => {
    // This can happen if the user denies clipboard permissions:
    console.error('Could not copy text: ', err);
  });

this is working in all desktop and mobile browsers and an iOS WebView application however I cant it fails and catches the following error within a android WebView application: DOMException: write permission denied.

these are the settings for the WebView within the app:

    webView.settings.javaScriptEnabled = true
    webView.settings.userAgentString = "EngageMobileApp Android"
    webView.settings.builtInZoomControls = true
    webView.settings.displayZoomControls = false
    webView.settings.allowFileAccess = true
    webView.settings.setAppCacheEnabled(true)
    webView.settings.domStorageEnabled = true
    webView.settings.loadWithOverviewMode = true
    webView.settings.allowContentAccess = true
    webView.settings.mediaPlaybackRequiresUserGesture = false
    webView.settings.javaScriptCanOpenWindowsAutomatically = true
    WebView.setWebContentsDebuggingEnabled(true)

and the set permissions within the manifest:

<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.CAMERA" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
like image 982
luke-tolley Avatar asked Dec 09 '25 02:12

luke-tolley


1 Answers

The error message "DOMException: write permission denied" typically indicates that the WebView is not allowing access to the clipboard. To enable clipboard access in a WebView on Android, you need to add the android.permission.WRITE_EXTERNAL_STORAGE permission to your app's manifest file and then explicitly grant the permission at runtime.

Here's how to request the permission at runtime:

// Check if the permission has been granted
if (ContextCompat.checkSelfPermission(this, Manifest.permission.WRITE_EXTERNAL_STORAGE)
        != PackageManager.PERMISSION_GRANTED) {
    // Request the permission
    ActivityCompat.requestPermissions(this,
            new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE},
            1);
} else {
    // Permission has already been granted
}

You'll also need to handle the result of the permission request:

@Override
public void onRequestPermissionsResult(int requestCode, String[] permissions,
        int[] grantResults) {
    if (requestCode == 1) {
        if (grantResults.length > 0
                && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
            // Permission has been granted
        } else {
            // Permission has been denied
        }
    }
}

Note that requesting the WRITE_EXTERNAL_STORAGE permission may prompt the user to grant other permissions related to storage access, such as READ_EXTERNAL_STORAGE.

like image 93
Akalanka Ekanayake Avatar answered Dec 11 '25 14:12

Akalanka Ekanayake



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!