排行榜 统计
  • 建站日期:2020-07-15
  • 文章总数:63 篇
  • 评论总数:1454 条
  • 分类总数:6 个
  • 最后更新:2023年03月28日
Typecho小程序接入百度登录详细教程

Typecho小程序接入百度登录详细教程

本文阅读 3 分钟
首页 精品教程 正文

Typecho小程序接入百度登录详细教程

看着有几个小伙伴在问小程序支不支持百度小程序,理论上uniapp可以编译到任一端,但是由于博客小程序中有登录等功能,所以还需要做一些兼容,之前我只写了QQ与微信两端的登录,今天给大家写一下如何接入百度小程序的登录,看过之后或许大家也可以尝试做抖音、快手等小程序的登录。

先在typecho插件后台添加相关百度小程序Key和AppSecret的输入框

百度小程序Key和AppSecret的输入框

如上图所示的输入框就是需要添加的内容,这主要是为了方便用户去直接输入。想要添加该文本框,只需要在插件源码中Plugin.php中加入以下代码即可:


$bdappkey = new Typecho_Widget_Helper_Form_Element_Text('bdappkey', NULL, 'xxx', _t('百度小程序的APPKEY'),  _t('小程序的APPKEY'));
$form->addInput($bdappkey);
$bdappSecret = new Typecho_Widget_Helper_Form_Element_Text('bdappSecret', NULL, 'xxx', _t('百度小程序的APP secret ID'),  _t('小程序的APP secret'));
$form->addInput($bdappSecret);

然后在Action.php文件中导入之前的变量和编写百度小程序登录函数,导入输入框的变量只需要在该文件中的上方加入如下代码:


$this->bdappkey = Typecho_Widget::widget('Widget_Options')->plugin('Pisces')->bdappkey;
$this->bdappSecret = Typecho_Widget::widget('Widget_Options')->plugin('Pisces')->bdappSecret;

百度小程序登录的函数,如下代码:


private function BDlogin()
{
        $sec = self::GET('apisec', 'null');
        self::checkApisec($sec);

        $code = self::GET('code', 'null');
        if($code != 'null')
        {
            $nickname = self::GET('nickname', 'null');
            $avatarUrl = self::GET('avatarUrl', 'null');
            $gender = self::GET('gender', 'null');
            $province = self::GET('province', 'null');

            $url = sprintf('https://spapi.baidu.com/oauth/jscode2sessionkey?code=%s&client_id=%s&sk=%s',$code,$this->bdappkey,$this->bdappSecret);
            $info = file_get_contents($url);
            $json = json_decode($info);//对json数据解码
            $arr = get_object_vars($json);
            $openid = $arr['openid'];
            if( $openid != null && $openid != '' ) {
                $row = $this->db->fetchRow($this->db->select('openid','lastlogin')->from('table.pisces')->where('openid = ?', $openid));
                //已存在的用户,更新上次登录时间
                if(sizeof($row)>0) {
                    $this->db->query($this->db->update('table.pisces')->rows(array('lastlogin' => time()))->where('openid = ?', $openid));
                    $this->export($openid);
                }
                else {
                    //新用户
                    $this->db->query($this->db->insert('table.pisces')->rows(array('openid' => $openid, 'createtime' => time(), 'lastlogin' => time(),
                        'nickname' => $nickname, 'avatarUrl' => $avatarUrl, 'city' => $city, 'country' => $country,
                        'gender' => $gender, 'province' => $province, 'type'=>'百度','points'=>0)));
                    $this->export($openid);
                }
            } else {
                $this->export('none');
            }
        }
        else
        {
            $this->export("error code");
        }

这样插件端就算完成了,接下来做一下前端的修改。

首先因为百度小程序获取用户信息的方式仍旧是通过按钮点击获取,所以我们可以直接通过条件编译写一个符合百度小程序规则的按钮,然后绑定登录事件,不过为了方便用户网络请求我们先在小程序封装的api.js(在uniapp源码的文件utils文件夹中)中封装以下百度小程序的登录Url。代码如下:


BDLogin: function(userInfo) {
    return this.appendAPISEC(API_URL + 'BDlogin?code=' + userInfo.code + '&nickname=' + userInfo.nickName + '&avatarUrl=' +
      userInfo.avatarUrl + '&city=' + userInfo.city + '&country=' + userInfo.country + '&gender=' + userInfo.gender +
      '&province=' + userInfo.province);
  },

然后是mine.vue文件中的代码,通过条件编译写出按钮:


<!-- #ifndef MP-BAIDU -->
      <button @click="getuserinfo">点击登录</button>
<!-- #endif -->
<!-- #ifdef MP-BAIDU -->
       <button  open-type="getUserInfo" @getuserinfo="getBaiduUserInfo">
              点击登录
      </button>
<!-- #endif -->

ifndef里面的是之前的小程序用到的按钮,下面的是百度小程序所需要用到的按钮,既然重新定义事件了,那也不用兼容了,直接重新在写一个百度小程序的登录事件,代码如下:


getBaiduUserInfo:function(e){
      uni.showLoading({
        title:"登录中"
      })
      let userInfo = e.detail.userInfo;
      this.userInfo = userInfo;
      uni.login({
        success: res => {
          console.log(res);
          userInfo.code = res.code;
          console.log(userInfo)
          uni.request({
            url:API.BDLogin(userInfo),
            success: (res) => {
              console.log(res)
              uni.hideLoading();
              this.userInfo.openid = res.data.data;
              uni.setStorageSync('isLogin', true);
              this.isLogin = true;
              uni.setStorageSync('userInfo', this.userInfo);
              uni.setStorageSync('openid', this.userInfo.openid);
            }

          })
        }
      });
    },

以上就是完成的接入过程了,按照步骤来的话还是比较简单的。

本文来自投稿,不代表本站立场,如若转载,请注明出处:http://www.i4qq.com/jpjc/typechoxcxjrbdxxjc.html
Typecho小程序1.2版本适配方案
« 上一篇 04-23
Node.js关于微信支付V3版相关处理方法
下一篇 » 07-12

发表评论

成为第一个评论的人

作者信息

热门文章

标签TAG

热评文章