Laravel 微信小程序获取『用户详细信息』及『带参数小程序码』扩展

功能介绍

本扩展包包含用户详细信息解密、带参数小程序码生成并保存在本地目录功能。
用户详细信息解密官方也提供多种语言版本SDK(C++、PHP、Node、Python),在本扩展包中仅仅做封装处理。
带参数小程序码生成,官方给出三种接口,在此扩展包中采用 接口B (适用于需要的码数量极多的业务场景,通过该接口生成的小程序码,永久有效,数量暂无限制)。

项目地址

https://github.com/icharle/Wxtool

使用方法

运行以下命令以获取最新版本:

composer require icharle/wxtool 1.0

将服务提供者添加到配置文件中的providers数组中config/app.php,如下所示:

'providers' => [

    ...

    Icharle\Wxtool\WxtoolServiceProvider::class,
]

发布配置文件

php artisan vendor:publish --tag=wxtool

此时有一个config/wxtool.php文件。

配置AppID及AppSecret

在根目录.env文件中添加如下代码

WX_APPID = 您的小程序小程序ID
WX_SECRET = 您的小程序密钥

公开storage访问文件(可选)

若要使用 带参数小程序码生成 功能时必须执行下面命令。生成的小程序码默认保存在storage/app/public/qrcode文件夹中

php artisan storage:link

快速入门

  • 获取带参数小程序码(示例代码)

    <?php
    
    namespace App\Http\Controllers;
    
    use Icharle\Wxtool\Wxtool;
    use Illuminate\Http\Request;
    
    class TestController extends Controller
    {    
    
        /**
         * 获取带参数小程序码
         * @param $scene 场景值(最大32个可见字符,只支持数字,大小写英文以及部分特殊字符)
         * @param $pages 页面(必须是已经发布的小程序存在的页面(否则报错)
         * @return $imgpath 小程序码路径 (可以直接访问 http://xxx.com/$imgpath)
         */
        public function GetImgCode($scene,$pages)
        {
            $a = new Wxtool();
            $imgpath = $a->GetQrcode($scene,$pages); 
        }
    }
  • 获取用户详细信息(示例代码)

    <?php
    
    namespace App\Http\Controllers;
    
    use Icharle\Wxtool\Wxtool;
    use Illuminate\Http\Request;
    
    class TestController extends Controller
    {    
    
        /**
         * 获取用户详细信息
         * @param Request $request
         */
        public function GetInfo(Request $request)
        {
            $a = new Wxtool();
            $code = $request->code;                                     //wx.login获取
            $encryptedData = $request->encryptedData;                   //wx.getUserInfo 获取
            $iv = $request->iv;                                         //wx.getUserInfo 获取
            $res = $a->GetSessionKey($code);                            //获取用户openid 和 session_key
            $userinfo = $a->GetUserInfo($encryptedData,$iv);            //获取用户详细信息
        }
    }

    解密返回结果

    {
        "openId": "OPENID",
        "nickName": "NICKNAME",
        "gender": GENDER,
        "city": "CITY",
        "province": "PROVINCE",
        "country": "COUNTRY",
        "avatarUrl": "AVATARURL",
        "unionId": "UNIONID",
        "watermark":
        {
            "appid":"APPID",
            "timestamp":TIMESTAMP
        }
    }
本作品采用《CC 协议》,转载必须注明作者和本文链接
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
讨论数量: 3
ThinkQ

很简略额

5年前 评论

@ThinkCsly 你是说示例用法写的不够详细?

5年前 评论
ThinkQ

@Icharle 步骤简单就完成功能。

5年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!