微信小程序常用个人信息获取(下)

简介: 第一篇文章:微信小程序登录流程解析的评论区,大家的留言给了作者很大的写作分享动力,本文继续新知识的学习,讲述微信小程序常用个人信息获取,附上示例代码供大家快速上手。

示例代码:

wx.chooseImage({
  count: 1, //用户可上传的图片数量
  sizeType: ['original', 'compressed'], //用户可选原图、压缩图
  sourceType: ['album', 'camera'], //用户可选图片来源
  success (res) {
    console.log("打印本地临时文件路径列表",res.tempFilePaths);
  }
})

使用场景:上传证件资料
注意事项:
1、如果要上传图片到云存储空间,可以通过wx.cloud.uploadFile()实现,在这不再展开;
2、如果要上传图片到开发者服务器,则用wx.uploadFile()实现上传,后端再进一步获取(如通过PHP的$_FILES)

wx.chooseImage({
  count: 1, //用户可上传的图片数量
  sizeType: ['original', 'compressed'], //用户可选原图、压缩图
  sourceType: ['album', 'camera'], //用户可选图片来源
  success: (res) => {
    const tempFilePaths = res.tempFilePaths
    wx.uploadFile({
      url: 开发者服务器接口地址,
      filePath: tempFilePaths[0],
      name: 'file',
      formData: {
        'xxx': 'xxx'
      },
      success : (res) => {
        //打印返回的数据
      }
    })
  }
})

3、类似的接口还有wx.chooseMedia(),从手机相册选择图片、视频或使用相机拍摄

wx.chooseMedia({
  count: 1,
  mediaType: ['image','video'],
  sourceType: ['album', 'camera'],
  maxDuration: 30, //拍摄视频最长拍摄时间,单位秒
  camera: 'back',
  success: (res) => {
    console.log("临时文件地址",res.tempFiles[0].tempFilePath);
    console.log("临时文件大小",res.tempFiles[0].size);
  }
})


   

08q


   

摄像头

接口1说明:调起摄像功能
是否需要授权:
页面截图: 

31.jpg

示例代码:

<!-- wxml -->
<!-- device-position="front"为前摄;
flash(闪光灯)的值可为auto(自动)、on(打开)、off(关闭)、torch(常亮) -->  
<camera device-position="back" flash="off" binderror="error" style="width: 100%; height: 300px;"></camera>
<button type="primary" bindtap="takePhoto">拍照</button>
<image mode="widthFix" src="{{src}}"></image>
<!-- js -->
takePhoto() {
  //创建 camera 上下文 CameraContext 对象
  const ctx = wx.createCameraContext();
  ctx.takePhoto({
    quality: "high",
    success: (res) => {
      this.setData({
        src: res.tempImagePath //照片地址赋值
      })
    }
  })
}

使用场景:人脸识别
注意事项:1、同一页面只能有一个camera组件,不需要点击事件触发授权窗口;
2、拍摄照片接口为takePhoto,需要先创建CameraContext 对象,见示例代码

接口2说明:调起扫码功能
是否需要授权:否
页面截图: 

32.png


示例代码:

wx.scanCode({
  onlyFromCamera: true, //是否只能从相机扫码(是否不允许从相册选择图片)
  success: (res) => {
    console.log("内容",res.result);//常为网址或空
    console.log("类型",res.scanType);//QR_CODE、WX_CODE等等
      }
})

使用场景:扫码

   

09q


   

手机号码

接口说明:获取用户手机号码
是否需要授权:
页面截图: 

333.jpg


示例代码:

<!-- wxml -->
<button open-type="getPhoneNumber" bindgetphonenumber="getPhoneNumber">获取手机号</button>
<!-- js -->
getPhoneNumber (e) {
  console.log("加密算法的初始向量",e.detail.iv);
  console.log("加密数据",e.detail.encryptedData);
  console.log("云ID", e.detail.cloudID);
}

使用场景:获取联系方式
注意事项:
1、button组件的open-type值需要设置为getPhoneNumber,用户允许授权之后触发bindgetphonenumber事件返回相关加密信息和云ID;
2、后续在开发者服务器结合加密数据解密手机号,或通过云函数结合cloudID获取手机号码


   

10q


   

通讯录信息

接口说明:返回联系人姓名和电话
是否需要授权:否(需要用户选择联系人才返回信息)
页面截图: 

34.jpg


示例代码:

wx.chooseContact({
  success: (res) => {
    console.log("姓名",res.displayName);
    console.log("电话号码",res.phoneNumber);
  }
})

使用场景:获取联系方式
注意事项:
部分安卓机返回特定联系人的所有手机号;

console.log("选定联系人手机号",res.phoneNumberList);


   

11q


   

设备信息


接口说明:返回用户的设备信息
是否需要授权:否
页面截图: 


35.jpg


示例代码:

wx.getSystemInfo({
  success (res) {
    console.log("设备品牌", res.brand);
    console.log("设备型号", res.model);
    console.log("屏幕宽度", res.screenWidth);
    console.log("屏幕高度", res.screenHeight);
    console.log("语言设置", res.language);
    console.log("微信版本", res.version);
    console.log("操作系统及版本", res.system);
    console.log("客户端平台", res.platform);
    console.log("客户端基础库版本", res.SDKVersion);
    console.log("蓝牙开关", res.bluetoothEnabled);
    console.log("Wi-Fi开关", res.wifiEnabled);
    console.log("宿主环境", res.host);
  }
})

使用场景:处理兼容性
注意事项:
1、异步版本为wx.getSystemInfoAsync;
2、如果是刚推出的新机型,获取的设备品牌可能为unknown,需要等待微信适配

本文作者:朱顺意,文章技术相关交流,可添加微信号:475333435

声明:本文为 脚本之家专栏作者 投稿,未经允许请勿转载。


相关文章
|
7月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp小程序的学院个人信息管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp小程序的学院个人信息管理系统附带文章源码部署视频讲解等
33 1
|
6月前
|
小程序 定位技术
【微信小程序-原生开发】TDesign 实战模板——个人信息编辑页
【微信小程序-原生开发】TDesign 实战模板——个人信息编辑页
59 0
|
8月前
|
小程序 数据安全/隐私保护 容器
电商小程序07显示用户个人信息
电商小程序07显示用户个人信息
|
小程序 API 数据安全/隐私保护
微信小程序常用个人信息获取(上)
第一篇文章:微信小程序登录流程解析的评论区,大家的留言给了作者很大的写作分享动力,本文继续新知识的学习,讲述微信小程序常用个人信息获取,附上示例代码供大家快速上手。
微信小程序常用个人信息获取(上)
|
2月前
|
小程序 前端开发 JavaScript
在线课堂+工具组件小程序uniapp移动端源码
在线课堂+工具组件小程序uniapp移动端源码
43 0
在线课堂+工具组件小程序uniapp移动端源码
|
3月前
|
移动开发 小程序 数据可视化
基于npm CLI脚手架的uniapp项目创建、运行与打包全攻略(微信小程序、H5、APP全覆盖)
基于npm CLI脚手架的uniapp项目创建、运行与打包全攻略(微信小程序、H5、APP全覆盖)
404 3
|
3月前
|
小程序 API
微信小程序更新提醒uniapp
在小程序开发中,版本更新至关重要。本方案利用 `uni-app` 的 `uni.getUpdateManager()` API 在启动时检测版本更新,提示用户并提供立即更新选项,自动下载更新内容,并在更新完成后重启小程序以应用新版本。适用于微信小程序,确保用户始终使用最新版本。以下是实现步骤: ### 实现步骤 1. **创建更新方法**:在 `App.vue` 中创建 `updateApp` 方法用于检查小程序是否有新版本。 2. **测试**:添加编译模式并选择成功状态进行模拟测试。
62 0
微信小程序更新提醒uniapp
|
5月前
|
小程序 前端开发 Java
SpringBoot+uniapp+uview打造H5+小程序+APP入门学习的聊天小项目
JavaDog Chat v1.0.0 是一款基于 SpringBoot、MybatisPlus 和 uniapp 的简易聊天软件,兼容 H5、小程序和 APP,提供丰富的注释和简洁代码,适合初学者。主要功能包括登录注册、消息发送、好友管理及群组交流。
123 0
SpringBoot+uniapp+uview打造H5+小程序+APP入门学习的聊天小项目
|
5月前
|
小程序 前端开发 JavaScript
【项目实战】SpringBoot+uniapp+uview2打造一个企业黑红名单吐槽小程序
【避坑宝】是一款企业黑红名单吐槽小程序,旨在帮助打工人群体辨别企业优劣。该平台采用SpringBoot+MybatisPlus+uniapp+uview2等技术栈构建,具备丰富的注释与简洁的代码结构,非常适合实战练习与学习。通过小程序搜索“避坑宝”即可体验。
130 0
【项目实战】SpringBoot+uniapp+uview2打造一个企业黑红名单吐槽小程序
|
5月前
|
存储 小程序 JavaScript