前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Typecho 免插件接入又拍云CDN

Typecho 免插件接入又拍云CDN

作者头像
用户7146828
发布2021-08-09 15:01:13
1.2K0
发布2021-08-09 15:01:13
举报
文章被收录于专栏:旧云博客旧云博客

原理

如果你有了解过PHP,那么你可能知道PHP有个函数ob_get_contents(),这个函数的作用是把缓冲区的内容读取到变量中。 什么是缓冲区?缓冲区就是在服务器渲染网页时暂存渲染结果的内存空间。

把输出读取到变量中,就任我们宰割了,直接把URL替换一下再输出就可以了。 Typecho 静态资源默认都是在/usr目录下的,如果修改过就不能用了。所以要读取Typecho的配置进行替换。

主题代码修改

2.新建完成后配置缓存规则 我的规则匹配参数是

代码语言:javascript
复制
/*.(js,css,json,txt,md,csv,xml,**log**,conf,vue,jpg,jpeg,gif,png,tif,tiff,bmp,svg,psd,ico,webp,tga,imb,mp3,mp4,avi,mpeg,rm,ra,ogg,wav,wmv,rmi,aac,rmvb,mkv,flv,swf,mov,movie,exe,ios,apk,ipa,pxl,sis,cab,deb,rar,zip,gzip,tar,7z,bzip2,dmg,gz,wim,tbz,tpz,z,jar,ttf,otf,woff,woff2,eot,sfnt)

3.配置跨域,不然无法加载字体图标

把下面的代码放到footer.php最后就可以使用又拍云CDN加速了

代码语言:javascript
复制
themeUrl, '/'));
define("THEME_NAME", end(explode("/", THEME_URL)));
if (isset($cdnHost) && strpos(trim($cdnHost), "http") === 0 || strpos(trim($cdnHost), "//") === 0) {
    //error_reporting(0);
    $htmlSource = ob_get_contents();
    $themeUrlCDN = rtrim(trim($cdnHost), '/') .  str_replace('//', '/', '/' . __TYPECHO_THEME_DIR__);
    $htmlSource =  str_replace(THEME_URL, $themeUrlCDN . '/' . THEME_NAME, $htmlSource);
    $uploadUrl = rtrim(str_replace(__TYPECHO_THEME_DIR__ . '/' . THEME_NAME, defined('__TYPECHO_UPLOAD_DIR__') ? __TYPECHO_UPLOAD_DIR__ : '/usr/uploads', THEME_URL), "/");
    $uploadUrlCDN = str_replace(__TYPECHO_THEME_DIR__, rtrim(defined('__TYPECHO_UPLOAD_DIR__') ? __TYPECHO_UPLOAD_DIR__ : '/usr/uploads', "/"), $themeUrlCDN);
    $htmlSource =  str_replace($uploadUrl, $uploadUrlCDN, $htmlSource);
    ob_clean();
    print $htmlSource;
    ob_end_flush();
}
?>
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021年05月17日,如有侵权请联系 cloudcommunity@tencent.com 删除

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

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

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

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