织梦dedecms未审核的文章仍然生成或在列表页面显示 - 墙角de猫

织梦dedecms未审核的文章仍然生成或在列表页面显示 - 墙角de猫 织梦dedecms未审核的文章仍然生成或在列表页面显示 - 墙角de猫



织梦dedecms未审核的文章仍然生成或在列表页面显示

以前有做过一个系统把内容导入到dedecms中但是会发现生成时未审核的文档也会在列表页面显示并且是以.php?id形式显示的,下面我们人来看看问题解决办法。
 

织梦的文档数据都是存在MySQL数据表里面的,就默认的安装的织梦系统来说,发的文章、软件、图片等等的文档信息,都会储存在dede_archives表中,dede_archives表是文档的主表。织梦是如何来判断一篇文档是否审核或者是否已经生成HTML文件的呢?

就是通过dede_archives表中的arcrank和ismake两个字段,今天来了解这两个字段的含义。具体来说arcrank是看这篇文章审核没有,它有-1和0两个值;ismake是代表是否生成了静态文件,它有三个值:0,1,-1。

下面是对各种情况进行组合,都有可能出现的文档状态:

审核状态生成html:$arcrank=-1 $ismake = 0 (但是后台文章列表那里显示没有生成,点击修改文章是显示以生成,其实没生成,因为是未审核,一但审核,自动变成1)。

审核状态动态浏览:$arcrank=-1 $ismake = -1 ;

开放状态生成html:$arcrank=0 $ismake = 1 ;

开放状态动态浏览:$arcrank=0 $ismake = -1 ;

总结一下,通过上面四个,得出以下结论:

$arcrank =-1是代表未审核,0带表审核:

$ismake生成html:0或者1; 入库的时候是0,程序会判断是不是生成了html,如果是会调整到1;

另外还有一个需要注意的地方,就是织梦还有一个文档微表dede_arctiny,如果我们在使用SQL语句对文档批量进行审核或者未审核操作时,必须把微表中的arcrank字段也设为相同的值


网上比较常见的办法是使用SQL语句设置,具体的SQL语句如下:

 代码如下 复制代码

Update dede_archives set arcrank = -1,ismake=0;

使用这两条SQL语句之后,所有的文章文档的状态就变成了未审核了。不过会遇到一个问题,有的是前台动态还可以访问,后台一键生成的时候居然还会生成,只是不会真正的生成文件。产生这种情况的原因是什么呢?其实是织梦DedeCMS的微表和主表的状态没有统一。网上有一种比较死的办法,是把文章删除之后再恢复文章就解决了。

No牛网今天要说的还是使用SQL语句解决这个问题。都知道是微表的问题了,只需要使用如下的SQL语句即可解决:

 代码如下 复制代码

Update dede_arctiny set arcrank = -1;

综合一下,我们在把所有的文章设置为未审核状态的时候,一定要使用以下的SQL语句:

 代码如下 复制代码

Update dede_archives set arcrank = -1,ismake=0; //www.111cn.net
Update dede_arctiny set arcrank = -1;

这样就把文章的主表、微表等等的信息都同步了。

最后发现是因为dede_archives与dede_arctiny表中有两不统一导致的。

 
 
笔者这样写:

Update dede_archives set arcrank = 0,ismake=0;


Update dede_arctiny set arcrank = 0;

墙角de猫 博客

评论 0

挤眼 亲亲 咆哮 开心 想想 可怜 糗大了 委屈 哈哈 小声点 右哼哼 左哼哼 疑问 坏笑 赚钱啦 悲伤 耍酷 勾引 厉害 握手 耶 嘻嘻 害羞 鼓掌 馋嘴 抓狂 抱抱 围观 威武 给力
提交评论

清空信息
关闭评论