# 概述

uni-id-pages,是uni-id体系的一部分。

它基于uni-id-common提供了一批现成的、开源的、登录注册账户管理相关的前端页面和云端云对象。

它是一个云端一体页面组的uni_modules,含前端页面和后端云对象(uni-id-co)。

开发者在项目中引入uni-id-pages,账户管理的功能无需自己再开发。由于源码的开放性和层次结构清晰,有二次开发需求也很方便调整。

下载地址:https://ext.dcloud.net.cn/plugin?name=uni-id-pages

uni-id-pages的功能包括:

  • 注册账号:
    • 用户名和密码
  • 免密登录(首次登录自动注册):
    • app一键登录
    • 短信验证码登录
    • 微信登录(自动获取头像和昵称)
    • 苹果登录
    • 支付宝小程序登录(暂未实现)
  • 密码登录
    • 用户名/手机号和密码登录
  • 账户管理
    • 个人中心
    • 头像更换
    • 修改昵称
    • 绑定手机号码
    • 修改密码(仅账号有设置密码时可见)
    • 找回密码(仅账号有绑定手机号码可见)
    • 退出登录
    • 注销账号(上架国内App应用市场必备)
    • 实名认证 (详见文档)
  • 用户服务协议和隐私政策条款授权

# 目录结构


├─uni_modules                                         存放uni_module规范的插件。
│    ├─其他module
│    └─uni-id-pages
│        ├─uniCloud
│        │    └─cloudfunctions                        云函数目录
│        │        └─uni-id-co                         集成调用uni-id方法的云对象
│        │            ├─common                        公用逻辑
│        │            ├─config                        配置
│        │            │  └─permission.js              调用接口所需的权限配置
│        │            ├─lang                          国际化目录
│        │            ├─lib                           基础功能,不建议修改此目录下文件
│        │            │  ├─third-party                三方平台接口
│        │            │  └─utils                      基础功能
│        │            ├─middleware                    中间件
│        │            └─module                        分模块存放的云对象方法
│        ├─common
│        │    ├─login-page.scss                       登录页面公共样式
│        │    ├─login-page.mixin.js                   登录页面公共mixin文件
│        │    └─loginSuccess.js                       登录成功后执行的文件
│        ├─components
│        │    ├─cloud-image                           uniCloud云存储图片解析组件
│        │    │    └─cloud-image.vue
│        │    ├─uni-id-pages-agreements               同意用户服务协议&隐私政策条款组件
│        │    │    └─uni-id-pages-agreements.vue
│        │    ├─uni-id-pages-avatar                   用户头像组件
│        │    │    └─uni-id-pages-avatar.vue
│        │    ├─uni-id-pages-bind-mobile              通过微信获取手机号码绑定个人资料
│        │    │    └─uni-id-pages-bind-mobile.vue
│        │    ├─uni-id-pages-email-form               邮箱验证码组件
│        │    │    └─uni-id-pages-email-form.vue
│        │    ├─uni-id-pages-fab-login                悬浮的切换登录方式组件
│        │    │    └─uni-id-pages-fab-login.vue
│        │    ├─uni-id-pages-sms-form                 获取短信验证码组件
│        │    │    └─uni-id-pages-sms-form.vue
│        │    └─uni-id-pages-user-profile             获取用户信息组件
│        │        └─uni-id-pages-user-profile.vue
│        ├─pages
│        │    ├─common
│        │    │    └─webview                          用于实现应用内浏览或打开《用户协议和隐私协议》URL链接页面
│        │    │        └─webview.vue
│        │    ├─login                        
│        │    │    ├─login-smscode.vue                短信验证码登录
│        │    │    ├─login-withoutpwd.vue             免密码登录
│        │    │    └─login-withpwd.vue                密码登录
│        │    ├─register                    
│        │    │    ├─register.vue                     通过用户名密码注册账号
│        │    │    ├─register-admin.vue               创建超级管理员
│        │    │    ├─register-by-email.vue            通过邮箱验证码注册账号
│        │    │    └─validator.js                     注册账号页的表单验证规则文件
│        │    ├─retrieve                              
│        │    │    ├─retrieve-by-email.vue            通过邮箱验证码重置密码
│        │    │    └─retrieve.vue					            通过手机验证码重置密码
│        │    └─userinfo
│        │        ├─bind-mobile.vue                   绑定手机号码
│        │        ├─change_pwd.vue                    修改密码
│        │        ├─cropImage.vue                     裁剪图片
│        │        ├─deactivate.vue                    注销账号
│        │        ├─set-pwd.vue                       设置密码
│        │        ├─realname-verify                   实名认证
│        │        └─userinfo.js                       注册账号页的表单验证规则文件
│        ├─static                                     静态资源目录
│        ├─changelog.md                               更新日志
│        ├─config.js                                  uni-id-pages的配置文件
│        ├─init.js                                    初始化文件
│        ├─package.json                               包管理文件
│        └─readme.md                                  插件自述文件

**完整的uni-app目录结构详情查看

# 前端页面

# 创建并配置uni-id的配置文件

# 初始化

需要在App.vue中初始化uni-id-pagesinit.js文件

示例代码如下:

<script>
	import uniIdPageInit from '@/uni_modules/uni-id-pages/init.js';
	export default {
	onLaunch: async function() {
	console.log('App Launch')
	await uniIdPageInit()
},
	onShow: function() {
	console.log('App Show')
},
	onHide: function() {
	console.log('App Hide')
}
}
</script>

# 配置

路径:/uni_modules/uni-id-pages/config.js

字段 类型 描述
debug Boolean 调试模式详情
loginTypes Array 登录方式详情
agreements Array 隐私政策详情
appid Object 接入各类服务(如微信登录服务)的应用id详情
passwordStrength Object 密码配置 详情
setPasswordAfterLogin Boolean/Object 登录后设置密码 详情

完整示例:

export default {
	//调试模式
	"debug":true,
	/*
		登录类型 未列举到的或运行环境不支持的,将被自动隐藏。
		如果需要在不同平台有不同的配置,直接用条件编译即可
	*/
	"loginTypes": [
		"univerify",
		"weixin",
		"username",
		"apple",
		"smsCode"
	],
	//政策协议
	"agreements": {
		"serviceUrl": "https://xxx", //用户服务协议链接
		"privacyUrl": "https://xxx", //隐私政策条款链接
		// 哪些场景下显示,1.注册(包括注册并登录,如:微信登录、苹果登录、短信验证码登录)、2.登录(如:用户名密码登录)、3. 实名认证
		"scope": ['register', 'login', 'realNameVerify']
	},
	// 提供各类服务接入(如微信登录服务)的应用id
	"appid":{
		"weixin":{
			// 微信公众号的appid,来源:登录微信公众号(https://mp.weixin.qq.com)-> 设置与开发 -> 基本配置 -> 公众号开发信息 -> AppID
			"h5":"wx111111111111111",
			// 微信开放平台的appid,来源:登录微信开放平台(https://open.weixin.qq.com) -> 管理中心 -> 网站应用 -> 选择对应的应用名称,点击查看 -> AppID
			"web":"wx22222222222222"
		}
	},
	/**
	 * 密码强度
	 * super(超强:密码必须包含大小写字母、数字和特殊符号,长度范围:8-16位之间)
	 * strong(强: 密密码必须包含字母、数字和特殊符号,长度范围:8-16位之间)
	 * medium (中:密码必须为字母、数字和特殊符号任意两种的组合,长度范围:8-16位之间)
	 * weak(弱:密码必须包含字母和数字,长度范围:6-16位之间)
	 * 为空或false则不验证密码强度
	 */
	"passwordStrength":"medium",
	/**
	 * 登录后允许用户设置密码(只针对未设置密码得用户)
	 * 开启此功能将 setPasswordAfterLogin 设置为 true 即可
	 * "setPasswordAfterLogin": false
	 *
	 * 如果允许用户跳过设置密码 将 allowSkip 设置为 true
	 * "setPasswordAfterLogin": {
	 *   "allowSkip": true
	 * }
	 * */
	"setPasswordAfterLogin": false
}

# 调试模式

debug模式下,启动应用会自动发起一次网络请求(调用uni-id-cogetSupportedLoginType)。

检查:uni-id-pages客户端配置的登录方式,是否未在uniCloud服务端配置正确,否则抛出异常。

# 登录方式

字段 描述 平台差异
univerify 一键登录 App 3.0.0+
smsCode 短信验证码登录
weixin 微信登录 App,微信小程序,Web(uni-id-pages 版本号1.0.8起支持)
weixinMobile 微信手机号登录 微信小程序
apple 苹果登录Apple登录 iOS13+支持,App 2.4.7+
username 用户名密码登录
# 配置示例
export default {
	"loginTypes": ["username","smsCode"]
}

如上示例配置,表示启用:账号密码登录、验证码登录。

同理配置为:

export default {
	"loginTypes": ["weixin","username","smsCode"]
}

则表示启用:微信登录、验证码登录、账号密码登录。

平台差异性配置:如果你希望在不同的平台有不同的登录方式,直接使用条件编译即可。如下配置,即表示仅在APP端启用短信验证码登录

export default {
	"loginTypes": [
		"username","univerify","weixin","apple"
		// #ifdef APP-PLUS
		,"smsCode"
		// #endif
	]
}

注意: iOS 的 AppStore 规则:应用若支持三方社交登录服务(如:一键登录、微信登录等),则必须同时向用户提供“以苹果账号登录”的选项。即:如果你的应用不支持三方登录,那么可以不带上苹果登录,如果你的应用支持三方登录,那必须同时把苹果登录也带上。

以上配置仅开启前端登录入口,实现功能还需:

  1. 开通对应登录方式服务,获得服务密钥,并在服务端uni-id模块的配置文件中完成配置。详情查看:登录服务开通与配置
  2. 如果是APP端,一键登录微信登录苹果登录,需要在manifest.json中勾选对应模块(微信登录必须配置:微信开发平台申请应用appID的值),并完成打包后才可用(自定义调试基座包和正式包均可)。

# 隐私政策

字段 类型 描述
serviceUrl String 用户服务协议网络链接
privacyUrl String 隐私政策网络链接
scope Object 作用于哪些场景

scope 说明:

字段 类型 描述
register String 注册(包括注册并登录,如:微信登录、苹果登录、短信验证码登录)
login String 登录(如:用户名密码登录)
realNameVerify String 实名认证

一款规范的小程序或App要上架到国内应用商店必须提供《隐私政策和用户使用协议》,参考模版:隐私权政策模板.zip

更多合规问题详情参考

推荐使用:HBuilderX编辑器,以markdown文档格式编辑《隐私政策和用户使用协议》,通过在文档中鼠标右键一键分享上传到前端网页托管获得链接

# 接入各类服务(如微信登录服务)的应用id

字段 类型 描述
weixin Object 微信
 |- h5 String 微信公众号的appid
来源:微信公众号-> 设置与开发 -> 基本配置 -> 公众号开发信息 -> AppID
 |- web String 微信开放平台的appid
来源:微信开放平台 -> 管理中心 -> 网站应用 -> 选择对应的应用名称,点击查看 -> AppID

# 密码强度

字段 类型 描述
为空或false - 不验证密码强度
super String 超强:密码必须包含大小写字母、数字和特殊符号,长度范围:8-16位之间
strong String 强: 密密码必须包含字母、数字和特殊符号,长度范围:8-16位之间
medium String 中:密码必须为字母、数字和特殊符号任意两种的组合,长度范围:8-16位之间
weak String 弱:密码必须包含字母和数字,长度范围:6-16位之间

# 登录后设置密码

用户如果没有设置密码,在登录后会跳转设置密码页面

此功能默认不开启, 开启请将 setPasswordAfterLogin 设置为 true,如下:

{
	setPasswordAfterLogin: true,
	// setPasswordAfterLogin: {
	// 	allowSkip: false
	// }
}

如果不需要强制设置密码可以将 allowSkip 设置为 true 用户可以选择跳过设置密码。

# 页面介绍

uni-id-pages包含:账号注册、免密登录、头像更换、修改昵称、绑定手机号码、找回密码、注销账号等页面。插件地址

项目中常有打开登录页面的需求,这里对登录页面展开介绍;包括两类登录方式:

  • 密码登录(账号密码登录),页面路径: /uni_modules/uni-id-pages/pages/login/login-withpwd
  • 免密登录(一键登录,短信验证码登录,微信登录,苹果登录),页面路径: /uni_modules/uni-id-pages/pages/login/login-withoutpwd

执行uni.navigateTo打开登录页面,会默认使用配置中loginTypes值的第一项为登录方式。

例如loginTypes["weixin","apple","univerify"]会以weixin,即微信登录为默认登录方式

uni-id-pages支持通过传递参数type,指定登录方式。例如:指定苹果登录,使用如下代码即可

uni.navigateTo({
	"url":"/uni_modules/uni-id-pages/pages/login/login-withoutpwd?type=apple"
})

可以配套使用uniIdRouter;当用户未登录,但访问了需强制登录的页面,或接口提示token无效或过期(响应体以TOKEN_INVALID开头)时均需要打开登录页面。你需要把以上两个路径路径定义为loginPage

# 钩子

为了便于集成uni-id-pages的项目监听到登录和注销登录事件,提供了两个全局事件:uni-id-pages-login-successuni-id-pages-logout。开发者可以通过uni.$on来监听这些事件。