微信支付链接二维码生成

7 篇文章 0 订阅

1、进入composer官方网站,搜索phpqrcode安装包

 composer命令安装

composer require aferrandini/phpqrcode

生成二维码图片的公共方法:

// 公用二维码生成
static function setQrcode($url){
    //二维码图片保存路径
    $path = 'advert/qrcode/'.date("Ymd");
    $pathname = storage_path('app/public/').$path;
    if(!is_dir($pathname)) { //若目录不存在则创建之
        mkdir($pathname,0777,true);
    }
    $qrcode = new QRcode();
    //二维码图片保存路径(若不生成文件则设置为false)
    $suijishu = date("YmdHis").rand(100,999);
    $filename = $pathname . "/qrcode_" . $suijishu . ".png";//生成路径
    $destName = 'storage/'.$path."/qrcode_" . $suijishu . ".png";//返回路径
    //二维码容错率,默认L
    $level = "L";
    //二维码图片每个黑点的像素,默认4
    $size = '10';
    //二维码边框的间距,默认2
    $padding = 2;
    //保存二维码图片并显示出来,$filename必须传递文件路径
    $saveandprint = true;
    //生成二维码图片
    $qrcode->png($url,$filename,$level,$size,$padding,$saveandprint);
    //二维logo
    //$logo = "./public/wxpay/images/logo.png";
    //$QR = imagecreatefromstring(file_get_contents($filename));
    //$logo = imagecreatefromstring(file_get_contents($logo));
    //$QR_width = imagesx($QR);
    //$QR_height = imagesy($QR);
    //$logo_width = imagesx($logo);
    //$logo_height = imagesy($logo);
    //$logo_qr_width = $QR_width / 5;
    //$scale = $logo_width / $logo_qr_width;
    //$logo_qr_height = $logo_height / $scale;
    //$from_width = ($QR_width - $logo_qr_width) / 2;
    //imagecopyresampled($QR, $logo, $from_width, $from_width, 0, 0, $logo_qr_width, $logo_qr_height, $logo_width, $logo_height);
    //imagecopyresampled($QR, $logo, $from_width, $from_width, 0, 0, $logo_qr_width, $logo_qr_height, $logo_width, $logo_height);
    //imagepng($QR,$filename);
    return $destName;
}

控制器调用:

use PHPQRCode\QRcode;

$result['code_url'] = $this->setQrcode($result['code_url']);//生成二维码
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
/** * 微信支付帮助库 * ==================================================== * 接口分三种类型: * 【请求型接口】--Wxpay_client_ * 统一支付接口类--UnifiedOrder * 订单查询接口--OrderQuery * 退款申请接口--Refund * 退款查询接口--RefundQuery * 对账单接口--DownloadBill * 短链接转换接口--ShortUrl * 【响应型接口】--Wxpay_server_ * 通用通知接口--Notify * Native支付——请求商家获取商品信息接口--NativeCall * 【其他】 * 静态链接二维--NativeLink * JSAPI支付--JsApi * ===================================================== * 【CommonUtil】常用工具: * trimString(),设置参数时需要用到的字符处理函数 * createNoncestr(),产生随机字符串,不长于32位 * formatBizQueryParaMap(),格式化参数,签名过程需要用到 * getSign(),生成签名 * arrayToXml(),array转xml * xmlToArray(),xml转 array * postXmlCurl(),以post方式提交xml到对应的接口url * postXmlSSLCurl(),使用证书,以post方式提交xml到对应的接口url */ include_once("SDKRuntimeException.php"); include_once("WxPay.pub.config.php"); /** * 所有接口的基类 */ class Common_util_pub { function __construct() { } function trimString($value) { $ret = null; if (null != $value) { $ret = $value; if (strlen($ret) == 0) { $ret = null; } } return $ret; } /** * 作用:产生随机字符串,不长于32位 */ public function createNoncestr( $length = 32 ) { $chars = "abcdefghijklmnopqrstuvwxyz0123456789"; $str =""; for ( $i = 0; $i $v) { if($urlencode) { $v = urlencode($v); } //$buff .= strtolower($k) . "=" . $v . "&"; $buff .= $k . "=" . $v . "&"; } $reqPar; if (strlen($buff) > 0) { $reqPar = substr($buff, 0, strlen($buff)-1); } return $reqPar; } /** * 作用:生成签名 */ public function getSign($Obj) { foreach ($Obj as $k => $v) { $Parameters[$k] = $v; } //签名步骤一:按字典序排序参数 ksort($Parameters); $String = $this->formatBizQueryParaMap($Parameters, false)

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值