php+laravel 扫码二维码签到功能

admin3年前PHP教程49
简介

为满足公司签到业务场景 最终敲定使用微信二维码来实现

微信公众号相关配置
在微信公众平台登陆上去后,点开开发中的基本配置看到的基本信息

框架及拓展包


laravel
overtrue/laravel-wechat 
安装方式:composer require "overtrue/laravel-wechat:^6.0"

详细了解请看:laravel-wechat

配置文件及对应信息


config/wechat.php
    /*
     * 公众号
     */
    'official_account' => [
        'default' => [
            'app_id'  => env('WECHAT_OFFICIAL_ACCOUNT_APPID', 'your-app-id'),         // AppID
            'secret'  => env('WECHAT_OFFICIAL_ACCOUNT_SECRET', 'your-app-secret'),    // AppSecret
            'token'   => env('WECHAT_OFFICIAL_ACCOUNT_TOKEN', 'your-token'),           // Token
            'aes_key' => env('WECHAT_OFFICIAL_ACCOUNT_AES_KEY', ''),                 // EncodingAESKey
 
        ],
    ],

生成二维码


<?php
 
namespace App\Model\WeChat;
 
use Illuminate\Database\Eloquent\Model;
 
class Qrcode extends Model
{
    private static $app;
    public function __construct(){
        self::$app = app('wechat.official_account');
    }
    
    /**
     * @title 生成临时二维码
     * @param $action_info
     * @param float|int $expire_seconds
     * @return $result
     * @return $result[ticket]  获取的二维码ticket,凭借此ticket可以在有效时间内换取二维码。
     * @return $result[expire_seconds]  该二维码有效时间,以秒为单位。 最大不超过2592000(即30天)
     * @return $result[url]  二维码图片解析后的地址,开发者可根据该地址自行生成需要的二维码图片
     * @return $result[url1]  通过ticket换取二维码后地址
     */
    public function temporary($action_info,$expire_seconds = 30*24*60*60){
        $result =  self::$app->qrcode->temporary($action_info, $expire_seconds);
        $ticket = $result['ticket'];
        $url = $this -> qrcode_url($ticket);
        $result['url1'] = $url;
        $result['action_info'] = $action_info;
        return $result;
    }
 
    /**
     * @title 生成永久二维码
     * @param $action_info
     * @return $result
     * @return $result[ticket] 获取的二维码ticket,凭借此ticket可以在有效时间内换取二维码
     * @return $result[expire_seconds] 该二维码有效时间,以秒为单位。 最大不超过2592000(即30天)
     * @return $result[url] 二维码图片解析后的地址,开发者可根据该地址自行生成需要的二维码图片
     * @return $result[url1] 通过ticket换取二维码后地址
     */
    public function forever($action_info){
        $result =  self::$app->qrcode->forever($action_info);
        $ticket = $result['ticket'];
        $url = $this -> qrcode_url($ticket);
        $result['url1'] = $url;
        $result['action_info'] = $action_info;
        return $result;
    }
 
    /**
     * @title 获取二维码url
     * @param $ticket
     * @return $url 二维码url
     */
    public function qrcode_url($ticket){
        $url = self::$app->qrcode->url($ticket);
        return $url;
    }
}

实现一个简单的推送


<?php
 
namespace App\Http\Controllers;
 
use App\Http\Controllers\Controller;
use Illuminate\Support\Facades\Log;
 
class WeChatController extends Controller
{
 
    /**
     * 处理微信的请求消息
     *
     * @return string
     */
    public function serve()
    {
        Log::info('request arrived.'); # 注意:Log 为 Laravel 组件,所以它记的日志去 Laravel 日志看,而不是 EasyWeChat 日志
 
        $app = app('wechat.official_account');
        $app->server->push(function($message){
            return "hello everyone!";
        });
 
        return $app->server->serve();
    }
}

处理事件


<?php
 
namespace App\Http\Controllers;
 
use App\Http\Controllers\Controller;
use Illuminate\Support\Facades\Log;
use Illuminate\Http\Request;
use App\Model\SCAN;
 
class WeChatController extends Controller
{
 
    /**
     * 处理微信的请求消息
     *
     * @return string
     */
    public function serve()
    {
        Log::info('request arrived.'); # 注意:Log 为 Laravel 组件,所以它记的日志去 Laravel 日志看,而不是 EasyWeChat 日志
 
        $app = app('wechat.official_account');
        $app->server->push(function($message){
            case 'event':
                    switch ($message['Event']) {
                        case 'subscribe':  //关注事件, 扫描带参数二维码事件(用户未关注时,进行关注后的事件推送)
                            return "hello everyone!";
                            break;
                        case 'unsubscribe':  //取消关注事件
                            break;
                        case 'SCAN':  //扫描带参数二维码事件(用户已关注时的事件推送)
                            $obj = new SCAN(); //处理扫码相关业务逻辑
                            $info = $obj -> index($message);
                            Log::info($info);
                            return $info;
                            break;
                        default:
                            return $message['Event'];
                            break;
                    }
                    break;
        });
 
        return $app->server->serve();
    }
}

业务模块并推送模版消息


<?php
 
namespace App\Model;
 
use Illuminate\Database\Eloquent\Model;
use Illuminate\Support\Facades\DB;
 
class SCAN extends Model
{
    //扫码
    public function index($message){
        $openid = $message['FromUserName'];
        $evenkey = $message['EventKey'];
        $preg = '/^aaa-/';
        preg_match_all($preg,$evenkey,$evenkey_arr);
        if(!empty($evenkey_arr[0])){
            $new_evenkey = $evenkey_arr[0][0];
            $reg = "/^$new_evenkey/";
            $evenkey = trim(preg_replace($reg, ' ', $evenkey));
            if($new_evenkey == "aaa-"){  //生成二维码时所传人的参数
                $this -> operation($evenkey,$openid);
            }
        }else{
            return;
        }
    }
 
    /**
    * @param evenkey 参数
    * @param openid 要向哪个用户推送信息
    */
    public function operation($evenkey,$openid)
    {
       //此处省略业务逻辑 根据一个状态判断 大家直接套用就好
       $status = 1;
       if($status == 1){
           $this->success($openid);
       }else{
           $this->error($openid);
       }
    }
 
 
    /**
    * @title 扫码成功
    * @param openid 用户openid
    */
    public function success($openid){
        $app = app('wechat.official_account');
 
        //这里可以填写您选择的公众号中模版消息的模版id
        $template_id = ''; 
        
        //$data是模版中的详细内容 按照微信中的内容进行填写 下面只是一个例子
        $data = array(
            "first"  => '',
            "keyword1"   => '',
            "keyword2"  => '',
            "keyword3"  => date('Y-m-d H:i'),
            "keyword4" => '',
            "remark" => ''
        );
 
        //最后发送的信息
        $info = [
            'touser' => $openid,
            'template_id' => $template_id,
            'url' => '',
            'data' => $data,
        ];
 
        return $app -> template_message ->send($info);
    }
 
 
    /**
    * @title 扫码失败
    * @param openid 用户openid
    */
    public function error($openid){
        $app = app('wechat.official_account');
 
        //这里可以填写您选择的公众号中模版消息的模版id
        $template_id = ''; 
        
        //$data是模版中的详细内容 按照微信中的内容进行填写 下面只是一个例子
        $data = array(
            "first"  => '',
            "keyword1"   => '',
            "keyword2"  => '',
            "keyword3"  => date('Y-m-d H:i'),
            "keyword4" => '',
            "remark" => ''
        );
 
        //最后发送的信息
        $info = [
            'touser' => $openid,
            'template_id' => $template_id,
            'url' => '',
            'data' => $data,
        ];
 
        return $app -> template_message ->send($info);
    }
}

以上是我的使用心得 谢谢大家!

到此这篇关于php+laravel 扫码二维码签到功能的文章就介绍到这了,更多相关php二维码签到内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

免责声明:本文内容来自用户上传并发布,站点仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。请核实广告和内容真实性,谨慎使用。

相关文章

国外多IP服务器如何选择国外多ip服务器租用地址是多少

一、国外多IP服务器有什么用?1、容易被搜索引擎收录普通国外服务器可能只包含一个独立IP。如果很多网站都放在一个IP上,那么引擎就不会重视,甚至会被视为毫无价值的网站。国外多IP服务器提供多个独立IP...

海外站群服务器有哪些优势

现今站长在做网站优化时,更喜欢站群服务器,可以提供很ip比较多的资源,利于网站收录。不过由于国内的ip资源有限,海外站群服务器成为站长的热门选择,今天分享一下海外站群服务器有哪些优势?1、拥有丰富的I...

GPU服务器的功能包括哪些?新加坡GPU服务器适合哪些行业购买?

GPU服务器是装有GPU(图形处理单元)的服务器。GPU,也称为图形卡或视频卡,是一种专门的电子电路,可加速创建和渲染计算机图形、视频等的过程。它执行快速数学计算,同时释放CPU以执行其他任务。GPU...

编程入门先学什么(如何学会编程写代码)

编程入门先学什么最近有许多关于学习编程的争辩。不仅仅是由于与软件开发公司公开的待应聘的职位数量相比较契合招聘要求的人远远无法满足缺口,编程也是工资最高和工作满足感最强的许多职业之一。也难怪越来越多的人...

韩国站群服务器原生IP如何辨别?韩国多ip服务器购买需要注意哪些事项?

不少客户在购买韩国站群服务器时会咨询是否原生ip,因为某些特定运用会严格限制ip,例如做外贸电子商务的客户,如果是原生ip就比较好注册和使用体验。依据ip可以和地理位置信息绑定的特性,可以可以分为原生...

台湾物理服务器配置推荐怎么选择

台湾物理服务器配置推荐怎么选择?选择台湾服务器的物理配置需要根据你的实际需求和预算来决定。以下是一些推荐的配置:处理器:双路IntelXeonE5或更高级别的处理器,可以提供更高的性能和稳定性。内存:...