给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=’www.dede58.com’; //如果为空则是www.dede58.com     这一步的目的在上面的注释中已经说明了,不再重复。相关修改见图一:   给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=’www.dede58.com’;//如果为空则是www.dede58.com     可以参照图一来操作。     继续查找:     $source = cn_substrR($source,30);     在下面添加:     $source_url = cn_substrR($source_url,255);     再查找(约193行):     source=’$source’,     在下面添加:     source_url=’$source_url’,     OK.现在已经完成两个文件的操作了,够长了,分个页,请点击下一页。