Meidawiki 配置

为coder建立了一个“编程百科”http://codingwiki.info,codingwiki采用mediawiki,这里记录详细的配置:

codingwiki编程百科站点是一个为Coder而建的关于编程(Coding)的wiki站点,我们期望“新人在这里可以学习提高,熟手在这里可以跨越瓶颈,迈向高手之路”。 codingwiki编程百科 的内容来自国外优秀的Coding博客或者 Coding技术站点。它属于非盈利性的,我们在这里创作、改进、收集和整理 编程(Coding)相关的中文文档,当然,我们热烈欢迎您也参与我们的翻译,您可以点击帮助了解相关信息。 如果想要与他人交流获得问题解答(多数情况作为最后选项,既然您已经来了这里:P),请参见建议的通讯方法

1、首先,配置logo

# logo $wgLogo = "/logo.png";

2、配置时间

## Timezone Settings $wgLocaltimezone = "Asia/Shanghai"; $oldtz = getenv("TZ"); putenv("TZ=$wgLocaltimezone"); $wgLocalTZoffset = date("Z") / 3600; putenv("TZ=$oldtz");

3、配置上传

#开启图片上传 $wgEnableUploads= true;

#上传文件类型 $wgFileExtensions = array( 'png', 'gif', 'jpg', 'jpeg','doc','ppt','pdf' );

4、urlrewrite Url重写

#url REWRITE $wgScriptPath        = ""; $wgArticlePath      = "/$1"; $wgUsePathInfo      = true; $wgScriptExtension  = ".php";

服务器采用nginx,添加下面的配置

location / {
		if (!-e $request_filename) {
			rewrite ^/([^?]*)(?:\?(.*))? /index.php?title=$1&$2 last;
		}
	}

5、添加常用扩展

#SyntaxHighlight require_once("$IP/extensions/SyntaxHighlight_GeSHi/SyntaxHighlight_GeSHi.php");

#ParserFunctions require_once( "$IP/extensions/ParserFunctions/ParserFunctions.php" );

6、实现自己的扩展——找出wiki最热条目和最新条目,以及热门分类,通过扩展tag实现

直接贴代码,详细效果见

http://codingwiki.info/%E9%A6%96%E9%A1%B5

http://codingwiki.info/%E5%88%86%E7%B1%BB:.NET

<?php
$wgHooks['ParserFirstCallInit'][] = 'efCodingWikiTagParserInit';
 
function efCodingWikiTagParserInit( &$parser ) {
        $parser->setHook( 'hotpages', 'efHotPageRender' );
		$parser->setHook( 'hotcategories', 'efHotCategoryRender' );
		$parser->setHook( 'newpage', 'efNewPageRender' );
        return true;
}

function makePageListItem( $row ) {
		global $wgUser;
		$title = Title::makeTitleSafe( $row->page_namespace, $row->page_title );
		if( !is_null( $title ) ) {
			$skin = $wgUser->getSkin();
			$link = $row->page_is_redirect
					? '<span class="allpagesredirect">' . $skin->makeKnownLinkObj( $title ) . '</span>'
					: $skin->makeKnownLinkObj( $title );
			return( "<li>{$link}({$row->page_counter}次)</li>\n" );
		} else {
			return( "<!-- Invalid title " . htmlspecialchars( $row->page_title ) . " in namespace " . htmlspecialchars( $row->page_namespace ) . " -->\n" );
		}
}
	
function efHotPageRender( $input, $args, $parser, $frame ) {
		global $wgRequest, $wgOut, $wgContLang, $wgLang;
		$dbr = wfGetDB( DB_SLAVE );
		$limit = isset($args["count"])?$args["count"]:10;
		$res = null;		
		if(isset($args["category"])){
			$res = $dbr->select(
				array('page','categorylinks'),
				'*',
				array('cl_to' => "{$args['category']}"),
				__METHOD__,
				array(
					'ORDER BY' => 'page_counter DESC',
					'LIMIT' => "$limit",
					'OFFSET' => '0',
				),
				array( 'categorylinks' => array('JOIN','page_id=cl_from') ) 
			);
		}else{
			$res = $dbr->select(
				'page',
				array(
					'page_namespace',
					'page_title',
					'page_counter',
					'page_is_redirect'
				),
				array('page_namespace'=>'0'),
				__METHOD__,
				array(
					'ORDER BY' => 'page_counter DESC',
					'LIMIT' => "$limit",
					'OFFSET' => '0',
				)
			);
		}
		$result = "<ul>";
		foreach ( $res as $row ) {
				$result .= makePageListItem( $row );
		}	
		$result .= "</ul>";		
        return $result;
}

function efHotCategoryRender( $input, $args, $parser, $frame ) {
		global $wgRequest, $wgOut, $wgContLang, $wgLang;
		$dbr = wfGetDB( DB_SLAVE );
		$limit = isset($args["count"])?$args["count"]:10;
		$res = $dbr->select(
			'category',
			'*',
			array(),
			__METHOD__,
			array(
				'ORDER BY' => 'cat_pages DESC',
				'LIMIT' => "$limit",
				'OFFSET' => '0',
			)
		);
		$result = "<ul>";
		foreach ( $res as $row ) {
				$result.= "<li><a href='/分类:{$row->cat_title}'>{$row->cat_title}</a>(<a href='/分类:{$row->cat_title}'>{$row->cat_pages}</a>)</li>\n" ;
		}	
		$result .= "</ul>";		
        return $result;
}

function efNewPageRender( $input, $args, $parser, $frame ) {
		global $wgRequest, $wgOut, $wgContLang, $wgLang;
		$dbr = wfGetDB( DB_SLAVE );
		$limit = isset($args["count"])?$args["count"]:10;
		$res = null;
		
		if(isset($args["category"])){
				$res = $dbr->select(
					array('page','categorylinks'),
				'*',
				array('cl_to' => "{$args['category']}"),
				__METHOD__,
				array(
					'ORDER BY' => 'page_id DESC',
					'LIMIT' => "$limit",
					'OFFSET' => '0',
				),
				array( 'categorylinks' => array('JOIN','page_id=cl_from') ) 
			);
		}else{
			$res = $dbr->select(
				'page',
				array(
					'page_namespace',
					'page_title',
					'page_counter',
					'page_is_redirect'
				),
				array(),
				__METHOD__,
				array(
					'ORDER BY' => 'page_id DESC',
					'LIMIT' => "$limit",
					'OFFSET' => '0',
				)
			);
		}
		$result = "<ul>";
		foreach ( $res as $row ) {
				$result .= makePageListItem( $row );
		}	
		$result .= "</ul>";		
        return $result;
}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏草根专栏

Entity Framework Core 2.1,添加种子数据

EFCore 2.1出来有一段时间了,里面的新功能还没怎么用,今天研究下如何使用EF Core 2.1添加种子数据。

1261
来自专栏Albert陈凯

Hbase二级索引

二级索引与索引Join是多数业务系统要求存储引擎提供的基本特性,RDBMS早已支持,NOSQL阵营也在摸索着符合自身特点的最佳解决方案。这篇文章会以Hbase做...

4554
来自专栏Hadoop数据仓库

HAWQ技术解析(十七) —— 最佳实践

一、HAWQ参数配置最佳实践 (原文地址:http://hawq.incubator.apache.org/docs/userguide/2.1.0.0-inc...

2057
来自专栏杨建荣的学习笔记

SQL Monitor,你值得掌握的一个特性(r10笔记第29天)

对于线上的SQL语句,看着执行计划cost还不错,但是实际执行的时候效果却有千壤之别,这是为什么呢? 对于一个庞大的SQL语句,看着得到的执行计...

3547
来自专栏张善友的专栏

SQLite vs MySQL vs PostgreSQL:关系型数据库比较

自1970年埃德加·科德提出关系模型之后,关系型数据库便开始出现,经过了40多年的演化,如今的关系型数据库种类繁多,功能强大,使用广泛。面对如此之多的关系型数据...

2275
来自专栏人工智能LeadAI

ElasticSearch优化系列三:索引过程

大家可能会遇到索引数据比较慢的过程。其实明白索引的原理就可以有针对性的进行优化。ES索引的过程到相对Lucene的索引过程多了分布式数据的扩展,而这ES主要是用...

3869

所有您需要了解的关于Elasticsearch 5.0:索引管理

我们看到两种主要的Elasticsearch索引使用模式 - 全局索引和滚动索引。多年来,Elasticsearch增加了一些功能,可以极大地改善这些模式的工作...

3813
来自专栏杨建荣的学习笔记

通过Snapshot Standby来精确评估SQL性能 (r9笔记第73天)

最近处理了一个需求,比较紧急,映射到数据库层面是需要更新17万id的值,听起来是不少,根据数据架构进行了分析,发现目前是做了分库分表的方式,所以这17万的id在...

3113
来自专栏数据和云

那些年,我们处理过的SQL问题

作者 | 郑林松,朗新科技股份有限公司数据库技术专家,从业10多年,主要服务移动运营商客户,电力客户,证券客户,制造业客户。精通 Oracle 性能优化,故障诊...

972
来自专栏码神联盟

碎片化 | 第四阶段-48-hibernate概述和配置-视频

本套视频从Java基础到架构模式以及AI算法,整体视频以“碎片化”学习的模式,提供给大家 ,并配备实际项目为案例,让大家在坐车、吃饭、午休、蹲坑的时候,都可以学...

3256

扫码关注云+社区