Saber 酱的抱枕

Fly me to the moon

08/4
2016
学习

被百度云加速CDN缓存坑惨了的我在伤心过后决定控诉它

前天换掉了某网站上的两张图,但是在浏览器里看死活就刷新不过来。就算把这张图片删掉也还是能打开。

后来ping了一下域名,ip竟然不是我们服务器的ip。

我去百度云加速里查看解析记录,发现解析的是对的。

于是我就去问客服小哥,他们说ping到的ip是他们百度的节点ip。

我忽然间明白过来了,图片没改变是百度缓存导致的吧。

于是我去清除了下cdn缓存,果然好了。

百度云加速 cdn 缓存

这问题折腾了我一个小时,心好累。

被百度云加速CDN缓存坑惨了的我在伤心过后决定控诉它

07/31
2016
学习

获取WordPress文章的短链接

如果我们启用了WordPress的固定链接,那么每篇文章都会有一个短链接和一个固定链接。短链接是数字id,固定链接则是根据我们预设的格式生成的。

如本文有以下两个链接可以打开:

获取WordPress文章的短链接
http://www.saber.love/获取wordpress文章的短链接

由于短链接是不会变的,而固定链接却可以被修改,所以发布网址时,使用短链接更加可靠。

以前WordPress在编辑文章时有个获取短链接按钮,现在没有了。我照网上说的一些方法也没能让它显示出来。不过仍然有两个办法可以看到短链接:

1.编辑文章时点击预览,在预览页面的url里包含有文章id。发布过的文章、没有发布的文章,都可以这么看。
2.在文章的前台页面里,也保存有短链接。我们可以执行如下代码获取它:

document.querySelectorAll("link[rel=shortlink]")[0].href

获取WordPress文章的短链接

07/28
2016
ACG 游戏

Samurai-Games游戏平台和美少女花骑士

Samurai-Games 美少女花騎士 flowerknightgirlx DMM 中文

刚才群里一位台湾童鞋(昵称是Lvci)给我们推荐了一个网站,Samurai-Games平台。这个平台是由DMM运营的,但是做了本地化工作,并且提供一些DMM游戏的中文版。这对于日文苦手真是好消息~

如果要玩这个平台上的游戏,推荐在这个网站注册一个账号,登录后可以进行游戏。如果要使用Google或Facebook账户登陆的话会连接到DMM进行确认,那样可能得挂vpn才行。

Lvci向我们推荐了一款游戏——flowerknightgirl(美少女花骑士),说身边有不少人在玩这款游戏。我也进去玩了一会儿。Samurai-Games平台上的几款游戏似乎都是R18的,所以里面的福利……你懂得。

我玩的时候是挂着蓝灯(lantern)的,玩的时候资源加载速度挺不错。大陆直连的话速度应该也不低的。

下面放几张游戏截图。未满18岁请在家长陪同下观看。
Read More →

Samurai-Games游戏平台和美少女花骑士

07/26
2016
学习

原生Ajax的简单实例

因为JavaScript水平太渣,以前我都是用JQuery来做ajax。现在看了些资料,感觉原生的写法也不难,而且兼容性也已经不错了,所以跟着练一练。

同步的ajax请求:

var xhr=new XMLHttpRequest();
xhr.open("get","http://saber.我爱你/demo/checknew.php",false);
xhr.send(null);
if (xhr.status===200) {
	alert(xhr.responseText);
}else{
	alert("发生了异常,状态码为"+xhr.status+","+xhr.statusText);
}

返回的数据里有如下属性:
responseText:作为响应主体被返回的文本。
responseXML:如果响应的内容类型是"text/xml"或"application/xml",这个属性中将保存包含着响应数据的XML DOM 文档。
status:响应的HTTP 状态。
statusText:HTTP 状态的说明。


异步的ajax请求:

var xhr=new XMLHttpRequest();
xhr.onreadystatechange=function(){
	if (xhr.readyState===4) {
		if (xhr.status===200) {
			alert(xhr.responseText);
		}else{
			alert("发生了异常,状态码为"+xhr.status+","+xhr.statusText);
		}
	}
}
xhr.open("get","http://saber.我爱你/demo/checknew.php",true);
xhr.send(null);

检测状态的部分也可以这样写:

xhr.onload=function (argument) {
	if (this.status == 200) {
		//……
    }
}

异步请求除了在xhr.open里将最后的参数设置为true之外,在接收数据时也和同步请求不同。异步请求通过检查xhr对象的readyState属性来判断请求处在哪个阶段。当readyState为4时,表示接收到了数据,并且数据可用。

我们通过onreadystatechange事件来检测readyState的值,当值为4时即可对数据进行处理。

另外,在接收到响应之前还可以调用abort()方法来取消异步请求。即xhr.abort(); 。

原生Ajax的简单实例