记 H5调用打开android文件管理上传文件

webView加载H5页面,H5调用android本地文件管理器搜索指定类型文件选择并上传

效果图:

 

贴代码:

mWebView.webChromeClient = object : WebChromeClient() {
            val mIsLoadFinish : AtomicBoolean = AtomicBoolean(false)

            @RequiresApi(Build.VERSION_CODES.LOLLIPOP)
            override fun onShowFileChooser(webView: WebView?, filePathCallback: ValueCallback<Array<Uri>>?, fileChooserParams: FileChooserParams?): Boolean {
                uploadMessageAboveL = filePathCallback


                PermissionX.init(this@WebActivity)
                        .permissions( Manifest.permission.WRITE_EXTERNAL_STORAGE, Manifest.permission.READ_EXTERNAL_STORAGE)
                        .request(RequestCallback { allGranted, grantedList, deniedList ->
                            if (allGranted) {
                                
                                    val acceptTypes = fileChooserParams!!.acceptTypes

                                    startActivityForResult(Intent.createChooser(getFilerChooserIntent(acceptTypes[0]), "File Chooser"), CHOOSER_REQUEST_OA)



                              
                            } else {
                                ToastManager.show("此功能需要存储权限,请在设置-应用中开启!")
                            }
                        })

                return true
            }
 fun  getFilerChooserIntent(flag : String)  : Intent{
        val intent =  Intent(Intent.ACTION_GET_CONTENT)
          intent.addFlags(Intent.FLAG_ACTIVITY_RESET_TASK_IF_NEEDED)

        intent.addCategory(Intent.CATEGORY_OPENABLE)
        when(flag){
            ".jpg"->{
                intent.type = "image/*"

            }

            ".xls"->{
                intent.putExtra(Intent.EXTRA_MIME_TYPES, arrayOf(MimeTyppes.XLS, MimeTyppes.XLST, MimeTyppes.XLSX))

                intent.type = "*/*"

            }
            ".pdf"->{
                intent.type = "application/pdf"

            }
            ".doc"->{

                intent.putExtra(Intent.EXTRA_MIME_TYPES, arrayOf(MimeTyppes.DOC, MimeTyppes.DOCX, MimeTyppes.DOTX))
                intent.type = "*/*"

            }
            else->{
                intent.type = "*/*"

            }
        }
        intent.putExtra(Intent.EXTRA_ALLOW_MULTIPLE, false)
        return intent
    }
 override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
        super.onActivityResult(requestCode, resultCode, data)
        
        if(requestCode == CHOOSER_REQUEST_OA){
            if ( null == uploadMessageAboveL) return
            if (uploadMessageAboveL != null) {
                onActivityResultAboveLOA(requestCode, resultCode, data)
            }

        }
    }

 private fun onActivityResultAboveLOA(requestCode: Int, resultCode: Int, intent: Intent?) {
        if ( uploadMessageAboveL == null) return
        var results: Array<Uri>? = null
        if (resultCode == RESULT_OK) {
            if (intent != null) {
                val dataString = intent.dataString
                if (dataString != null) results = arrayOf(Uri.parse(dataString))
            }
        }
        uploadMessageAboveL!!.onReceiveValue(results)
        uploadMessageAboveL = null
    }
object MimeTyppes {
    val DOC = "application/msword"
    val DOCX = "application/vnd.openxmlformats-officedocument.wordprocessingml.document"
    val DOTX = "application/vnd.openxmlformats-officedocument.wordprocessingml.template"
    val XLS = "application/vnd.ms-excel"
    val XLSX = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"
    val XLST = "application/vnd.openxmlformats-officedocument.spreadsheetml.template"
    val PDF = "application/pdf"
}

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
公众号h5pdf文件上传是指在公众号的自定义菜单或服务模块中,用户可以选择上传PDF文件进行阅读或下载。这种功能的实现主要依赖于公众号的开发能力和对文件上传的处理方式。 首先,公众号需要提供一个用户界面,用户可以在该界面中选择本地存储的PDF文件进行上传。用户可以通过手机相册、微信云存储或者其他文件管理应用选择文件。在选择文件后,公众号需要进行文件格式的判断,确保上传的文件符合PDF格式的要求。 其次,公众号需要通过H5技术将选择的PDF文件上传至服务器。H5技术可以使用一些前端框架如Vue.JS、React等,通过调用服务器端提供的API接口将PDF文件传输至服务器。这个过程中需要注意文件上传的速度和稳定性,以及对用户信息的保护。 最后,公众号需要对上传的PDF文件进行存储和管理。可以采用云存储技术,将文件存储在云端,这样可以节约服务器的存储空间。同时,公众号需要为用户提供浏览和下载PDF文件的功能,可以通过将PDF文件转换为图片或者使用第三方的PDF阅读器插件来实现。 公众号h5pdf文件上传功能的实现需要公众号开发人员具备一定的后端开发和前端开发的技术,同时需要与服务器端进行数据传输和信息安全的保护。通过对用户上传PDF文件的处理,公众号可以为用户提供更加丰富的服务体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值