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 条评论
登录 后参与评论

相关文章

来自专栏简书专栏

mysql必知必会

数据库是按照数据结构来组织、存储和管理数据的仓库,它产生于距今。 六十多年前,随着信息技术和市场的发展,特别是二十世纪九十年代以后,数据管理不再仅仅是存储和管...

631
来自专栏Albert陈凯

Hbase二级索引

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

3704
来自专栏北京马哥教育

TokuDB的特点验证

随着数据量越来越大,越来越频繁的遇到需要进行结构拆分的情况,每一次拆分都耗时很久,并且需要多方配合,非常的不想搞这个事情。于是在@zolker的提醒...

3037
来自专栏码神联盟

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

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

3216
来自专栏带你撸出一手好代码

sql连接查询中on筛选与where筛选的区别

sql查询这个东西, 要说它简单, 可以很简单, 通常情况下只需使用增删查改配合编程语言的逻辑表达能力,就能实现所有功能。 但是增删查改并不能代表sql语句的所...

3288
来自专栏Hadoop数据仓库

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

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

1907
来自专栏性能与架构

Kafka 流数据 SQL 引擎 -- KSQL

KSQL 是什么? KSQL 是一个 Kafka 的 SQL 引擎,可以让我们在流数据上持续执行 SQL 查询 例如,有一个用户点击流的topic,和一个可持续...

3816
来自专栏数据和云

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

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

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

物化视图自动刷新的碰壁(r7笔记第61天)

今天和开发的同事讨论一个问题,他们说source 1的环境中存在一个表,现在希望目标环境target 1和target 2中都需要用到这部分的数据。 ? 对...

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

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

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

3497

扫码关注云+社区