MENU

关于 Typecho 静态资源路径的问题

• November 1, 2016 • Read: 46105 • Codes

前几天有 Mirages 用户告诉我如果不开启伪静态的话,有两个链接会导致 404,然后才想起来因为我一直开着伪静态,所以一直忽略了这方面的需求,今天中午刚好有点时间,就尝试解决一下这个问题。

伪静态设置在 Typecho 后台有,选项名称为「是否使用地址重写功能」,翻了翻数据库,发现字段名为 rewrite,然后就根据这个字段做了下判断,在没开启地址重写功能的时候自动在链接中补上 index.php 就可以了。非常简单。

  • if ($options->rewrite == 0) {
  • }

顺便,想起了前两天看到 Jrotty 的一篇文章:如何为 typecho 站点设置多个域名,是关于带 www 和不带 www 的域名路径的一些问题,可能会导致一些静态文件跨域的问题(虽然我从来没遇到过。。。),但解决方案有好几种,但都会修改配置文件甚至 Typecho 源码。个人认为,这种事在主题层面解决会更好一些。

我个人的解决方案是不使用 $options->siteUrl,而是使用 $options->rootUrl,这样,Typecho 后台的「站点地址」选项的设置就影响不到我们链接的生成,而且,对于文章、分类、评论等 Typecho 自己生成的链接中( $item->permalink() )都是使用的 $options->rootUrl

但是这里有一点问题,就是 $options->themeUrl 使用的是 $options->siteUrl,很多人制作主题的时候会使用它引入静态文件:

  • <link rel="stylesheet" href="<?php $this->options->themeUrl('style.css'); ?>">

这也是官方主题的做法。除了调用函数,我们还可以直接使用 $options->themeUrl 获取其值,然后对其进行拼接:

  • <link rel="stylesheet" href="<?= $this->options->themeUrl.'/style.css'; ?>">

所以我们可以对其做一下替换:

  • define("THEME_URL", rtrim(preg_replace('/^'.preg_quote($options->siteUrl, '/').'/', $options->rootUrl.'/', $options->themeUrl, 1),'/'));

然后就可以使用了:

  • <link rel="stylesheet" href="<?= THEME_URL ?>/style.css">

目前测试下来一切正常。

以上。

Archives QR Code Tip
QR Code for this page
Tipping QR Code
Leave a Comment

30 Comments
  1. 感觉开伪静态好看而且只要搞♂ 一下.htaccess 就行了

    1. @橘纸柚是的,所以一直以来都把这个东西给忽略了

  2. 哇,学习了,我的模板未来 1.7 版将抄用 \#(赞一个),还有就是文章已转载 \#(欢呼)

  3. 伪静态!\#(小眼睛)

    1. @CAISIDUO 怎么了?\#(喷水)

    2. @Hran 路径全是 #!xxx 的一脸懵逼 \#(小眼睛)

    3. @CAISIDUO 你那个更厉害了 @(你懂的)

    4. @Hran 收录就丢一边吧 qwq

    5. @CAISIDUO 你这开开关关的要收录干嘛 \#(小怒)

    6. @Hran 我咋说不出话来了 \#(小眼睛)

  4. @(疑问) 这个是可以把 www 重定向到不带 www 的域名的方法吗 \#(期待)

    1. @小铭の森林看得有点迷糊 \#(皱眉)

    2. @小铭の森林不是的,重定向可以用服务器搞定,不用这么麻烦

    3. @Hran\#(惊喜) 秒回呀。。就是服务器弄那啥 301 定向那个吗?

    4. @小铭の森林

    5. @小铭の森林于是我来留个广告,关于怎么 301 重定向的:https://liyuans.com/archives/htaccess-to-achieve-pseudo-static-301-redirect-antitheft-chain.html

    6. @Leonn_Li\#(惊喜)

    7. @小铭の森林 \#(高兴)

  5. 还是开启伪静态功能比较好!

    1. @Meekdai 是啊,但是就算不开启也要兼容嘛 \#(肿包)