IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> 微信小程序--授权登录 -> 正文阅读

[移动开发]微信小程序--授权登录

1.wxml

通过按钮触发绑定事件,来授权登录。

<!-- 如果只是展示用户头像昵称,可以使用 <open-data /> 组件 -->
<open-data type="userAvatarUrl"></open-data>
<open-data type="userNickName"></open-data>
<!-- 需要使用 button 来授权登录 -->
<button type="primary" open-type="getUserInfo" bindtap="login">授权登录</button>

?

2.js

? ? ? ?在后端js页面里面写入。

 data: {
    canIUse: wx.canIUse('button.open-type.getUserInfo')
  },

  login() {
    undefined
    wx.getUserProfile({
      undefined,
      desc: '用于完善会员资料',
      success: (res) => {
        undefined
        wx.login({
          undefined,
          success(res) {
            undefined
            // 判断是否有code
            console.log(res.code)
            if (res.code) {
              undefined
              //发起网络请求
              wx.request({
                undefined,
                url: 'http://www.xiao.com/index.php/Wlogin',//填写自己的地址
                method: "POST",
                data: {
                  undefined,
                  code: res.code
                },
                success(res) {
                  undefined
                  console.log(res.data.data)
                  // 缓存session_key
                  wx.setStorage({
                    undefined,
                    key: "openid",
                    data: res.data.data.openid
                  })
                  // 跳转到成功页面
                  wx.navigateTo({
                    undefined,
                    url:"/pages/me/me"//跳转页面地址
                  })
                }
              })
            } else {
              undefined
              console.log('登录失败!' + res.errMsg)
            }
          }
        })
      }
    })
  },

3.后端框架

//微信授权登录
    public function WxLogin(Request $request)
    {
        //   接收code
        $code = $request->post("code");
        //   读取appid
        $appId = "wxa2469ff6402360ff";
        //  读取开发密钥
        $appSecret = "47732169fb165797f0303f1f781de142";
        //向平台换取session_key和open_id
        $url = "https://api.weixin.qq.com/sns/jscode2session?appid={$appId}&secret={$appSecret}&js_code={$code}&grant_type=authorization_code";
        //    用curl对接
        $headerArray = array("Content-type:application/json;", "Accept:application/json");
        $ch = curl_init();
        curl_setopt($ch, CURLOPT_URL, $url);
        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
        curl_setopt($ch, CURLOPT_HTTPHEADER, $headerArray);
        $output = curl_exec($ch);
        curl_close($ch);
        $output = json_decode($output, true);
        return json(['data' => $output]);
    }

效果图:

?

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2022-03-06 13:12:56  更:2022-03-06 13:13:58 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 16:43:43-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码