Failed to find provider <authority> for user 0 ; expected to find a valid ContentProvider for的解决办法

可能是我愚蠢迟钝,按照其他网站的办法一整晚都没有解决到这个问题,但是隔天下午重新整理思绪看了下一个地方的提醒后来试了下才醒悟,下面贴代码:

app功能是做一个程序锁,将需要锁起来的程序保存在一个数据库中,创建个内容观察者即使在service运行的时候也能添加程序

getContentResolver().registerContentObserver(Uri.parse("Content://AppLock"),true, mInnerObserver);

下面是需要添加的地方:

        <provider
            android:name="com.example.adminstrator.phonetool.authority.AppLock"  //定义一个继承ContentProvider类
            android:authorities="AppLock"  //authorities是填写“Content://”后面跟上的Authority(即AppLock)
            android:enabled="true"
            android:exported="false">
        </provider>



以上,敬礼

献上借鉴的地方:

https://blog.csdn.net/weixin_37077539/article/details/80067073

https://stackoverflow.com/questions/45925380/securityexception-failed-to-find-provider-null-for-user-0-on-activeandroid-on


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
对数据进行修改需要在编辑按钮的点击事件中进行处理,可以在方法中接收当前被点击的数据对象,然后将其赋值给一个临时变量,进行修改后再将修改后的数据赋值回去。同时需要确保不改变数据的id。 下面是一个可能的实现方式: <template> <div class="content"> <div class="row"> <div class="list"> <ul> <li>序号</li> <li>权限</li> <li>角色</li> <li>账号</li> <li>编辑</li> </ul> </div> </div> <div class="row"> <div class="lists"> <ul v-for="item in dataList" :key="item.id"> <li>{{ item.userid }}</li> <li>{{ item.authority }}</li> <li>{{ item.role }}</li> <li>{{ item.username }}</li> <li @click="edit(item)">编辑</li> </ul> </div> </div> </div> </template> <script setup> import { ref, onMounted } from "vue"; import { getList } from "@/api/user"; const dataList = ref([]); const editedData = ref(null); onMounted(async () => { try { const response = await getList(); dataList.value = response.data; } catch (error) { console.error(error); } }); const edit = (data) => { editedData.value = { ...data }; // 弹出编辑框,让用户修改数据 // ... } const save = () => { // 将修改后的数据赋值回去 const index = dataList.value.findIndex((item) => item.id === editedData.value.id); if (index >= 0) { dataList.value[index] = { ...editedData.value }; } // 隐藏编辑框 // ... } </script> 在 edit 方法中,我们将当前被点击的数据对象赋值给了 editedData 变量,这样在编辑框中修改数据时,就修改的是这个临时变量中的数据。在 save 方法中,我们根据 editedData 变量中的 id 找到原始数据中对应的索引,然后将修改后的数据赋值回去。这样就实现了对数据的修改而不改变 id 的要求。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值