平时可能会有删标签的习惯,有网站收录了删掉的标签,访客访问这个链接EMLOG6就会报SQL语句执行错误。

例如标签“测试”不存在,访问这个标签链接http://www.myxzy.com/tag/测试 就会报SQL语句执行错误,会出现以下提示:

SQL语句执行错误: SELECT `gid` FROM `emlog_tag` WHERE `tid` =

You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '' at line 1

346-1.png

emlog 6.0.0正式版本的发布,趁着有时间,对自己的博客程序也进行了升级。

对比下emlog5.3.1和emlog6.0.0发现程序变化不大,主要是对tag标签进行了优化。


升级方法:

1、确定程序是emlog5.3.1(本程序是对照5.3.1和6.0.0做的)

2、备份网站系统和数据库(非常重要);

3、把update.php上传到网站根目录,同config.php同一个目录;

4、浏览器访问update,按照提示输入数据库密码,确认等待升级完成;

星之宇 发布于2018-3-14 9:53

Emlog修改版(PHP7版本)

最近对自己的博客代码,主题,以及后台等等进行了大面积的优化,所以心血来潮做了这个emlog 5.3.1 XZY修改版,主要是针对PHP7的支持做了修改。

Github的项目地址:https://github.com/myxzy/emlog


修改内容:

by 2018-10-4

修改版1.1

1、Tag缓存改成emlog 6.0.0生成方式,生成首页文章所有的标签缓存

2、修改1.0修改中产生的一些BUG

更新emlog的编辑器为新版本的kindeditor,这个不是插件,请不要使用插件的安装方式。

浏览器FireFox,IE8、9,Chrome等测试编辑器一切正常。

 

1.8版本开始的安装方法:下载解压百度网盘中的文件,把解压文件夹中文件editor文件夹,替换到博客程序中admin文件夹下的editor文件夹(覆盖)。

卸载方法:删掉admin文件夹中的editor,找官网程序中admin文件夹下的editor放到admin文件夹下(覆盖的话也是可以,但是会产生多余的文件)。

PHP5.5之后新加了两个密码相关的函数:password_hash(加密)和password_verify(验证)。

string password_hash ( string $password , integer $algo [, array $options ] )

boolean password_verify ( string $password , string $hash )

想到emlog使用的是passwordhash类来实现加密和解密的,正好使用这2个新函数来改造emlog程序。(该修改仅用于测试)


修改方法如下:

1、在include/lib/function.base.php添加加密函数

星之宇 发布于2016-1-21 0:19

PHP7下安装Emlog5.3.1

PHP7出来一段时间了,据说PHP7可以性能翻倍。而且我的服务器上也已经开通了PHP7,就开始折腾下Emlog5.3.1。


直接在php7安装emlog5.3.1各种报错。emlog5.3.1虽然已经出了使用mysqli连接类,但是为了兼容性还是默认是使用了mysql。因为PHP7已经不支持mysql扩展了,但是支持mysqli和pdo_mysql。所以这里还是介绍如何使用mysqli来安装emlog。


以下是修改emlog安装程序,无报错安装。如果是实际环境请在本地环境模拟后成功后再更换。

1、修改include\lib\option.php,大概11行修改为mysqli

今天论坛有人说评论有BUG,我看了一下,无意中注意到isLogCanComment函数。

	function isLogCanComment($blogId) {
		if (Option::get('iscomment') == 'n') {
			return false;
		}
		$query = $this->db->query("SELECT allow_remark FROM ".DB_PREFIX."blog WHERE gid=$blogId");
		$show_remark = $this->db->fetch_array($query);
		if ($show_remark['allow_remark'] == 'n' || $show_remark === false) {
			return false;
		}else {
			return true;
		}
	}

文件缓存型时间轴归档,后台更新缓存或者发布新文章的时候会自动更新。

本站这个代码是使用缓存系统的,是需要修改内核文件的。慎用!


1、修改cache.php文件,添加归档缓存函数(路径include/lib)

private $logalias_cache;
之后添加
private $loglists_cache;

emlog文章连接使用gid自增号作为文章的ID,但是由于后台有删除文章的功能,一旦删除文章那么gid自增就会出现断号。

其实断号问题解决很方便,只要在添加文章的时候判断gid之前的有没有断号问题,有的话直接插入,没有的话自增。

我这里的解决方法是这样的,我把gid自增段顺序读取作为值写入数组,自增段是从1开始的,但是数组键值是0开始的,那么先把数组($gidarr[0]='0')赋值掉,然后把$gidarr[]=gid,然后只要发现$gidarr键和键值不等就是断号了。

找到我们的addlog添加文章和页面函数。路径在include/model/log_model.php。

原始代码:

Markdown for emlog这是一个由星知苑出品的hack emlog编辑器的代码(不是插件)。

安装方法:

解压本站的Markdown for emlog代码包,用FTP把代码包里的admin和include文件夹上传到emlog安装的根目录,提示覆盖选择全部覆盖即可。

源码下载:

Github项目主页:https://github.com/myxzy/markdown-for-emlog

百度网盘分流下载:http://pan.baidu.com/s/1sjHLv0D

提交
订阅