前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >分享张戈博客自用的php网址在线转换二维码的API源码

分享张戈博客自用的php网址在线转换二维码的API源码

作者头像
张戈
发布2018-03-23 14:11:27
1.2K0
发布2018-03-23 14:11:27
举报
文章被收录于专栏:张戈的专栏张戈的专栏

最新补充:博客已分享性能最好的 js 生成二维码方案==>传送门

去年张戈博客曾分享过一篇与二维码 API 有关的文章:《分享几个可用的二维码 API,以及给博客添加文章二维码图片的方法》,由于第三方二维码 API 总感觉稳定性和自定义性稍差,所以就到网上爬了一下相关代码,自己搭建了一个二维码 API,用了几个月感觉良好,完全可以满足我博客的自定义需求。至于博客二维码这个功能是否鸡肋,那就仁者见仁智者见智了。我个人认为,在这个移动互联网飞速发展的时代,抢占先机,做好移动端的用户体验至关重要!

这个功能不是原创,而且百度一搜一大把,都不好意思拿来分享一二。最近看到有网友留言,想要我分享这个二维码 API 源码,鉴于博客分享初衷,就厚着脸皮贴出来了。当然,不止是那个 qr code 类,而是搭建成品的整体代码或心得,毕竟张戈博客存在的目的就是尽力降低各类 IT 教程的使用门槛(哈,是不是感觉很高尚...)!

一、PHP 代码

代码语言:javascript
复制
<?php
/**
* PHP在线网址二维码API源码分享示例 By 张戈博客(zhangge.net)
* 文章地址:http://zhangge.net/5031.html
**/
 
//载入qrcode类
include "./phpqrcode.php";
 
//取得GET参数
$url        = isset($_GET["url"]) ? $_GET["url"] : 'help';
$errorLevel = isset($_GET["e"]) ? $_GET["e"] : 'L';
$PointSize  = isset($_GET["p"]) ? $_GET["p"] : '3';
$margin     = isset($_GET["m"]) ? $_GET["m"] : '0';
preg_match('/http:\/\/([\w\W]*?)\//si', $url, $matches);
 
//简单判断
//if ( $matches[1] != 'zhangge.net' && $matches[1] != 'zgboke.com' || $url == 'help') { //取消此行注释并注释下面一行,就能加入自定义的url过滤功能
if ( $url == 'help'){
    //简单的描述一下使用方法
    header("Content-type: text/html; charset=utf-8");
    echo '<title>在线二维码API接口| 张戈博客</title>';
    echo '<h1>欢迎使用张戈博客在线二维码API服务!</h1>
    使用前请仔细查看参数说明:<br />
    <br />
    url: 二维码对应的网址<br /><br />
    m&nbsp&nbsp: 二维码白色边框尺寸,缺省值: 0px<br /><br />
    e&nbsp&nbsp: 容错级别(errorLevel),可选参数如下(缺省值 L):<br />
    &nbsp;&nbsp;&nbsp;&nbsp;&nbspL水平    7%的字码可被修正<br />
    &nbsp;&nbsp;&nbsp;&nbsp;&nbspM水平    15%的字码可被修正<br />
    &nbsp;&nbsp;&nbsp;&nbsp;&nbspQ水平    25%的字码可被修正<br />
    &nbsp;&nbsp;&nbsp;&nbsp;&nbspH水平    30%的字码可被修正<br />
    p&nbsp&nbsp: 二维码尺寸,可选范围1-10(具体大小和容错级别有关)(缺省值:3)<br /><br />
    常规用法:<a href="//seo.zgboke.com/qr/?m=0&e=L&p=3&url=http://zhangge.net/" target="_blank">http://seo.zgboke.com/qr/?m=0&e=L&p=3&url=http://zhangge.net/</a><br /><br />
    
    CDN 加速:<br />
    格	式:http://seo.zgboke.com/qr/$m_$e_$p_$url_cdn.png <br />
    示	例:<a href="//seo.zgboke.com/qr/0_l_3_http://zhangge.net_cdn.png" target="_blank">http://seo.zgboke.com/qr/0_l_3_http://zhangge.net_cdn.png</a><br />
    ';
	exit();
} else  {
    //调用二维码生成函数
    createqr($url, $errorLevel, $PointSize, $margin);
}
 
//简单二维码生成函数
function createqr($value,$errorCorrectionLevel,$matrixPointSize,$margin) {
    QRcode::png($value, false, $errorCorrectionLevel, $matrixPointSize, $margin);
}
?>

将以上代码保存为 php 文件(比如 qr.php),上传到网站指定目录(比如根目录 /)。

二、QrCode 类

下载 PHP 的 QrCode 类,上传到网站目录,其实百度一搜一大把,还是贴上张戈博客自用的文件吧!

下载地址

Ps:以上相关代码均已包含在内。

三、CDN 加速

因为这个 API 是在线生成的,如果请求过于频繁,将会影响到服务器性能和加载速度。所以,我们有必要继续优化一下。我个人想到 3 个解决方案:

①、每生成一个新的二维码图片就缓存一份到服务器,下次若是相同的内容,将直接读取; ②、利用伪静态重写请求地址,伪装成静态文件格式,比如 png、jpg 等,然后开启免费 CDN; ③、结合①和②,实现伪静态+CDN 加速+浏览器缓存加速,达到优化加载速度。

目前张戈博客仅使用了第 ② 种方案,已完全可以满足博客的需求,所以就懒得去折腾更完善的方法,感兴趣的童鞋可以自己去试试,下面说一下伪静态规则。

张戈博客将这个 API 搭建在万网的免费虚拟主机上,所以仅分享 Apache 伪静态规则,其他 WEB 服务器请自行解决。

Apache 伪静态规则:

代码语言:javascript
复制
RewriteEngine on
RewriteBase /
 
#QR二维码
RewriteRule ^qr/(.*)_(.*)_(.*)_http:/(.*)_cdn\.png$ qr/index.php?m=$1&e=$2&p=$3&url=http://$4 [L]
RewriteRule ^qr/(.*)_(.*)_(.*)_(.*)_cdn\.png$ qr/index.php?m=$1&e=$2&p=$3&url=$4 [L]

注:以上是将 API 源码上传到网站根目录下的 qr 文件夹的例子!

伪静态之后,这个二维码地址就是一个正常的 png 格式了,只要到免费 CDN(比如百度云加速或 360 网站卫士等)开启静态资源缓存即可实现 CDN 加速。

四、使用范例

直接访问本文第一段代码所保存的文件就能看到简单的使用说明了:

代码语言:javascript
复制
欢迎使用张戈博客在线二维码API服务!
 
使用前请仔细查看参数说明:
 
url: 二维码对应的网址
 
m  : 二维码白色边框尺寸,缺省值: 0px
 
e  : 容错级别(errorLevel),可选参数如下(缺省值 L):
     L水平 7%的字码可被修正
     M水平 15%的字码可被修正
     Q水平 25%的字码可被修正
     H水平 30%的字码可被修正
p  : 二维码尺寸,可选范围1-10(具体大小和容错级别有关)(缺省值:3)
 
常规用法:http://seo.zgboke.com/qr/?m=0&e=L&p=3&url=http://zhangge.net/
 
CDN 加速:
格    式:http://seo.zgboke.com/qr/$m_$e_$p_$url_cdn.png 
示    例:http://seo.zgboke.com/qr/0_l_3_http://zhangge.net_cdn.png

查看效果:http://seo.zgboke.com/qr/0_l_3_http://zhangge.net_cdn.png

按下 F12,到 NetWork 选项卡查看头部已经可以看到百度云加速的 HIT 缓存标识了!

至于如何应用到博客当中,请移步查看张戈博客以前分享的教程:https://cloud.tencent.com/developer/article/1071356

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2015年04月13日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、PHP 代码
  • 二、QrCode 类
  • 三、CDN 加速
  • 四、使用范例
相关产品与服务
内容分发网络 CDN
内容分发网络(Content Delivery Network,CDN)通过将站点内容发布至遍布全球的海量加速节点,使其用户可就近获取所需内容,避免因网络拥堵、跨运营商、跨地域、跨境等因素带来的网络不稳定、访问延迟高等问题,有效提升下载速度、降低响应时间,提供流畅的用户体验。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档