给Dedecms前台/后台添加来源网址功能

 不久以前,小编在织梦论坛发表了《DEDE发布文章添加来源网址功能》一帖,在发表本帖的同时,小编也确实感觉到了其实这是一个鸡肋功能,因为中文站长的一大特点就是喜欢转载而不附带他人的链接,果然,此帖的响应者寥寥无几。

 

  就在前天,又有一个网友看到了此帖,并通过QQ的形式找到了小编,希望能将这篇教程发布出来,他非常希望可以实现这个功能,那么现在小编就来满足这位朋友的需求,好了我们来看一下如何实现本功能。

 

  原理分析:

 

  添加来源网址功能,说白了就是在后台前台发表文章的表单内增加一个选项,首先我们要做的是在数据库增加一个字段,然后在dedecms后台前台文件分别添加相关代码。下面,我们就以后台(前台添加的方法,请照葫芦画瓢,不再赘述)添加来源网址的功能为例,讲述一下如何实现本功能。

 

  实现步骤:

 

  1.操作数据库

 

  在数据库添加一个字段,这个字段需要添加到dedecms的dede_archives 表中,你可以通过phpmyadmin工具的可视化工具来操作,也可以在后台-系统-SQL命令行工具来执行SQL语句,语句如下:

 

  ALTER TABLE `dede_archives` ADD `source_url` char(255) NOT NULL DEFAULT '0';

 

  在上面的语句中,我们可以了解到红色的为表名,蓝色的为字段(这是织梦58给来源网址定义的字段名,如果你想用其它字段名称,请在下面的教程中同步修改),绿色的255表示字段最大的长度是255个字符。注意:如果你在安装dedecms时修改了表前缀,请修改红色部分的表名称。

 

  相关文章:MySql在已知数据表添加新字段的语句

 

  完成这一步后,进入第2步。

 

  2.修改后台文件

 

  我们需要修改的文件共有四个(这里是以文章模型为例,如果你想在其它模型中增加来源网址,请修改相应的模板与文件),分别是后台目录(默认是dede,如果你修改了后台地址,请找到相应路径)下的:article_add.php、article_edit.php与后台templets下的article_add.htm、article_edit.htm

 

  首先打开article_add.php文件,查找://对保存的内容进行处理

 

  在 if(empty($writer))$writer=$cuserLogin->getUserName(); 的下面添加代码:

 

  if(empty($source_url))$source_url=''; //如果为空则是

 

  这一步的目的在上面的注释中已经说明了,不再重复。相关修改见图一:

 

Dedecms前台/后台添加来源网址功能【图一】

 

 

图一

 

  继续操作,查找代码:

 

  $source = cn_substrR($source,30);

 

  在下面添加:

 

  $source_url = cn_substrR($source_url,255);

 

  再查找://保存到主表

 

  找到source,按格式插入:source_url

 

  找到$source,按格式插入:$source_url

 

  以上操作目的是写入数据库。修改情况见图二:

 

Dedecms前台/后台添加来源网址功能【图二】 

图二

 

  恭喜你,完成了四个文件之一的修改。下面我们来进行article_edit.php的修改。

 

  首先,查找://对保存的内容进行处理 在下面添加

 

  if(empty($source_url))$source_url='';//如果为空则是

 

  可以参照图一来操作。

 

  继续查找:

 

  $source = cn_substrR($source,30);

 

  在下面添加:

 

  $source_url = cn_substrR($source_url,255);

 

  再查找(约193行):

 

  source='$source',

 

  在下面添加:

 

  source_url='$source_url',

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/65889bf8bb12d92de17eecd2e6b6df13.html