分类
WordPress

WordPress 上传文件出错

在 IIS8.5 中运行 WordPress 时,遇到上传图片出错的问题:此响应不是合法的 JSON 响应。

按 F12 打开开发者工具看了一下,原来是在上传完成图片后返回的 JSON 头部,多一段 HTML 代码:

<head><title>文档已移动</title></head>
<body><h1>对象已移动</h1>可在<a HREF="http://www.ilinshu.cn/wp-json/wp/v2/media/448">此处</a>找到该文档</body>

真正的 JSON 数据在这段 HTML 后面。

经过多方查找资料,得知这段代码是 IIS 插入的,但是目前没有明确的方法来禁止 IIS 的这一行为。微软曾经提供过一个hotfix,但是已经不再维护了,不适用于 IIS8.5 。微软推荐的解决办法是升级到最新的 Windows 版本,使用 Windows10 或最新的 Windows Server 版本。

话是这样说,但是升级的话,硬件要求最低要2G内存才行,增加了多余的经济负担(主要还是因为穷~)。其实我早就想完全换到 Linux ,但这是不可能的,因为还有一些服务需要 Windows Server 来运行。

其实目前来说,仅有的一个方案就是切换到 Apache,Apache 反向代理 IIS ,统一提供对外的 Web 服务。IIS 只运行 ASP.NET 应用,PHP 通过 Apache 来运行。

方案是可行的,唯一的缺点就是网站的部署稍微麻烦了一点,不过还算可以接受。

参考链接:

https://core.trac.wordpress.org/ticket/46311

https://stackoverflow.com/questions/10594225/prevent-iis-from-changing-response-when-location-header-is-present

https://stackoverflow.com/questions/12074730/w7-pro-iis-7-5-overwrites-php-location-header

https://forums.iis.net/t/1234223.aspx?Python+REST+API+Status+201+Create+IIS+Adds+HTML+To+JSON+Response

2021.11.19更新:目前整个服务器按上面的进行调整部署,现在 WordPress 上传文件的问题已经解决,一切正常平稳运行!

测试了阿里云的 Windows Server 2019,内存占用太高,2G 内存不怎么够用。

分类
WordPress

去掉WordPress5.4仪表盘中站点健康状态面板

昨天升级到WordPress5.4,发现仪表盘中新增了“站点健康状态”面板,如果不想要,可以这样去掉,在functions.php里添加以下代码:

// 从仪表盘中去掉相关面板
function remove_dashboard_meta() {    
    remove_meta_box( 'dashboard_primary', 'dashboard', 'side' ); // 去掉wordpress活动及新闻
    remove_meta_box( 'dashboard_site_health', 'dashboard', 'side' );  // 去掉站点健康状态
}
add_action( 'admin_init', 'remove_dashboard_meta' );
分类
WordPress

WordPress的最佳固定链接

WordPress提供了六种固定链接结构,前五种是固定结构,最后一种是可以自定义的结构。既然提供了不同的选择,自然就有不同的适用场景,这两天我一直在思考这个问题。

第一种类型,朴素型,https://example.com/?p=123,这种类型以前是WordPress的默认类型。这种结构的固定链接,没有任何语义性,人类和搜索引擎都无法理解链接中包含的信息,所以不建议使用。

第二种类型,日期和名称型,链接结构如下https://example.com/2019/12/28/sample-post/,这种类型强调日期。一天发布多篇文章的网站可以使用这种,比如新闻性质的网站或企业博客等,可以通过日期来判断文章的时效性。WordPress目前默认的固定链接就是这种类型。使用这种链接类型的企业博客网站之一微软官方博客(用的是WordPress),因为一天可能发布多篇文章,所以使用了这种类型。

第三种类型, 月份和名称型 ,https://example.com/2019/12/sample-post/,这种类型的固定链接和第二种差不多,强调月份,用于发布不是特别频繁并且需要明确大体日期的站点,例如个人博客、技术网站等。WordPress创始人Matt Mullenweg的博客就是使用的这种类型。

第四种是数字型,即https://example.com/archives/123,这种类型如同第一种,不过把URL参数变成了目录结构的形式。由于链接没有任何语义,不推荐这种。

第五种是文章名型,即https://example.com/sample-post/,链接只有postname一种元素,这种类型不强调时间,不强调时效性,只注重文章的关键信息。而且修改文章的发布时间、目录等属性不影响固定链接的构成,同时由于只有一个层级,对搜索引擎的权重相对高,方便提取关键信息,对于人类也很容易读懂。注重SEO和营销类型的网站可以使用这种

第六种,自定义类型,通过使用不同的标记来自定义链接的结构。

总体来说,对于个人博客,比较适合的类型是第五种和第三种。个人博客,适合使用年月进行归档,就像按年份和月份建立文件夹一样,把某年某月的文章整理到一起。在做外链或者做记录的时候,看到链接就能知道文章的发布年月和标题,做到心中有数,虽然有时候并不希望这样。 第五种也不错,简单纯粹,除了post-name,再无其它干扰,并且URL更短,层级最小,更利于搜索引擎抓取,修改文章的一些属性不会影响固定链接。

最后一点,固定链接一旦确定下来,就不要换来换去。一但更改,对于站内链接和站外链接的修复都很麻烦,如果注重SEO的话,对于SEO也是灾难。当然这些问题都有应对的办法,不过为了不折腾,选择了就坚持下去,只管写文章,再不用考虑这个问题。

分类
WordPress

解决wordpress IOS APP上传图片失败

刚才在使用ios端的APP写文章上传图片时,遇到报错,错误信息 WordPressKit.WordPressOrgXMLRPCApiError error 0. ,在google查询后得知是nginx上传文件大小设置的问题。在nginx配置文件中把网站上传大小设置大一点就可以了。这里我设置的是200M,配置代码如下:

#文件上传大小限制  必须要放在server下的server_name下
client_max_body_size 200m;

修改之后,重新加载ningx配置再上传就没问题了。

https://en.forums.wordpress.com/topic/the-operation-couldnt-be-completed-wordpresskit-wordpressorgxmlrpcapierror/

解决方案原链接