PHP调微信小程序接口:生成永久有效,数量暂无限制的小程序码_php 小程序获取无限制的二维码-程序员宅基地

技术标签: # 微信小程序 - 服务端  微信小程序  # PHP  php  小程序  

520 的 日子里当然是写博客啦啦啦 - - -

520 得 日子里当然是写博客哈哈哈!!!

520 地 日子里当然是写博客呜呜呜 ~ ~ ~

一、官方文档地址

  • 【获取 AccessToken】导航:微信官方文档 --> 服务端 --> 接口调用凭证 --> getAccessToken
  • 【生成永久有效,数量暂无限制的小程序码】微信官方文档 -> 小程序 -> 服务端 -> 小程序码 -> getUnlimited

二、我把这两篇合二为一了

如果遇到了小程序的相关问题,可以看我这个分类下的博客:微信小程序

三、废话不多说,直接上代码

    public function test() {
    
        $scene = 'uid=1;pid=2'; //小程序码带的参数
//        $page = 'pages/index/index';
        $page = ''; //扫码跳转的页面,默认跳首页
        $url = self::getQrCode($scene, $page);

        echo "小程序码地址是: {
      $url}";
        <<<EOF
【存本项目时返回】小程序码地址是: public/uploads/20220520/6286f97212345.jpg
【存云储存时返回】小程序码地址是: https://resource.******.com/20220520/6286f97212345.jpg
EOF;
    }

    /**
     * 获取小程序码
     * @param string $scene 二维码地址带的参数:最大32个可见字符,只支持数字,大小写英文以及部分特殊字符:!#$&'()*+,/:;=?@-._~,其它字符请自行编码为合法字符(因不支持%,中文无法使用 urlencode 处理,请使用其他编码方式)
     * @param string $page 扫码需要跳转的页面://必须是已经发布的小程序存在的页面(否则报错),例如 pages/index/index, 根路径前不要填加 /,不能携带参数(参数请放在scene字段里),如果不填写这个字段,默认跳主页面
     * @param int $width 二维码的宽度,单位 px,最小 280px,最大 1280px
     * @return bool|string
     */
    public function getQrCode($scene, $page = '', $width = 200) {
    
        $accessToken = self::getAccessToken();
        $url = "https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token={
      $accessToken}";
        $data = [
            'scene' => $scene, //最大32个可见字符,只支持数字,大小写英文以及部分特殊字符:!#$&'()*+,/:;=?@-._~,其它字符请自行编码为合法字符(因不支持%,中文无法使用 urlencode 处理,请使用其他编码方式)
            'page' => $page, //必须是已经发布的小程序存在的页面(否则报错),例如 pages/index/index, 根路径前不要填加 /,不能携带参数(参数请放在scene字段里),如果不填写这个字段,默认跳主页面
            'width' => $width, //二维码的宽度,单位 px,最小 280px,最大 1280px
        ];
        $result = self::curlPostJson($url, $data);
        <<<EOF
result 正常时 返回普通字符串:����JFIF��C��C��\b"��\b \v���}!1AQa"q2���\b#B��R��$3br� %&'()*456789:CDEFGHIJSTUVWXYZcdefghijstuvwxyz������������
result 异常时 返回json字符串:{"errcode":41030,"errmsg":"invalid page rid: 6286f575-5efffc6c-********"}
EOF;
        if (is_json($result)) {
     //result 异常时 返回json字符串
            die("getwxacodeunlimit 接口异常:" . $result); //记录异常:这里改成自己项目里的格式:存日志然后return,还是直接抛出异常
        }

        $url = self::saveQrcode($result);

        return $url;
    }

    /**
     * 保存小程序码到本地,还是上传到阿里云,根据自己的实际情况
     * @param string $imageBuffer 图片buffer
     * @param bool $isCloud 是否存云储存,默认否
     * @return mixed
     */
    public function saveQrcode($imageBuffer, $isCloud = false) {
    
        $date = date('Ymd'); //以年月日为文件夹名
        $fileName = $date . '/' . uniqid() . '.jpg'; //创建后缀为 .jpg 的文件名

        $absolutePath = Env::get('root_path') . 'public/uploads/' . $date;
        $absolutePath = str_replace('\\','/', $absolutePath);

        $relativeFile = 'public/uploads/' . $fileName; //相对文件路径
        $absoluteFile = Env::get('root_path') . $relativeFile; //绝对文件路径

        if (!is_dir($absolutePath)) {
    
            mkdir($absolutePath,0777,true); //true:支持递归创建文件夹
            chmod($absolutePath,0777);
        }

        file_put_contents($absoluteFile, $imageBuffer); //把文件存到项目中

        //如果是上传云储存,则返回云储存路径,删除本地文件
        if ($isCloud) {
    
            ALYOss::upload($fileName, $absoluteFile); //把本地的绝对文件上传到阿里云oss
            $url = "https://resource.****.com/" . $fileName;
            unlink(str_replace('\\','/', $absoluteFile)); //如果上传了oss,可以删除本地文件
        } else {
    
            $url = $relativeFile; //不上传云储存,返回项目的相对路径
        }

        return $url;
    }

    /**
     * 获取access_token
     * @return string
     */
    public function getAccessToken() {
    
        //$appid,$secret 实际使用中可以从配置文件中读取
        $appid = 'wxewrewrger*****'; //小程序唯一凭证,即 AppID
        $secret = '612313dfefet*****'; //小程序唯一凭证密钥,即 AppSecret

        $url = 'https://api.weixin.qq.com/cgi-bin/token';
        $data = [
            'grant_type' => 'client_credential', //填写 client_credential
            'appid' => $appid, //小程序唯一凭证:AppID 16位16进制(字母小写)
            'secret' => $secret //小程序唯一凭证:AppSecret 32位16进制(字母小写) => 类似于md5()
        ];
        $apiUrl = self::getUrl($url, $data);
        $apiResult = self::curlGet($apiUrl);
        $result =  json_decode($apiResult,true);
        $accessToken = isset($result['access_token']) ? $result['access_token'] : '';
        if (!$accessToken) {
    
            die("access_token 接口异常:" . $apiResult);  //记录异常:这里改成自己项目里的格式:存日志然后return,还是直接抛出异常
        }
        return $accessToken; //返回格式形如:58_jWlcuOEwwerxIuwcU7u**********
    }

    //url生成器
    public function getUrl($apiUrl, $param = []){
    
        $param = http_build_query($param);
        return $apiUrl . '?' . $param;
    }

    //get 请求
    public function curlGet($url, $header = []) {
    
        $ch = curl_init();
        curl_setopt($ch, CURLOPT_URL, $url);
        curl_setopt($ch, CURLOPT_HTTPGET, true);
        if ($header) {
    
            curl_setopt($ch, CURLOPT_HTTPHEADER, $header);
        }
        curl_setopt($ch, CURLOPT_TIMEOUT, 30); //设置超时时间:30s
        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE); //忽略ssl检测
        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); //1 或 TRUE 将curl_exec()获取的信息以字符串返回,而不是直接输出。-
        curl_setopt($ch, CURLINFO_HEADER_OUT, true); //TRUE 时追踪句柄的请求字符串,从 PHP 5.1.3 开始可用。这个很关键,就是允许你查看请求header
        $output = curl_exec($ch);
        if (!$output) {
    
//        echo "request $url fail:", (array)curl_error($ch); //记录日志
        }
        curl_close($ch);
//    echo "request $url success:" . json_encode(array($url, $header, $output), true); //记录日志
        return $output;
    }

    //json post请求
    public function curlPostJson($url, $data, $header = []) {
    
        $data = json_encode($data);
        $ch = curl_init();
        if (!empty($data)) {
    
            curl_setopt($ch, CURLOPT_POST,true);
            curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
        }
        $header[]='Content-Type: application/json; charset=utf-8';
        curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true); //为true,则会跟踪爬取重定向页面,否则,不会跟踪重定向页面
        curl_setopt($ch, CURLOPT_HTTPHEADER, $header);
        curl_setopt($ch, CURLOPT_TIMEOUT, 30); //设置超时时间:30s
        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE); //忽略ssl检测
        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); //1 或 TRUE 将curl_exec()获取的信息以字符串返回,而不是直接输出。-
        curl_setopt($ch, CURLINFO_HEADER_OUT, true); //TRUE 时追踪句柄的请求字符串,从 PHP 5.1.3 开始可用。这个很关键,就是允许你查看请求header
        curl_setopt($ch, CURLOPT_URL, $url);
        $output = curl_exec($ch);
        if (!$output) {
    
//        echo "request $url fail:", (array)curl_error($ch); //记录日志
        }
        curl_close($ch);
//    echo "request $url success:" . json_encode(array($url, $header, $output), true); //记录日志
        return $output;
    }

四、在 体验版/开发版 生成小程序码

  • 接口 https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=ACCESS_TOKEN 只要增加2个参数:check_pathenv_version 就行了,格式如下:
$data = [
            'scene' => $scene, //最大32个可见字符,只支持数字,大小写英文以及部分特殊字符:!#$&'()*+,/:;=?@-._~,其它字符请自行编码为合法字符(因不支持%,中文无法使用 urlencode 处理,请使用其他编码方式)
            'page' => $page, //必须是已经发布的小程序存在的页面(否则报错),例如 pages/index/index, 根路径前不要填加 /,不能携带参数(参数请放在scene字段里),如果不填写这个字段,默认跳主页面
            'width' => $width, //二维码的宽度,单位 px,最小 280px,最大 1280px
            'check_path' => false, //检查 page 是否存在,为 true 时 page 必须是已经发布的小程序存在的页面(否则报错);为 false 时允许小程序未发布或者 page 不存在, 但 page 有数量上限(60000个)请勿滥用
            'env_version' => 'trial' //要打开的小程序版本。正式版为 release,体验版为 trial,开发版为 develop
        ];
  • 【接口文档地址:生成永久有效,数量暂无限制的小程序码】微信官方文档 -> 小程序 -> 服务端 -> 小程序码 -> getUnlimited
    在这里插入图片描述

五、需要注意的坑

  • 需要注意生成二维码的两个参数 scenepath(新手必看、必踩的坑)
scene 最大32个可见字符,只支持数字,大小写英文以及部分特殊字符:!#$&'()*+,/:;=?@-._~,其它字符请自行编码为合法字符(因不支持%,中文无法使用 urlencode 处理,请使用其他编码方式)
page 页面 page,例如 pages/index/index,根路径前不要填加 /,不能携带参数(参数请放在 scene 字段里),如果不填写这个字段,默认跳主页面
  • 如果想要在测试版测试,请看第四步,需修改参数:
    • check_pathfalse
    • env_version 为 :体验版- trial 或 开发版- develop(release 为正式版)

六、小程序获取scene场景值参数

  • 在小程序 onLoad 的时候 需要使用 decodeURIComponent 获取到生成二维码时传入的 scene 值
Page({
    
 onLoad (options)  {
    
   // scene 需使用 decodeURIComponent 才能获取到生成的小程序码传入的 scene(场景值)
   if (options.scene) {
     //scene场景值不存在时:options.scene 为 undefined
   	const scene = decodeURIComponent(options.scene)
   }
 }
})

需要注意的是:如果你传递的 scene 参数是 uid=1&pid=9,那么在 encodeURIComponent 出来后的结果也是uid=1&pid=9,获取 uid,pid 对应的值就需要自己对字符串做处理了。

谢谢阅读!!!
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_36025814/article/details/124890654

智能推荐

解决win10/win8/8.1 64位操作系统MT65xx preloader线刷驱动无法安装_mt65驱动-程序员宅基地

文章浏览阅读1.3w次。转载自 http://www.miui.com/thread-2003672-1-1.html 当手机在刷错包或者误修改删除系统文件后会出现无法开机或者是移动定制(联通合约机)版想刷标准版,这时就会用到线刷,首先就是安装线刷驱动。 在XP和win7上线刷是比较方便的,用那个驱动自动安装版,直接就可以安装好,完成线刷。不过现在也有好多机友换成了win8/8.1系统,再使用这个_mt65驱动

SonarQube简介及客户端集成_sonar的客户端区别-程序员宅基地

文章浏览阅读1k次。SonarQube是一个代码质量管理平台,可以扫描监测代码并给出质量评价及修改建议,通过插件机制支持25+中开发语言,可以很容易与gradle\maven\jenkins等工具进行集成,是非常流行的代码质量管控平台。通CheckStyle、findbugs等工具定位不同,SonarQube定位于平台,有完善的管理机制及强大的管理页面,并通过插件支持checkstyle及findbugs等既有的流..._sonar的客户端区别

元学习系列(六):神经图灵机详细分析_神经图灵机方法改进-程序员宅基地

文章浏览阅读3.4k次,点赞2次,收藏27次。神经图灵机是LSTM、GRU的改进版本,本质上依然包含一个外部记忆结构、可对记忆进行读写操作,主要针对读写操作进行了改进,或者说提出了一种新的读写操作思路。神经图灵机之所以叫这个名字是因为它通过深度学习模型模拟了图灵机,但是我觉得如果先去介绍图灵机的概念,就会搞得很混乱,所以这里主要从神经图灵机改进了LSTM的哪些方面入手进行讲解,同时,由于模型的结构比较复杂,为了让思路更清晰,这次也会分开几..._神经图灵机方法改进

【机器学习】机器学习模型迭代方法(Python)-程序员宅基地

文章浏览阅读2.8k次。一、模型迭代方法机器学习模型在实际应用的场景,通常要根据新增的数据下进行模型的迭代,常见的模型迭代方法有以下几种:1、全量数据重新训练一个模型,直接合并历史训练数据与新增的数据,模型直接离线学习全量数据,学习得到一个全新的模型。优缺点:这也是实际最为常见的模型迭代方式,通常模型效果也是最好的,但这样模型迭代比较耗时,资源耗费比较多,实时性较差,特别是在大数据场景更为困难;2、模型融合的方法,将旧模..._模型迭代

base64图片打成Zip包上传,以及服务端解压的简单实现_base64可以装换zip吗-程序员宅基地

文章浏览阅读2.3k次。1、前言上传图片一般采用异步上传的方式,但是异步上传带来不好的地方,就如果图片有改变或者删除,图片服务器端就会造成浪费。所以有时候就会和参数同步提交。笔者喜欢base64图片一起上传,但是图片过多时就会出现数据丢失等异常。因为tomcat的post请求默认是2M的长度限制。2、解决办法有两种:① 修改tomcat的servel.xml的配置文件,设置 maxPostSize=..._base64可以装换zip吗

Opencv自然场景文本识别系统(源码&教程)_opencv自然场景实时识别文字-程序员宅基地

文章浏览阅读1k次,点赞17次,收藏22次。Opencv自然场景文本识别系统(源码&教程)_opencv自然场景实时识别文字

随便推点

ESXi 快速复制虚拟机脚本_exsi6.7快速克隆centos-程序员宅基地

文章浏览阅读1.3k次。拷贝虚拟机文件时间比较长,因为虚拟机 flat 文件很大,所以要等。脚本完成后,以复制虚拟机文件夹。将以下脚本内容写入文件。_exsi6.7快速克隆centos

好友推荐—基于关系的java和spark代码实现_本关任务:使用 spark core 知识完成 " 好友推荐 " 的程序。-程序员宅基地

文章浏览阅读2k次。本文主要实现基于二度好友的推荐。数学公式参考于:http://blog.csdn.net/qq_14950717/article/details/52197565测试数据为自己随手画的关系图把图片整理成文本信息如下:a b c d e f yb c a f gc a b dd c a e h q re f h d af e a b gg h f bh e g i di j m n ..._本关任务:使用 spark core 知识完成 " 好友推荐 " 的程序。

南京大学-高级程序设计复习总结_南京大学高级程序设计-程序员宅基地

文章浏览阅读367次。南京大学高级程序设计期末复习总结,c++面向对象编程_南京大学高级程序设计

4.朴素贝叶斯分类器实现-matlab_朴素贝叶斯 matlab训练和测试输出-程序员宅基地

文章浏览阅读3.1k次,点赞2次,收藏12次。实现朴素贝叶斯分类器,并且根据李航《统计机器学习》第四章提供的数据训练与测试,结果与书中一致分别实现了朴素贝叶斯以及带有laplace平滑的朴素贝叶斯%书中例题实现朴素贝叶斯%特征1的取值集合A1=[1;2;3];%特征2的取值集合A2=[4;5;6];%S M LAValues={A1;A2};%Y的取值集合YValue=[-1;1];%数据集和T=[ 1,4,-1;..._朴素贝叶斯 matlab训练和测试输出

Markdown 文本换行_markdowntext 换行-程序员宅基地

文章浏览阅读1.6k次。Markdown 文本换行_markdowntext 换行

错误:0xC0000022 在运行 Microsoft Windows 非核心版本的计算机上,运行”slui.exe 0x2a 0xC0000022″以显示错误文本_错误: 0xc0000022 在运行 microsoft windows 非核心版本的计算机上,运行-程序员宅基地

文章浏览阅读6.7w次,点赞2次,收藏37次。win10 2016长期服务版激活错误解决方法:打开“注册表编辑器”;(Windows + R然后输入Regedit)修改SkipRearm的值为1:(在HKEY_LOCAL_MACHINE–》SOFTWARE–》Microsoft–》Windows NT–》CurrentVersion–》SoftwareProtectionPlatform里面,将SkipRearm的值修改为1)重..._错误: 0xc0000022 在运行 microsoft windows 非核心版本的计算机上,运行“slui.ex