1.3.9 • Published 14 days ago

@yidun/quickpass-plugin-rn v1.3.9

Weekly downloads
-
License
Apache 2.0
Repository
-
Last release
14 days ago

号码认证

直连三大运营商,一步校验手机号与当前SIM卡号一致性。优化注册/登录/支付等场景验证流程

平台支持(兼容性)

AndroidiOS
适用版本区间:4.4以上适用版本区间:9 以上

环境准备

CocoaPods安装教程

资源引入/集成

npm install @yidun/quickpass-plugin-rn

项目开发配置

旧版本需要在 react-native 工程对应的 android/app/build.gradle 文件的 android 域中添加

repositories {
    flatDir {
        dirs project(':yidun_quickpass-plugin-rn').file('libs')
    }
}

release 包需要添加混淆规则

-dontwarn com.cmic.sso.sdk.**
-keep class com.cmic.sso.**{*;}
-dontwarn com.sdk.**
-keep class com.sdk.** { *;}
-keep class cn.com.chinatelecom.account.**{*;}
-keep public class * extends android.view.View
-keep class com.netease.nis.quicklogin.entity.**{*;}
-keep class com.netease.nis.quicklogin.listener.**{*;}
-keep class com.netease.nis.quicklogin.QuickLogin{
    public <methods>;
    public <fields>;
}
-keep class com.netease.nis.quicklogin.helper.UnifyUiConfig{*;}
-keep class com.netease.nis.quicklogin.helper.UnifyUiConfig$Builder{
     public <methods>;
     public <fields>;
 }
-keep class com.netease.nis.quicklogin.utils.LoginUiHelper$CustomViewListener{
     public <methods>;
     public <fields>;
}
-keep class com.netease.nis.basesdk.**{
    public *;
    protected *;
}

调用示例

export default class App extends Component {
  componentDidMount() {
    NativeModules.QuickLoginPlugin.initQuickLogin('此处填写您申请的业务id');
  }

  handlePressLogin() {
    NativeModules.QuickLoginPlugin.prefetchNumber((success, resultDic) => {
      if (!success) return;
      
      const token = resultDic.token

      let uiJsonConfig;
      if (Platform.OS==='android') {
        uiJsonConfig = androidConfigJson;
        NativeModules.QuickLoginPlugin.setUiConfig(uiJsonConfig);
        NativeModules.QuickLoginPlugin.login((success, resultDic)=>{
            if (!success) return
            NativeModules.QuickLoginPlugin.closeAuthController();

            fetch('您的后端认证接口', {
                method: 'POST',
                body: JSON.stringify({
                    token,
                    accessToken: resultDic.accessToken
                })
            })
        })
      } else {
        uiJsonConfig = iosConfigJson;
        NativeModules.QuickLoginPlugin.setUiConfig(uiJsonConfig, (success) => {
            if (success) {
                console.log("设置UI成功")
                NativeModules.QuickLoginPlugin.login((success, resultDic)=>{
                    if (!success) return
                    NativeModules.QuickLoginPlugin.closeAuthController();

                    fetch('您的后端认证接口', {
                        method: 'POST', 
                        body: JSON.stringify({
                            token,
                            accessToken: resultDic.accessToken
                        })
                    })
                });
            } 
        });
      }
    })
  }

  render() {
    return (
      <View>
        <TouchableOpacity onPress={this.handlePressLogin}>
          <View>
            <Text>登录</Text>
          </View>
        </TouchableOpacity>
      </View>
    )
  }
}

更多使用场景请参考 demo

SDK方法说明

1. 创建对象

代码说明:

import {NativeModules} from 'react-native';
var quichLoginPlugin = NativeModules.QuickLoginPlugin;

2. 初始化

代码说明:

quichLoginPlugin.initQuickLogin('此处填写您申请的业务id');

参数说明:

  • 入参说明:

    参数类型是否必填默认值描述
    businessIdString易盾分配的业务id

3. 预取号

代码说明:

quichLoginPlugin.prefetchNumber((success, data) => {
  if (success) {
    // TODO: 预取号成功处理,可以进行授权页面配置和调起授权页
  } else {
    // TODO: 预取号失败处理  
  }
})

参数说明:

  • 回调参数说明:

    回调参数类型描述
    successBoolean预取号成功
    data.tokenString如果预取号成功则返回易盾token,否则无此字段
    data.descString如果预取号失败,返回错误详情, 否则无此字段

4. 是否具备一键登录能力

代码说明:

quichLoginPlugin.checkVerifyEnable((success) => {
  if (success) {
    // TODO: 具备一键登录能力
  } else {
    // TODO: 不具备一键登录能力
  }
})

参数说明:

  • 回调参数说明:

    回调参数类型描述
    successBoolean是否具备一键登录能力

5. 自定义授权页面

代码说明:

NativeModules.QuickLoginPlugin.setUiConfig(config, (success) => {
    if (success) {  
        // TODO:设置UI成功,可以进行取号接口调用
    } else {
    }
});

参数说明:

  • 基础参数:

    参数类型是否必填默认值描述
    configObject自定义配置项
    successBoolean设置授权页面UI成功

config 可配置项说明: android版

开发者不得通过任何技术手段,将授权页面的隐私栏、手机掩码号、供应商品牌内容隐藏、覆盖 网易易盾与运营商会对应用授权页面进行审查,若发现上述违规行为,网易易盾有权将您的一键登录功能下线

安卓规范示意图 自定义展示图

状态栏
配置项说明
statusBarColor:String设置状态栏背景颜色,十六进制RGB值,如 "#ff0000"
isStatusBarDarkColor:boolean设置状态栏字体图标颜色是否为暗色(黑色)
导航栏
配置项说明
navBackIcon:String导航栏图标,图标放在 android drawable 下,这里配置图标名字
navBackIconWidth:int设置导航栏返回图标的宽度,单位 dp
navBackIconHeight:int设置导航栏返回图标的高度,单位 dp
navBackIconGravity:int设置导航栏返回图标位置,居左 3,居右 5,默认居左
navBackIconMargin:int设置导航栏返回距离左边的距离,单位 dp
isHideBackIcon:boolean设置是否隐藏导航栏返回按钮
navBackgroundColor:String设置导航栏背景颜色,十六进制RGB值,如 "#ff0000"
navHeight:int设置导航栏高度,单位 dp
navTitle:String设置导航栏标题
navTitleColor:String设置导航栏标题颜色,十六进制RGB值,如 "#ff0000"值
navTitleSize:int设置导航栏标题大小,单位 sp
navTitleDpSize:int设置导航栏标题大小,单位 dp
isNavTitleBold:boolean设置导航栏标题是否为粗体
isHideNav:boolean设置是否隐藏导航栏
应用 Logo
配置项说明
logoIconName:String应用 logo 图标,图标放在 android drawable 下,这里配置图标名字
logoWidth:int设置应用logo宽度,单位dp
logoHeight:int设置应用 logo 高度,单位 dp
logoTopYOffset:int设置 logo 顶部 Y 轴偏移,单位 dp
logoBottomYOffset:int设置 logo 距离屏幕底部偏移,单位 dp
logoXOffset:int设置 logo 水平方向的偏移,单位 dp
isHideLogo:boolean设置是否隐藏 logo
手机掩码
配置项说明
maskNumberColor:String设置手机掩码颜色,十六进制RGB值,如 "#ff0000"
maskNumberSize:int设置手机掩码字体大小,单位 px
maskNumberXOffset:int设置手机掩码水平方向的偏移,单位 dp
maskNumberDpSize:int设置手机掩码字体大小,单位 dp
maskNumberTopYOffset:int设置手机掩码顶部Y轴偏移,单位 dp
maskNumberBottomYOffset:int设置手机掩码距离屏幕底部偏移,单位 dp
isMaskNumberBold:boolean设置手机掩码是否粗体
认证品牌
配置项说明
sloganSize:int设置认证品牌字体大小,单位 px
sloganDpSize:int设置认证品牌字体大小,单位 dp
sloganColor:String设置认证品牌颜色,十六进制RGB值,如 "#ff0000"
sloganTopYOffset:int设置认证品牌顶部 Y 轴偏移,单位 dp
sloganBottomYOffset:int设置认证品牌距离屏幕底部偏移,单位 dp
sloganXOffset:int设置认证品牌水平方向的偏移,单位 dp
isSloganBold:boolean设置认证品牌是否粗体
登录按钮
配置项说明
loginBtnText:String设置登录按钮文本
loginBtnTextSize:int设置登录按钮文本字体大小,单位 px
loginBtnTextDpSize:int设置登录按钮文本字体大小,单位 dp
loginBtnTextColor:String设置登录按钮文本颜色,十六进制RGB值,如 "#ff0000"
loginBtnWidth:int设置登录按钮宽度,单位 dp
loginBtnHeight:int设置登录按钮高度,单位 dp
loginBtnMarginLeft:int设置登录按钮左边距,单位 dp
loginBtnMarginRight:int设置登录按钮右边距,单位 dp
loginBtnBackgroundRes:String设置登录按钮背景图标,图标放在 android drawable 下,这里配置图标名字
loginBtnTopYOffset:int设置登录按钮顶部Y轴偏移,单位 dp
loginBtnBottomYOffset:int设置登录按钮距离屏幕底部偏移,单位 dp
loginBtnXOffset:int设置登录按钮水平方向的偏移,单位 dp
isLoginBtnBold:boolean设置登录按钮文本是否粗体
隐私协议
配置项说明
privacyTextColor:String设置隐私栏文本颜色,不包括协议 ,如若隐私栏协议文案为:登录即同意《中国移动认证条款》且授权 QuickLogin 登录, 则该API对除协议‘《中国移动认证条款》’区域外的其余文本生效
privacyDialogTextColor:String设置协议未勾选弹窗隐私栏文本颜色,不包括协议
privacyProtocolColor:String设置隐私栏协议颜色 。例如:登录即同意《中国移动认证条款》且授权 QuickLogin 登录 , 则该 API 仅对‘《中国移动认证条款》’文案生效
privacyDialogProtocolColor:String设置协议未勾选弹窗隐私栏协议颜色
privacySize:int设置隐私栏区域字体大小,单位 px
privacyDpSize:int设置隐私栏区域字体大小,单位 dp
privacyTopYOffset:int设置隐私栏顶部Y轴偏移,单位 dp
privacyBottomYOffset:int设置隐私栏距离屏幕底部偏移,单位 dp
privacyWidth:int设置隐私栏区域宽度,单位 dp
privacyTextMarginLeft:int设置隐私栏复选框和文字内边距,单位 dp
privacyMarginLeft:int设置隐私栏水平方向的偏移,单位 dp
privacyMarginRight:int设置隐私栏右侧边距,单位 dp
privacyState:boolean设置隐私栏协议复选框勾选状态,true 勾选,false 不勾选
isHidePrivacyCheckBox:boolean设置是否隐藏隐私栏勾选框
isPrivacyTextGravityCenter:boolean设置隐私栏文案换行后是否居中对齐,如果为true则居中对齐,否则左对齐
checkBoxGravity:int设置隐私栏勾选框与文本协议对齐方式,可选择顶部(48),居中(17),底部(80)等
checkBoxWith:int设置隐私栏复选框宽度,单位 dp
checkBoxHeight:int设置隐私栏复选框高度,单位 dp
checkedImageName:string设置隐私栏复选框选中时的图片资源,图标放在 android drawable 下,这里配置图标名字
unCheckedImageName:String设置隐私栏复选框未选中时的图片资源,图标放在 android drawable 下,这里配置图标名字
privacyTextStart:String设置隐私栏声明部分起始文案 。如:隐私栏声明为"登录即同意《隐私政策》和《中国移动认证条款》且授权易盾授予本机号码",则可传入"登录即同意"
privacyTextStartSize:int隐私栏起始文案字体大小
privacyLineSpacingAdd:int隐私栏文本间距
privacyLineSpacingMul:int隐私栏文本间距倍数
protocolConnect:String设置隐私栏运营商协议和自定义协议的连接符
userProtocolConnect:String设置隐私栏自定义协议之间的连接符
operatorPrivacyAtLast:boolean运营商协议是否在末尾
isHidePrivacySmh:boolean是否隐藏运营商协议书名号
protocolText:String设置隐私栏协议文本
protocolLink:String设置隐私栏协议链接
protocol2Text:String设置隐私栏协议 2 文本
protocol2Link:String设置隐私栏协议 2 链接
protocol3Text:String设置隐私栏协议 3 文本
protocol3Link:String设置隐私栏协议 3 链接
privacyTextEnd:String设置隐私栏声明部分尾部文案。如:隐私栏声明为"登录即同意《隐私政策》和《中国移动认证条款》且授权易盾授予本机号码",则可传入"且授权易盾授予本机号码"
privacyDialogWidth:int协议未勾选弹窗宽度
privacyDialogHeight:int协议未勾选弹窗高度
privacyDialogBg:String协议未勾选弹窗背景,支持Shape
privacyDialogTitle:String协议未勾选弹窗标题
privacyDialogTitleSize:int协议未勾选弹窗标题字体大小
privacyDialogTitleColor:String协议未勾选弹窗标题字体颜色
isPrivacyDialogTitleBold:boolean协议未勾选弹窗标题是否加粗
privacyDialogTitleMarginTop:int协议未勾选弹窗标题距离顶部边距
privacyDialogContentStart:String协议未勾选弹窗内容Content开始文本
privacyDialogContentEnd:String协议未勾选弹窗内容Content结束文本
privacyDialogContentMarginLeft:int协议未勾选弹窗内容Content距离左边边距
privacyDialogContentMarginRight:int协议未勾选弹窗内容Content距离右边边距
privacyDialogContentMarginTop:int协议未勾选弹窗内容Content距离顶部边距
isPrivacyDialogContentBold:boolean协议未勾选弹窗内容Content标题是否加粗
privacyDialogText:String协议未勾选弹窗自定义内容Content
privacyDialogSize:int协议未勾选弹窗内容文本Content字体大小
privacyDialogTextColor:String设置协议未勾选弹窗隐私栏文本颜色,不包括协议
privacyDialogProtocolColor:String设置协议未勾选弹窗隐私栏协议颜色
privacyDialogBtnWidth:int协议未勾选弹窗底部按钮宽度
privacyDialogBtnHeight:int协议未勾选弹窗底部按钮高度
privacyDialogBtnTextSize:int协议未勾选弹窗底部按钮字体大小
privacyDialogBtnAgreeTextColor:String协议未勾选弹窗底部同意按钮文本颜色
privacyDialogBtnDisagreeTextColor:String协议未勾选弹窗底部拒绝按钮文本颜色
privacyDialogBtnMarginLeft:int协议未勾选弹窗底部按钮距离左边边距
privacyDialogBtnMarginRight:int协议未勾选弹窗底部按钮距离右边边距
privacyDialogBtnMarginTop:int协议未勾选弹窗底部按钮距离顶部边距
privacyDialogBtnMarginBottom:int协议未勾选弹窗底部按钮距离底部边距
privacyDialogBtnAgreeText:String协议未勾选弹窗底部同意按钮文本
privacyDialogBtnDisagreeText:String协议未勾选弹窗底部拒绝按钮文本
privacyDialogBtnAgreeBg:String协议未勾选弹窗底部同意按钮背景
privacyDialogBtnDisagreeBg:String协议未勾选弹窗底部拒绝按钮背景
isShowPrivacyDialog:boolean是否显示协议未勾选默认弹窗
privacyToastStr:String协议未勾选点击登录按钮toast内容(配合isShowPrivacyDialog使用)
isPrivacyBold:boolean设置隐私协议文本是否粗体
协议详情 Web 页面导航栏
配置项说明
protocolNavTitle:String设置协议 Web 页面导航栏标题,如果需要根据不同运营商设置不同标题
protocolNavTitleColor:String设置协议 Web 页面导航栏标题颜色
protocolNavBackIcon:String设置协议 Web 页面导航栏返回图标,图标放在 android drawable 下,这里配置图标名字
protocolNavColor:String设置协议Web页面导航栏颜色
protocolNavHeight:int设置协议 Web 页面导航栏高度
protocolNavTitleSize:int设置协议Web页面导航栏标题大小,单位 px
protocolNavTitleDpSize:int设置协议 Web 页面导航栏标题大小,单位 dp
protocolNavBackIconWidth:int设置协议 Web 页面导航栏返回按钮宽度,单位 dp
protocolNavBackIconHeight:int设置协议 Web 页面导航栏返回按钮高度,单位 dp
protocolNavBackIconMargin:int设置协议 Web 页面导航栏返回按钮距离左边的距离,单位 dp
isProtocolNavTitleBold:boolean设置协议 Web 页面导航栏标题是否粗体
其他
配置项说明
backgroundImage:String设置登录页面背景,图片放在 android drawable 下,这里配置图片名字
backgroundGif:String设置登录页面背景为 Gif,Gif 资源需要放置到android drawable 目录下,传入资源名称即可
backgroundVideo:String设置登录页面背景为视频,视频放在android res/raw 文件夹下,这里配置视频文件名字。必须同时配置 backgroundVideo
backgroundVideoImage:String设置视频背景时的预览图,图片放在 android drawable 下,这里配置图标名字,配合 backgroundVideo 使用
enterAnimation:String设置授权页进场动画,enterAnimation 进场动画xml无后缀文件名。放置在 android anim目录下
exitAnimation:String设置授权页退出动画,exitAnimation 进场动画xml无后缀文件名。放置在 android anim目录下
isLandscape:boolean是否横屏
isDialogMode:boolean是否弹窗模式
dialogWidth:int授权页弹窗宽度,单位 dp
dialogHeight:int授权页弹窗高度,单位 dp
dialogX:int授权页弹窗 X 轴偏移量,以屏幕中心为原点
dialogY:int授权页弹窗 Y 轴偏移量,以屏幕中心为原点
isBottomDialog:boolean授权页弹窗是否贴于屏幕底部true:显示在屏幕底部,dialogY 失效 false:不显示在屏幕底部,以 dialogY 参数为准
isProtocolDialogMode:boolean协议详情页是否开启弹窗模式
isPrivacyDialogAuto:boolean协议未勾选弹窗点击是否自动登录
isShowLoading:boolean授权页loading是否显示
isBackPressedAvailable:boolean设置物理返回键是否可用
isVirtualButtonHidden:boolean是否隐藏虚拟键
自定义view
配置项说明
widgets:JsonArray自定义view数组
 ∟ viewId:String控件 id
 ∟ type:String控件类型,可选值为 TextView、Button、ImageView
 ∟ top:int控件距离顶部的偏移,单位 dp
 ∟ left:int控件距离左侧的偏移,单位 dp
 ∟ right:int控件距离右侧的偏移,单位 dp
 ∟ bottom:int控件距离底部的偏移,和top互斥,单位 dp
 ∟ width:int控件宽度,单位 dp
 ∟ height:int控件高度,单位 dp
 ∟ text:String控件文本,单位 dp
 ∟ font:int控件文本大小,单位 sp
 ∟ textColor:String控件文本颜色,十六进制颜色码
 ∟ clickable:boolean控件是否可点击,单位 sp
 ∟ backgroundColor:String控件背景颜色,十六进制颜色码
 ∟ backgroundImgPath:String控件背景图片,图片放在 android drawable 下,这里配置图片名字
 ∟ positionType:int添加控件的位置类型,0表示位于导航栏下方的body部分(默认)1表示位于导航栏

config 可配置项说明: iOS版

设计规范概览 开发者不得通过任何技术手段,将授权页面的隐私栏、手机掩码号、供应商品牌内容隐藏、覆盖 网易易盾与运营商会对应用授权页面进行审查,若发现上述违规行为,网易易盾有权将您的一键登录功能下线 iOS设计规范 自定义展示图

基础配置
属性说明
backgroundColor设置授权页面背景颜色
authWindowPop设置窗口类型0 表示全屏模式 1 表示窗口在屏幕的中间 2 表示窗口在屏幕的底部(不支持横屏)
faceOrientation设置授权页面方向 0 表示设置保持直立1 表示左横屏 2 表示右横屏 3 表示左右横屏 4 屏幕全旋转
bgImage设置授权转背景图片,例如 :"图片名"
contentMode设置背景图片显示模式 0 表示 UIViewContentModeScaleToFill,1表示UIViewContentModeScaleAspectFit ,2表示UIViewContentModeScaleAspectFill
转场动画
属性说明
modalTransitionStyle设置授权转场动画 0 表示下推1 表示翻转2 表示淡出
自定义控件

事例,注意:授权页面的图片需放到iOS项目 Assets.xcassets 中

"widgets": [
        {
            "type": "UIButton",
            "image": "weixin",
            "title": "",    
            "titleColor": "#000000",
            "titleFont": 12,
            "cornerRadius": 20,
            "action": "handleCustomEvent1",
            "frame": {"mainScreenLeftDistance":70,"mainScreenTopDistance":340,"width":40,"height":40},
            "backgroundImage":""
        },
        {
            "type": "UIButton",
            "image": "qq",
            "title": "",    
            "titleColor": "#FFFFFF",
            "titleFont": 12,
            "cornerRadius": 20,
            "action": "handleCustomEvent2",
            "frame": {"mainScreenCenterXWithLeftDistance":0,"mainScreenTopDistance":340,"width":40,"height":40},
            "backgroundImage": ""
        },
        {
            "type": "UIButton",
            "image": "weibo",
            "title": "",    
            "titleColor": "#FFFFFF",
            "titleFont": 12,
            "cornerRadius": 20,
            "action": "handleCustomEvent3",
            "frame": {"mainScreenRightDistance":70,"mainScreenTopDistance":340,"width":40,"height":40},
            "backgroundImage": ""
        },
        {
            "type": "UIButton",
            "image": "",
            "title": "其他登录方式",
            "titleColor": "#000000",
            "titleFont": 14,
            "cornerRadius": 20,
            "action": "handleCustomLabel",
            "backgroundImage": "login_btn_normal",
            "backgroundColor": "#000000",
            "frame": {"mainScreenLeftDistance":80,"mainScreenRightDistance":80,"mainScreenTopDistance":280,"height":40}
        },
        {
            "type": "UILabel",
            "textColor": "#FFFFFF",
            "font": 15,
            "cornerRadius": 20,
            "action": "handleCustomLabel1",
            "text": "其他登录方式",
            "textAlignment": 1,
            "backgroundColor": "#000000",
            "frame": {"mainScreenLeftDistance":80,"mainScreenRightDistance":80,"mainScreenBottomDistance":400,"height":40}
        }
    ]
配置项说明
widgets:JsonArray自定义view数组
 ∟ type:String控件类型,可选值为 UILabel、UIButton
 ∟ image:StringUIButton显示的图片。内容为图片名,不需要加图片后缀
 ∟ title:StringUIButton显示的文字
 ∟ titleColor:StringUIButton显示的字体颜色
 ∟ titleFont:int字体的大小
 ∟ cornerRadius:int控件的圆角
 ∟ backgroundImage:StringUIButton的背景图片
 ∟ backgroundColor:String控件背景颜色
 ∟ mainScreenLeftDistance:int距离屏幕左边的距离,默认为0
 ∟ mainScreenRightDistance:int距离屏幕右边的距离,默认为0
 ∟ mainScreenTopDistance:int距离屏幕顶部的距离,默认为0
 ∟ mainScreenCenterXWithLeftDistance:int为0时,居中显示。大于0,向屏幕左侧偏移。小于0,向右侧偏移
 ∟ width:int控件的宽度,默认为0
 ∟ height:int控件的高度,默认为0
 ∟ textAlignment:int0,文本左对齐。1,文本居中显示。2文本右对齐
 ∟ text:StringUILabel显示的文字
 ∟ textColor:StringUILabel的字体颜色
 ∟ action:String设置可点击控件的点击事件,在监听中回调。详见事件监听
背景设置视频
属性说明
isRepeatPlay设置是否重复播放视频,YES 表示重复播放,NO 表示不重复播放
videoURL设置网络视频的地址
背景设置 Gif
属性说明
animationRepeatCount设置动画重复的次数 -1无限重复
animationImages设置图片数组
animationDuration设置动画的时长
状态栏
属性说明
statusBarStyle设置状态栏样式 iOS13之前 0表示文字黑色,1表示文字白色 iOS13之后 0表示自动选择黑色或白色,3 表示文字黑色,2 表示文字白色
导航栏
属性说明
navBarHidden导航栏是否隐藏
navBgColor设置导航栏背景颜色
navText设置导航栏标题
navTextFont设置导航栏标题字体大小
navTextColor设置导航栏标题字体颜色
navTextHidden设置导航栏标题是否隐藏,默认不隐藏
navReturnImg设置导航返回图标,例如:"back-1"
navReturnImgLeftMargin设置导航返回图标距离屏幕左边的距离,默认0
navReturnImgBottomMargin设置导航返回图标距离屏幕底部的距离,默认0
navReturnImgWidth设置导航返回图标的宽度,默认44
navReturnImgHeight设置导航返回图标的高度 , 默认44
应用 Logo
属性说明
logoIconName设置logo图片, 例如 :"图片名"]
logoWidth设置logo图片宽度
logoHeight设置logo图片高度
logoOffsetTopY设置logo图片沿Y轴偏移量, logoOffsetTopY为距离屏幕顶部的距离 ,默认为20
logoOffsetX设置logo图片沿X轴偏移量,logoOffsetX = 0居中显示
logoHidden设置logo图片是否隐藏,默认不隐藏
手机掩码
属性说明
numberColor设置手机号码字体颜色
numberFont设置手机号码字体大小, 默认18
numberOffsetTopY设置手机号码沿Y轴偏移量, numberOffsetTopY为距离屏幕顶部的距离 ,默认为100
numberOffsetX设置logo图片沿X轴偏移量,logoOffsetX = 0居中显示
numberHeight设置手机号码框的高度 默认27
numberBackgroundColor设置手机号码的背景颜色
numberCornerRadius设置手机号码的控件的圆角
numberLeftContent设置手机号码的左边描述内容,默认为空
numberRightContent设置手机号码的右边描述内容,默认为空色
认证品牌
属性说明
brandColor设置认证服务品牌文字颜色
brandBackgroundColor设置认证服务品牌背景颜色
brandFont设置认证服务品牌文字字体 默认12
brandWidth设置认证服务品牌的宽度, 默认200
brandHeight设置认证服务品牌的高度, 默认16
brandOffsetX设置认证服务品牌X偏移量 ,brandOffsetX = 0居中显示
brandOffsetTopY设置认证服务品牌Y偏移量, brandOffsetTopY为距离屏幕顶部的距离 ,默认为150
brandHidden设置是否隐藏认证服务品牌,默认显示
登录按钮
属性说明
logBtnText设置登录按钮文本
logBtnTextFont设置登录按钮字体大小
logBtnTextColor设置登录按钮文本颜色
logBtnOffsetTopY设置登录按钮Y偏移量 ,logBtnOffsetTopY为距离屏幕顶部的距离 ,默认为200
logBtnRadius设置登录按钮圆角,默认8
logBtnUsableBGColor设置登录按钮背景颜色
logBtnEnableImg设置登录按钮可用状态下的背景图片
logBtnHighlightedImg登录按钮高亮状态下的背景图片
logBtnOriginLeft登录按钮的左边距 ,横屏默认40 ,竖屏默认260
logBtnOriginRight设置登录按钮的左边距,横屏默认40 ,竖屏默认260
logBtnHeight设置登录按钮的高度,默认44
隐私协议

若勾选框需要展示,请务必设置勾选框的选中态图片与未选中态图片 协议未勾选时,登录按钮是否可点击可以自定义设置,弹窗提示的样式也可以自定义

属性说明
unCheckedImageName例如:/图片名
checkedImageName例如:/图片名
checkboxWH设置复选框大小(只能正方形) ,默认 12
privacyState设置复选框默认状态 默认:NO
checkBoxAlignment设置隐私条款check框位置 0 表示相对协议顶对齐 1 表示相对协议中对齐 2 表示相对协议下对齐 默认顶对齐
checkedSelected设置复选框勾选状态,YES:勾选,NO:取消勾选状态
checkBoxMargin设置复选框距离隐私条款的边距 默认 8
appPrivacyOriginLeftMargin设置隐私条款距离屏幕左边的距离 默认 60
appPrivacyOriginRightMargin设置隐私条款距离屏幕右边的距离 默认 40
appPrivacyOriginBottomMargin设置隐私条款距离屏幕的距离 默认 40
privacyNavReturnImg设置用户协议界面,导航栏返回图标,默认用导航栏返回图标
appPrivacyText设置隐私的内容模板:全句可自定义但必须保留"《默认》"字段表明SDK默认协议,否则设置不生效。必设置项(参考SDK的demo)appPrivacyText设置内容:登录并同意《默认》和易盾协议1、网易协议2登录并支持一键登录,展示:登录并同意中国移动条款协议和易盾协议1、网易协议2登录并支持一键登录
appFPrivacyText设置开发者隐私条款协议名称(第一个协议)
appFPrivacyURL设置开发者隐私条款协议url(第一个协议)
appSPrivacyText设置开发者隐私条款协议名称(第二个协议)
appSPrivacyURL设置开发者隐私条款协议url(第二个协议)
appTPrivacyText设置开发者隐私条款协议名称(第三个协议)
appTPrivacyURL设置开发者隐私条款协议url(第三个协议)
appFourPrivacyText设置开发者隐私条款协议名称(第四个协议)
appFourPrivacyURL设置开发者隐私条款协议url(第四个协议)
shouldHiddenPrivacyMarks设置是否隐藏"《默认》" 两边的《》,默认不隐藏
privacyColor设置隐私条款名称颜色
privacyFont设置隐私条款字体的大小
protocolColor设置协议条款协议名称颜色
appPrivacyLineSpacing设置隐私协议的行间距, 默认是1
appPrivacyWordSpacing设置隐私协议的字间距, 默认是0
progressColor设置用户协议界面,进度条颜色
弹窗模式
属性说明
popBackgroundColor设置窗口模式的背景颜色
authWindowWidth设置弹窗的宽度,竖屏状态下默认是 300,横屏状态下默认是 335
authWindowHeight设置弹窗高度,竖屏状态下默认是335, 横屏状态下默认是300 ⚠️底部半屏弹窗模式的高度可通过修改 authWindowHeight,调整高度 默认335pt
closePopImg设置弹窗模式下关闭按钮的图片,⚠️(必传)
closePopImgWidth设置弹窗模式下关闭按钮图片的宽度 默认20*
closePopImgHeight设置弹窗模式下关闭按钮图片的高度 默认20
closePopImgOriginY设置关闭按钮距离顶部的距离,默认距离顶部10,距离 = 10 + closePopImgOriginY
closePopImgOriginX设置关闭按钮距离父视图右边的距离,默认距离为10,距离 = 10 + closePopImgOriginX
authWindowCenterOriginY设置居中弹窗沿Y轴移动的距离。例如 :authWindowCenterOriginY = 10 表示中间点沿Y轴向下偏移10个像素
authWindowCenterOriginX设置居中弹窗沿X轴移动的距离。例如 :authWindowCenterOriginX = 10 表示中间点沿X轴向右偏移10个像素
popCenterCornerRadius设置居中弹窗模式下,弹窗的圆角,默认圆角为16
popBottomCornerRadius设置底部弹窗模式下,弹窗的圆角,默认圆角为16,注:只可修改顶部左右二边的值
isOpenSwipeGesture设置底部弹窗模式下,是否开启轻扫手势,向下轻扫关闭弹窗。默认关闭
isShowLoading:boolean授权页loading是否显示

6. 调起授权页面

代码说明:

quichLoginPlugin.login((success, data) => {
  if (success) {
    // TODO: 授权成功处理,可以进行关闭授权页、服务端验证等
    NativeModules.QuickLoginPlugin.closeAuthController();
  } else {
    // TODO: 授权失败处理
  }
})

参数说明:

  • 回调参数说明:

    回调参数类型描述
    successBoolean授权是否成功
    data.accessTokenString如果取号成功返回运营商授权码,否则无此字段
    data.descString如果取号失败,返回的错误详情, 否则返回"取号成功

7. 事件监听

代码说明:

const emitter = new NativeEventEmitter(NativeModules.QuickLoginPlugin)
emitter.addListener('uiCallback', (value) => {
  // TODO: 处理监听事件
})

value 是一个 Map ,里面包含各种 key 和对应的值

  • iOS value 值说明:

    回调参数类型描述
    value.actionStringauthViewDidLoad 表示正在加载授权页authViewWillAppear 表示授权页已经出现 authViewWillDisappear 表示授权页将要消失 authViewDidDisappear表示授权页已经消失authViewDealloc 表示授权页销毁 appDPrivacy 表示点击了默认协议appFPrivacy 表示点击了议第一个协议点击 appSPrivacy 表示点击了第二个协议 loginAction 表示点击了登录按钮,data.checked = true 表示在点击登录按钮时复选框选已选中反之 checkedAction 表示点击了复选框,data.checked = true 表示复选框已选中反之
  • Android value 值说明:

    回调参数类型描述
    value.viewIdString自定义 view 点击,返回自定义 view 的 id
    value.lifecycleStringonCreate - 页面创建,onStart - 页面已开始活动,onResume - 页面展示,onPause - 页面非活动状态,onStop - 页面已停止,onDestroy - 页面销毁
    value.clickViewTypeStringprivacy - 隐私协议点击事件,checkbox - 复选框点击事件(含isCheckboxChecked: 0/1),loginButton - 登录按钮点击事件(含isCheckboxChecked: 0/1),leftBackButton - 左上角返回按钮点击事件
    value.isCheckboxCheckedString协议复选框的值,仅在复选框事件和登录按钮点击事件中存在

8. 关闭授权页面

代码说明:

quichLoginPlugin.closeAuthController()

9. 本机校验

在初始化之后执行,本机校验和一键登录可共用初始化,本机校验界面需自行实现

代码说明:

quichLoginPlugin.verifyPhoneNumber(String phoneNumber,(success, data) => {
  if (success) {
    // TODO: 本机校验成功处理
  } else {
    // TODO: 本机校验失败处理
  }
})

参数说明:

  • 入参说明:

    参数类型是否必填默认值描述
    phoneNumberString待校验手机号
  • 回调参数说明:

    回调参数类型描述
    successBoolean授权是否成功
    data.accessTokenString如果本机校验返回运营商授权码,否则无此字段
    data.descString如果本机校验失败,返回的错误详情, 否则返回"本机校验成功
1.3.9

14 days ago

1.3.8

2 months ago

1.3.7

2 months ago

1.3.6

8 months ago

1.3.5

12 months ago

1.2.8

2 years ago

1.3.4

1 year ago

1.3.3

1 year ago

1.3.2

1 year ago

1.3.1

1 year ago

1.3.0

1 year ago

1.2.9

2 years ago

1.2.7

2 years ago

1.2.6

2 years ago

1.2.5

2 years ago

1.2.4

2 years ago

1.2.0

2 years ago

1.1.1

3 years ago

1.1.0

3 years ago

1.1.9

2 years ago

1.1.8

3 years ago

1.0.9

3 years ago

1.1.7

3 years ago

1.0.8

3 years ago

1.1.6

3 years ago

1.0.7

3 years ago

1.1.5

3 years ago

1.2.3

2 years ago

1.1.4

3 years ago

1.2.2

2 years ago

1.1.3

3 years ago

1.2.1

2 years ago

1.1.2

3 years ago

1.0.6

3 years ago

1.0.5

3 years ago

1.0.4

4 years ago

1.0.3

4 years ago