uni-app进行小程序隐私协议开发

简介: 为规范开发者的用户个人信息处理行为,保障用户合法权益,小程序、插件中涉及处理用户个人信息的开发者,均需补充相应用户隐私保护指引。

小程序隐私协议开发

开发说明

为规范开发者的用户个人信息处理行为,保障用户合法权益,微信要求开发者主动同步微信当前用户已阅读并同意小程序的隐私政策等收集使用规则,方可调用微信提供的隐私接口。

提供了4 个接口给开发者使用

wx.getPrivacySetting:查询微信侧记录的用户是否有待同意的隐私政策信息

wx.openPrivacyContract:打开跳转到隐私协议页面

wx.onNeedPrivacyAuthorization:监听隐私接口需要用户授权事件

wx.requirePrivacyAuthorize :模拟隐私接口调用,并触发隐私弹窗逻辑

注意:

隐私协议保护从基础库2.32.3开始支持,因此,微信开发者工具的调试基础库需>=2.32.3

开发参考:官方用户隐私保护文档

配置《小程序用户隐私保护指引》

开发者需在「小程序管理后台」配置《小程序用户隐私保护指引》,具体参考:填写说明

注意:

每个用到的隐私接口(同一类型)都需要在后台声明,仅有声明所处理的用户信息,才可以调用平台提供的对应接口或组件。若未声明,对应接口或组件将直接禁用

配置manifest.json

在manifest.json文件中添加"__usePrivacyCheck__": true配置项

    /* 微信小程序特有相关 */
    "mp-weixin": {
    
    
        "requiredPrivateInfos": [
            "getLocation"
        ],
        /*开启隐私保护*/
        "__usePrivacyCheck__": true
    },

查询隐私授权情况

创建privacyProtocol.js文件,封装查询用户隐私协议授权情况的函数

const privacyProtocol = {
   
   
    needAuthorization: false,
    privacyContractName: ''
}

/**
 * 检查用户隐私协议
 */
export function checkUserPrivacyProtocol() {
   
   
    wx.getPrivacySetting({
   
   
        success: (res) => {
   
   
            console.log(res)
            if (res.needAuthorization) {
   
   
                privacyProtocol.needAuthorization=res.needAuthorization
                privacyProtocol.privacyContractName=res.privacyContractName
            }else{
   
   
                privacyProtocol.needAuthorization=false
            }
            uni.setStorageSync("privacyProtocol", privacyProtocol);
        }
    })
}

APP.vue

在app.vue入口中调用隐私协议检查函数

<script>
    import {
   
   checkUserPrivacyProtocol} from "@/common/utils/privacyProtocol";

  export default {
   
   
        onLaunch: function() {
   
   
            console.log('App Launch')
      uni.getSystemInfo({
   
   
        success:(res)=>{
   
   
          this.$store.commit("initSystemInfo",res)
        }
      })

      const updateManager = uni.getUpdateManager();
      updateManager.onCheckForUpdate(function (res) {
   
   
        console.log("检查更新")
      });

      updateManager.onUpdateReady(function (res) {
   
   
        uni.showModal({
   
   
          title: '更新提示',
          content: '新版本已经准备好,是否重启应用?',
          success(res) {
   
   
            if (res.confirm) {
   
   
              updateManager.applyUpdate();
            }
          }
        });

      });

      updateManager.onUpdateFailed(function (res) {
   
   
        console.log("新版本下载失败")
        uni.showToast({
   
   title: "小程序更新失败", icon: 'none',duration: 5000});
      });

      /*隐私协议检查*/
      checkUserPrivacyProtocol()
        },
        onShow: function() {
   
   
            console.log('App Show')
        },
        onHide: function() {
   
   
            console.log('App Hide')
        }
    }
</script>

<style lang="scss">
      @import "uview-ui/index.scss";
      @import "@/plugin/colorui/main.css";
      @import "@/plugin/colorui/icon.css";
</style>

创建弹窗提示组件

如果存在有待用户同意的隐私政策信息,开发者需要主动提示用户阅读隐私政策等收集使用规则,也就是使用一个弹窗让用户查看隐私协议,并确认同意!

自己写的样式丑不拉几,参考开源项目:https://github.com/94xy/miniprogram-privacy,复制其弹窗组件样式

<template>
  <view>
    <view class="privacy" v-if="privacyProtocol.needAuthorization">
      <view class="content">
        <view class="title">隐私保护提示</view>
        <view class="des">
          在使用当前小程序服务之前,请仔细阅读<text class="link" @click="openPrivacyAgreement">{
  
  {privacyProtocol.privacyContractName}}</text>。如你同意{
  
  {privacyProtocol.privacyContractName}},请点击“同意”开始使用。
        </view>
        <view class="btns">
          <button class="item reject" @click="rejectAuthorization">拒绝</button>
          <button id="agree-btn" class="item agree" open-type="agreePrivacyAuthorization" @click="confirmAuthorization">同意</button>
        </view>
      </view>
    </view>
  </view>
</template>

<script>


export default {
    
    
  name: "PrivacyConfirm",
  data() {
    
    
    return {
    
    
      privacyProtocol: {
    
    }
    }
  },
  created() {
    
    
    setTimeout(() => {
    
    
      this.privacyProtocol = uni.getStorageSync("privacyProtocol");
    }, 500);
  },

  methods: {
    
    
    /**
     * 打开弹窗
     */
    open() {
    
    
      this.privacyProtocol.needAuthorization = true;
    },

    /**
     * 关闭弹窗
     */
    close() {
    
    
      this.privacyProtocol.needAuthorization = false;
    },
    /**
     * 用户点击同意
     */
    confirmAuthorization() {
    
    
      this.close();
    },
    /**
     * 用户点击拒绝
     */
    rejectAuthorization() {
    
    
      const that = this;
      uni.showModal({
    
    
        content: '如果拒绝,部分功能将异常,您确定要拒绝吗?',
        success: res => {
    
    
          if (res.confirm) {
    
    
            that.showPrivacy = false;
            // 直接退出小程序
            uni.exitMiniProgram();
          }
        }
      });
    },
    /**
     * 打开隐私协议
     */
    openPrivacyAgreement() {
    
    
      wx.openPrivacyContract({
    
    
        fail: () => {
    
    
          uni.showToast({
    
    
            title: '网络错误',
            icon: 'error'
          });
        }
      });
    },
  },
}
</script>

<style scoped>

.privacy {
    
    
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: rgba(0, 0, 0, .5);
  z-index: 9999999;
  display: flex;
  align-items: center;
  justify-content: center;
}

.content {
    
    
  width: 632rpx;
  padding: 48rpx;
  box-sizing: border-box;
  background: #fff;
  border-radius: 16rpx;
}

.content .title {
    
    
  text-align: center;
  color: #333;
  font-weight: bold;
  font-size: 32rpx;
}

.content .des {
    
    
  font-size: 26rpx;
  color: #666;
  margin-top: 40rpx;
  text-align: justify;
  line-height: 1.6;
}

.content .des .link {
    
    
  color: #07c160;
  text-decoration: underline;
}

.btns {
    
    
  margin-top: 48rpx;
  display: flex;
}

.btns .item {
    
    
  justify-content: space-between;
  width: 244rpx;
  height: 80rpx;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 16rpx;
  box-sizing: border-box;
  border: none;
}

.btns .reject {
    
    
  background: #f4f4f5;
  color: #909399;
}

.btns .agree {
    
    
  background: #07c160;
  color: #fff;
}


</style>

使用

在使用了隐私接口的页面都加上该组件,授权一次之后使用所有隐私接口就不再需要授权

<template>
  <view>
    <!--隐私协议保护确认-->
    <PrivacyConfirm></PrivacyConfirm>
  </view>
</template>

<script>
import PrivacyConfirm from './components/PrivacyConfirm'
    export default {
    
    
    name: "index",
    components:{
    
    
      PrivacyConfirm
    },
    data() {
    
    
        return {
    
    

        }
    }
  }
</script>

image.png

清空历史同步状态

从「微信下拉-最近-最近使用的小程序」中删除小程序,将清空历史同步状态。

在开发者工具中「清除模拟器缓存-清除授权数据」清空历史同步状态

官方隐私弹窗

在自行开发完隐私协议弹窗后,平台发布了官方隐私授权弹窗。

官方隐私授权弹窗在隐私相关功能启用后(2023-10-17日后或开发者在 app.json中配置 __usePrivacyCheck__: true后),无需开发者适配开发,自动向C端用户展示。

执行逻辑:

当开发者调用隐私相关接口时,微信会判断此次调用是否需要触发 wx.onNeedPrivacyAuthorization 事件,若触发后开发者未进行响应,微信将主动弹出官方弹窗。若用户同意,该接口将正常执行后续调用逻辑;若用户拒绝,将进行报错。

相关文章
|
9天前
|
JSON 自然语言处理 前端开发
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
105 72
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
|
1月前
|
前端开发 安全 开发工具
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
176 90
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
2月前
|
Dart 前端开发
【05】flutter完成注册页面完善样式bug-增加自定义可复用组件widgets-严格规划文件和目录结构-规范入口文件-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【05】flutter完成注册页面完善样式bug-增加自定义可复用组件widgets-严格规划文件和目录结构-规范入口文件-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
129 75
【05】flutter完成注册页面完善样式bug-增加自定义可复用组件widgets-严格规划文件和目录结构-规范入口文件-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
|
7天前
|
人工智能 自然语言处理 小程序
技术小白如何利用DeepSeek半小时开发微信小程序?
通过通义灵码的“AI程序员”功能,即使没有编程基础也能轻松创建小程序或网页。借助DeepSeek V3和R1满血版模型,用户只需用自然语言描述需求,就能自动生成代码并优化程序。例如,一个文科生仅通过描述需求就成功开发了一款记录日常活动的微信小程序。此外,通义灵码还提供智能问答模式,帮助用户解决开发中的各种问题,极大简化了开发流程,让普通人的开发体验更加顺畅。
技术小白如何利用DeepSeek半小时开发微信小程序?
|
1月前
|
JavaScript 搜索推荐 Android开发
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
65 8
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
|
1月前
|
机器学习/深度学习 存储 人工智能
MNN-LLM App:在手机上离线运行大模型,阿里巴巴开源基于 MNN-LLM 框架开发的手机 AI 助手应用
MNN-LLM App 是阿里巴巴基于 MNN-LLM 框架开发的 Android 应用,支持多模态交互、多种主流模型选择、离线运行及性能优化。
1624 14
MNN-LLM App:在手机上离线运行大模型,阿里巴巴开源基于 MNN-LLM 框架开发的手机 AI 助手应用
|
1月前
|
前端开发 Java Shell
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
179 20
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
3天前
|
搜索推荐 数据挖掘
直播App程序源码开发前期功能调研:运营角度思考如何有利于推广运营获利
在直播App程序源码开发的前期,功能调研至关重要。除了技术实现的可行性,更需要从运营角度出发,思考哪些功能能够助力推广运营,最终实现获利。山东布谷科技从运营角度,对直播App功能进行调研分析
|
13天前
|
小程序 数据安全/隐私保护 开发者
【02】微信支付商户申请下户到配置完整流程-微信开放平台申请APP应用-微信商户支付绑定appid-公众号和小程序分别申请appid-申请+配置完整流程-优雅草卓伊凡
【02】微信支付商户申请下户到配置完整流程-微信开放平台申请APP应用-微信商户支付绑定appid-公众号和小程序分别申请appid-申请+配置完整流程-优雅草卓伊凡
40 3
|
2月前
|
Dart 前端开发 容器
【07】flutter完成主页-完成底部菜单栏并且做自定义组件-完整短视频仿抖音上下滑动页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【07】flutter完成主页-完成底部菜单栏并且做自定义组件-完整短视频仿抖音上下滑动页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
100 18
【07】flutter完成主页-完成底部菜单栏并且做自定义组件-完整短视频仿抖音上下滑动页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈

热门文章

最新文章