uniapp微信小程序授权登录实现

我们在做小程序的时候用的最多的方式登录 就是原生的授权登录的功能

这个方法 也不是很难 首先我们要获取我们在小程序中的code值

我们小封装一个获取code 的方法 在页面中可以直接调用 封装在 js 中

javascript 复制代码
export const wxlogin = () => {
  return new Promise((resolve, reject) => {
    uni.login({
      provider: 'weixin',
      success: function(loginRes) {
        resolve(loginRes.code);
      },
      fail(err) {
        reject(err)
      }
    })
  })
}

把登录的要封装在一个单独的文件中,这样修改的时候,也方便修改

javascript 复制代码
<template>
  <view class="province_box" v-if="isPopupVisible">
    <view class="container">
      <view class="popupMobile_box">
        <view class="please-mobile">请授权手机号并登录</view>
        <view class="login_mobile">登录就代表已阅读并同意 <text style="color:#0091FF;">《用户隐私协议》</text></view>
        <view class="popup-action">
          <view class="action-button" @click="onCloseAuthMobile">
            取消
          </view>
          <view>
            <button class="action-confirm" @click="onConfirmAuthMobile" open-type="getPhoneNumber"
              @getphonenumber="getPhoneNumber" hover-class="none">
              授权手机号
            </button>
          </view>
        </view>
      </view>
    </view>
  </view>
</template>

<script>
  import {
    wxlogin
  } from '@/utils/wxlogin.js'
  export default {
    data() {
      return {
        wxPhoneParams: {
          authCode: "",
          iv: "",
          encryptedData: ""
        },
        isPopupVisible: false, // 初始状态为隐藏
      }
    },
    mounted() {
      this.towxlogin()
    },
    methods: {
      onOpenAuthMobile() {
        this.isPopupVisible = true; // 打开弹窗
      },
      async onShowAuthMobile() {
        await this.towxlogin();
        this.onOpenAuthMobile()
      },
      // 获取code 值
      async towxlogin() {
        let code = await wxlogin();
        this.wxPhoneParams.authCode = code;
      },
      //取消授权
      onCloseAuthMobile() {
        this.isPopupVisible = false; // 关闭弹窗
      },
      onConfirmAuthMobile() {
        this.isPopupVisible = false; // 关闭弹窗
      },
      //微信登录
      getPhoneNumber(e) {
        if (e.detail.iv && e.detail.encryptedData) {
          this.wxPhoneParams.iv = e.detail.iv
          this.wxPhoneParams.encryptedData = e.detail.encryptedData
          this.wxMobileLogin(this.wxPhoneParams)
        }
      },
      wxMobileLogin(wxParams) {
        console.log('登陆中....')
         // 这个里面就可以调用登录的时候传入的接口
      }

    }
  }
</script>

<style scoped lang="less">
  .province_box {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 999;
  }

  .container {
    background-color: #fff;
    border-radius: 8px 8px 0 0;
    width: 100%;
    max-width: 400px;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    box-sizing: border-box;
    padding-bottom: constant(safe-area-inset-bottom);
    padding-bottom: env(safe-area-inset-bottom);
  }

  .popupMobile_box {
    background-color: #fff;
    height: 380rpx;
    border-radius: 30rpx 30rpx 0 0;
  }

  .please-mobile {
    text-align: center;
    padding: 50rpx 0 30rpx;
    font-size: 34rpx;
    color: #000;
  }

  .login_mobile {
    text-align: center;
    font-size: 32rpx;
    color: #333;
  }

  .popup-action {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 70rpx 100rpx 0;

    .action-button {
      width: 240rpx;
      height: 80rpx;
      font-size: 32rpx;
      font-weight: 600;
      color: #9f9f9f;
      line-height: 80rpx;
      border: 1rpx solid #DFDFDF;
      text-align: center;
      border-radius: 10rpx;
    }

    .action-confirm {
      background: #0091FF;
      color: #fff;
      width: 240rpx;
      height: 80rpx;
      font-size: 32rpx;
      line-height: 80rpx;
      text-align: center;
      border-radius: 10rpx;
    }

    button {
      border-radius: 0rpx;
    }

    button:after {
      border: none;

    }
  }
</style>
相关推荐
风等雨归期43 分钟前
【python】【绘制小程序】动态爱心绘制
开发语言·python·小程序
平凡シンプル1 小时前
安卓 uniapp跨端开发
android·uni-app
李宥小哥2 小时前
微信小程序07-开发进阶
微信小程序·小程序·notepad++
艾小逗3 小时前
uniapp快速入门教程,内容来源于官方文档,仅仅记录快速入门需要了解到的知识点
小程序·uni-app·app·es6
程序员阿龙3 小时前
【2025】儿童疫苗接种预约小程序(源码+文档+解答)
小程序·毕业设计·小程序开发·预约小程序·疫苗管理小程序·出勤数据分析·智能考勤
818源码资源站3 小时前
表情包创作、取图小程序端(带流量主)
小程序
2401_8459375313 小时前
PHP一键约课高效健身智能健身管理系统小程序源码
微信·微信小程序·小程序·微信公众平台·微信开放平台
程序员入门进阶15 小时前
基于微信小程序的科创微应用平台设计与实现+ssm(lw+演示+源码+运行)
微信小程序·小程序
鸭子嘎鹅子呱17 小时前
uniapp使用高德地图设置marker标记点,后续根据接口数据改变某个marker标记点,动态更新
uni-app·map·高德地图
计算机源码社1 天前
分享一个基于微信小程序的居家养老服务小程序 养老服务预约安卓app uniapp(源码、调试、LW、开题、PPT)
android·微信小程序·uni-app·毕业设计项目·毕业设计源码·计算机课程设计·计算机毕业设计开题