Moodle作為一個(gè)主流的開源網(wǎng)絡(luò)課程管理系統(tǒng),以其簡(jiǎn)單而清晰的使用方式和靈活的擴(kuò)展空間贏得了多數(shù)人的青睞。它解決了大部分信息化學(xué)習(xí)和課程管理的 共同問(wèn)題(課程設(shè)計(jì)、發(fā)布、組織、作業(yè)、測(cè)試、統(tǒng)計(jì)、評(píng)價(jià)等) ,能夠不加任何修改就能夠進(jìn)行實(shí)際應(yīng)用。<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com: office: office" />
Moodle數(shù)據(jù)庫(kù)模型
Moodle的數(shù)據(jù)庫(kù)模型經(jīng)過(guò)幾年的發(fā)展已經(jīng)很復(fù)雜,為了減少這種復(fù)雜關(guān)系帶來(lái)的混亂,它采用了這樣的命名方式。如: mdl_course_categories,其中“mdl_”是所有系統(tǒng)表格的前綴,course代表屬于course的模塊,categroies代 表課程分類表,這樣既可以保證清晰的表述,又可以避免不同模塊之間數(shù)據(jù)表格的重名。可以利用DBDesigner4(一種免費(fèi)的數(shù)據(jù)庫(kù)設(shè)計(jì)軟件,可以從
http://fabforce.net/dbdesigner4/
下載)將Moodle數(shù)據(jù)庫(kù)導(dǎo)出成XML文件,并進(jìn)行分析。Moodle提供了ADODB數(shù)據(jù)訪問(wèn)抽象層來(lái)進(jìn)行數(shù)據(jù)庫(kù)的訪問(wèn),所以我們不需要直接編寫訪問(wèn)數(shù)據(jù)庫(kù)的代碼,只要通過(guò)抽象層的方法即可。
Moodle data(Moodle數(shù)據(jù))
Moodle數(shù)據(jù)是用戶上傳內(nèi)容的文件存儲(chǔ)位置記錄,Moodle數(shù)據(jù)也存儲(chǔ)登錄到該系統(tǒng)用戶的會(huì)話數(shù)據(jù)(sessions data),如果基于文件的會(huì)話(sessions)正在使用。
Moodle數(shù)據(jù)在文件夾中的組織結(jié)構(gòu)由用戶或課程組成。每門課程有一個(gè)文件夾,命名為一個(gè)整數(shù)值。這個(gè)整數(shù)值即為這門課程的內(nèi)部數(shù)據(jù)庫(kù)的ID。
Moodle 2.0使用一種全新的組織模式來(lái)組織用戶上傳的文件,這是基于哈希算法。
Moodle主要目錄結(jié)構(gòu)
admin:
系統(tǒng)管理的代碼
包含控制管理用戶界面的PHP文件。其中包括一個(gè)cron.php:作為批處理進(jìn)程執(zhí)行系統(tǒng)維護(hù)任務(wù),如消息傳遞和過(guò)程中備份,同時(shí)它也用于處理批量操作
auth:
驗(yàn)證用戶基本模塊及擴(kuò)展模塊
包含所有Moodle的身份驗(yàn)證模塊。“auth”目錄里每一個(gè)子目錄就是一個(gè)身份驗(yàn)證模塊。這些認(rèn)證模塊控制創(chuàng)建用戶,用戶配置文件數(shù)據(jù),和用戶訪問(wèn)系統(tǒng)權(quán)限。
backup:
課程備份代碼
包含課程備份的核心功能:備份,恢復(fù)和導(dǎo)入的課程。
blocks:
界面板塊基本模塊及擴(kuò)展模塊
板塊用于顯示信息框,可以在Moodle頁(yè)面的右側(cè)或左側(cè)欄。這是最簡(jiǎn)單的可擴(kuò)展的模塊設(shè)計(jì)類型。
course:
顯示和管理課程的代碼
這是Moodle重要的組成部分,Moodle是圍繞課程組織的。開發(fā)人員最有可能修改或增加課程的格式和報(bào)告。定制課程格式,可用于改變課程的布局。
enrol:
注冊(cè)模塊
包含所有的Moodle的注冊(cè)模塊。注冊(cè)模塊控制課程級(jí)角色分配(注冊(cè))的創(chuàng)建和管理。
files:
顯示和管理上傳文件的代碼
該文件組件控制文件的上傳,訪問(wèn)控制,并查看文件。文件管理在Moodle2.0中改寫變化很大。Moodle的2.0將允許外部文件庫(kù)中的文件存儲(chǔ)和使用,如:Alfresco, Box.net, and Google Docs等。
filter:
過(guò)濾器
過(guò)濾器系統(tǒng)是關(guān)聯(lián)從數(shù)據(jù)庫(kù)到頁(yè)面創(chuàng)建用戶輸入的內(nèi)容。過(guò)濾器匹配和修改頁(yè)面顯示之前。它需要考慮到性能的影響,需要認(rèn)真制定。
lang:語(yǔ)言模塊
包含核心系統(tǒng)的語(yǔ)言字符串。語(yǔ)言字符串映射也都存儲(chǔ)在Moodle的數(shù)據(jù)lang文件夾。不同語(yǔ)言的對(duì)應(yīng)文本,每個(gè)目錄表示一種語(yǔ)言,并且和具體的模塊對(duì)應(yīng)。
lib:
Moodle的核心代碼庫(kù)
包含的核心系統(tǒng)庫(kù)函數(shù)。當(dāng)我們開發(fā)和定制模塊時(shí),我們將使用在此文件夾中定義的類和功能。
mod:
Moodle的基本模塊和擴(kuò)展模塊
包含的活動(dòng)模塊(activity modules),如assignment, quiz, wiki, forum, and lesson模塊。學(xué)習(xí)活動(dòng)是使用Moodle任何課程的核心功能。活動(dòng)模塊(activity modules)比塊(blocks)創(chuàng)建更具挑戰(zhàn)性和復(fù)雜性,因?yàn)樗鼈冊(cè)O(shè)計(jì)到備份,還原,和存儲(chǔ)等級(jí)等內(nèi)容。
my:
我的課程
它提供了一個(gè)上市的分配給學(xué)習(xí)者的課程列表,包括即將到來(lái)的課程活動(dòng)的總結(jié)。用戶也可以添加和刪除他或她的門戶網(wǎng)站頁(yè)面上的塊。“my”提供了一個(gè)很好的位置,以最小的核心變化到Moodle顯示自定義信息。例如,我們利用“my”作為一個(gè)定制許多項(xiàng)目的面板位置。
theme:
站點(diǎn)的主題包,控制站點(diǎn)的樣式
包含了所有的內(nèi)置的Moodle主題和任何自定義主題。每個(gè)主題都有其自己的文件夾。
?
其它還有:
calendar:維護(hù)及顯示日歷的代碼
doc:Moodle的幫助文檔
login:登錄及賬號(hào)創(chuàng)建代碼
pix:站點(diǎn)的圖片
user:顯示和管理用戶
onfig.php包含基本的系統(tǒng)設(shè)置,一般在第一次安轉(zhuǎn)時(shí)設(shè)置
ns tall.php安裝站點(diǎn)
vers ion版本控制
index.php站點(diǎn)首頁(yè)
開發(fā)概要詳見:
http://docs.moodle.org/archive/zh/index.php?title=%E5%BC%80%E5%8F%91:%E6%A6%82%E8%A6%81&variant=zh-cn
?
1、2個(gè)很有用的關(guān)于path的變量
$CFG->dirroot??指向moodle root folder
$CFG->libdir 指向moodle root folder下的lib folder
例如:若要include moodle_home/lib下的lib library,可以
require_once($CFG->libdir . '/blocklib.php');
?
optional_param & required_param
這2個(gè)是moodle特有的function,用來(lái)代替php自身的從$GET, $POST, $COOKIE中獲取參數(shù)值。
required_param函數(shù)則要求必須要所要的參數(shù),而optional_param則不需要一定存在所要的參數(shù)。
這兩個(gè)函數(shù)都會(huì)驗(yàn)證指定的參數(shù)為基礎(chǔ)的數(shù)據(jù),如果是預(yù)期以外的數(shù)據(jù)通過(guò)就會(huì)產(chǎn)生錯(cuò)誤或警告。(詳細(xì)描述上網(wǎng)查)
例:
$id = optional_param('id', 0, PARAM_INT); $name = optional_param('name', '', PARAM_RAW);
第1個(gè)參數(shù)是param name,第2個(gè)參數(shù)是缺省值
?
2、Moodle的入口點(diǎn)
/index.php: The front page(站點(diǎn)首頁(yè))
/login/index.php: The login page(登錄頁(yè))
/admin/index.php: The main administration page(管理頁(yè))
/course/view.php: A course page(課程頁(yè))
/mod/*/view.php: A module page(模塊頁(yè))
如:http://localhost/course/view.php?id=23
3、設(shè)置與安裝:config.php & setup.php
所有的入口點(diǎn)php文件的第一行都是
require_once(‘../config.php’)
?
config.php文件執(zhí)行在全局變量$CFG里設(shè)置的初始參數(shù)
$CFG中的信息包括:database數(shù)據(jù)庫(kù),網(wǎng)頁(yè)的URL,script腳本目錄,以及數(shù)據(jù)存儲(chǔ)目錄的定義設(shè)置。
注意:config.php includes /lib/setup.php
setup.php設(shè)置所有所需的完整的執(zhí)行環(huán)境的初步方案。這包括定義其他幾個(gè)重要的全局變量,包括: $SESSION, $COURSE, $THEME, and $db。
Setup.php會(huì)根據(jù)設(shè)置在config.php中定義:建立和連接數(shù)據(jù)庫(kù)的設(shè)置。
Moodle使用ADOdb來(lái)進(jìn)行數(shù)據(jù)庫(kù)操作,Moodle使用的默認(rèn)數(shù)據(jù)庫(kù)是MySQL, 是一個(gè)開源的關(guān)系數(shù)據(jù)庫(kù)系統(tǒng)。為了可以使用其他的關(guān)系數(shù)據(jù)庫(kù)服務(wù)器, Moodle使用了ADODB將數(shù)據(jù)層抽象, 這樣Moodle就可以使用諸如MS SQL Server、 Oracle等關(guān)系型數(shù)據(jù)庫(kù)。使用ADOdb你需要include /lib/adodb/adodb.inc.php
setup.php還會(huì)inlude一些常用的庫(kù),還會(huì)設(shè)置其他一些關(guān)鍵的全局變量,從數(shù)據(jù)庫(kù)中加載配置變量,設(shè)置了緩存(caching),會(huì)話 (sessions),環(huán)境變量(environment variables),主題(themes),語(yǔ)言(language),和區(qū)域(locales)設(shè)置。
4、get_record function
該函數(shù)是從database里獲取record
? ? 例:
if (! ($course = get_record('course', 'id', $id)) ) { error('Invalid course id'); }
5、require_login function
該函數(shù)是用來(lái)檢查用戶是否已登錄到網(wǎng)站或課程 (有些課程可能設(shè)置成不需要login). 如果需要登錄網(wǎng)站,但用戶又沒有登錄,就重定向到登錄頁(yè)面。如果用戶已經(jīng)登錄,他正在嘗試訪問(wèn)課程,但又沒有注冊(cè)到該課程,那么執(zhí)行該函數(shù)就會(huì)將用戶重定向到選課注冊(cè)頁(yè)面。
例:
require_login($course);
6、在Moodle里的顯示函數(shù)
輸出html header的函數(shù)有2個(gè)
print_header
print_header_simple
上面函數(shù)用于輸出html header, 包括主題信息和所要的javascript文件等
例:
$PAGE->print_header(get_string('course').': %fullname%', NULL, '', $bodytags);
?
輸出html body是由course的特定format來(lái)處理。首先要先include 該課程的format的php文件。
require($CFG->dirroot .'/course/format/'. $course->format .'/ format.php');
?
? ? 例如,如果課程使用topics format,就會(huì)include /course/format/topics/format.php。
該format.php用于處理特定的course page的輸出,包括the blocks and main content。
print_footer函數(shù)用于輸出footer
例:
print_footer(NULL, $course);
?
7、配置Moodle
Moodle的設(shè)置分別處于3個(gè)地方:
直接在config.php里hard code。
mdl_config table。可以通過(guò)administrative code and interfaces進(jìn)行控制
mdl_config_plugins table。主要是存儲(chǔ)來(lái)自各個(gè)plugin的設(shè)置。可以通過(guò)plugin administration來(lái)進(jìn)行控制。
所有的配置信息都存在全局變量$CFG里(plugin的設(shè)置則會(huì)放在plugin變量里)。
例如:$CFG->theme包含您網(wǎng)站的主題選定的文本名稱。
? ? config.php一開始會(huì)調(diào)用unset($CFG);來(lái)保證在config.php and setup.php之前清除所有的設(shè)置。
? ? 在config.php里,包含下列的設(shè)置:
$CFG->dbtype = 'mysql'; $CFG->dbhost = 'localhost'; $CFG->dbname = 'moodle'; $CFG->dbuser = 'xxx'; $CFG->dbpass = 'xxx'; $CFG->dbpersist = false; $CFG->prefix = 'mdl_'; $CFG->wwwroot = 'http://xxxx:8080/moodle'; $CFG->dirroot = 'E:/develop/Zend/Apache2/htdocs/moodle'; $CFG->dataroot = 'E:/develop/Zend/Apache2/htdocs/moodledata'; $CFG->admin = 'admin'; $CFG->directorypermissions = xxx; // try 02777 on a server in Safe Mode $CFG->passwordsaltmain = 'xxxx';
?
? ? 這是config.php最必須的設(shè)置,如果想在config.php里進(jìn)行更多的設(shè)置,則要參看config-dist.php的所有的配置設(shè)置,然后修改config.php。
? ?上述設(shè)置你可以直接在config.php里修改。
? ? 除了config.php之外的所有其他設(shè)置都存儲(chǔ)在database的mdl_config 表and mdl_config_plugins 表里。
? ? 那么moodle何時(shí)把這些來(lái)自database的設(shè)置賦給$CFG?
就是在config.php里include了lib/setup.php,setup.php調(diào)用了
$CFG = get_config();
??? ?? ???
? ?來(lái)執(zhí)行。get_config()函數(shù)來(lái)自/lib/moodlelib.php庫(kù)文件
? ?注意:get_config函數(shù)不會(huì)對(duì)于在調(diào)用之前已經(jīng)存在的設(shè)置進(jìn)行覆蓋。(will not overwrite any $CFG setting that has already been set)。即它不會(huì)覆蓋config.php里的設(shè)置. 這意味著你可以在config.php里硬編碼你希望的設(shè)置,在config.php最后一行include了setup.php,但來(lái)自 database的設(shè)置如果與config.php里的設(shè)置同名,則不會(huì)覆蓋它。
?
對(duì)configuration進(jìn)行修改是通過(guò)set_config函數(shù)。該函數(shù)會(huì)以(name、value、plugin name (optional))作為參數(shù)。如果不使用第三個(gè)參數(shù),那么set_confg就會(huì)把設(shè)置存儲(chǔ)在mdl_config 表,如果使用這個(gè)參數(shù),則存在mdl_config_plugins表里。
? ? 我們開發(fā)的通常是插件 (modules, blocks, and so on)。在開發(fā)過(guò)程中,如果你想添加設(shè)置的話,強(qiáng)烈建議使用mdl_config_plugins表來(lái)存儲(chǔ),即調(diào)用set_config時(shí)要用到 plugin name參數(shù)。這是因?yàn)椋涸O(shè)置的name必須唯一。如果你想添加設(shè)置到mdl_config表里,那么就有可能該設(shè)置的name已經(jīng)存在,產(chǎn)生沖突。而對(duì) 于mdl_config_plugins表,它多了一個(gè)”plugin” field,這就使你只要保證該設(shè)置的name在該plugin里是唯一的即可。
? ? 注意:plugin的設(shè)置則會(huì)放在plugin變量里,而不是存在$CFG里。
通常,我們都是通過(guò)administration interfaces來(lái)set configuration variables。絕對(duì)多數(shù)的Moodle configuration variables都可以在Site Administration block (用admin login后的home page會(huì)看到它)里進(jìn)行設(shè)置。
?
8、Moodle API
絕大多數(shù)的api都放在lib目錄下,該目錄下的library php的命名方式是
? ? [function]lib.php
? ? 例如 textlib.php and weblib.php
? ? 幾乎所有的核心庫(kù)是包含的,當(dāng)您通過(guò)config.php加載/lib/setup.php將其列入。
?
最常用的library有
???moodlelib.php
???weblib.php
???dmllib.php
???accesslib.php
???grouplib.php
?
Moodle還會(huì)用到一些開源的library,如
???PEAR
???ADOdb
???YUI
???XMLDB
?
訪問(wèn)控制,登錄和角色
Access control, logins, and roles Moodle的登錄函數(shù)使用PHP的'cookie'的功能設(shè)置成當(dāng)前會(huì)話的Cookie。
?
1、六種分配級(jí)別權(quán)限:
? ?? ???·site/global(網(wǎng)站全局)
? ?? ???·course category(課程類)
? ?? ???·course(課程)
? ?? ???·blocks(塊)
? ?? ???·activities(活動(dòng))
? ?? ???·user(用戶)
? ?? ???·front page(首頁(yè))
?
Contexts是與定義的context水平相關(guān)的系統(tǒng)中的元素,Context定義在/lib/accesslib.php里
define('CONTEXT_SYSTEM', 10); define('CONTEXT_USER', 30); define('CONTEXT_COURSECAT', 40); define('CONTEXT_COURSE', 50); define('CONTEXT_GROUP', 60); define('CONTEXT_MODULE', 70); define('CONTEXT_BLOCK', 80);
“System”context只有一個(gè),其他的則有許多個(gè),如”Course”context,“User”context等。
2、有7個(gè)內(nèi)置的角色(role)
? ???·administrator(管理員):系統(tǒng)管理員擁有任何權(quán)限,操作任何課程。
? ???·teacher(教師):教師可以在負(fù)責(zé)的課程中做任何事,包括更改活動(dòng)和為學(xué)生評(píng)分。
? ???·non-editing teacher(無(wú)編輯權(quán)教師):可以在課程中教授和給學(xué)生們打分,但是無(wú)法改變活動(dòng)內(nèi)容。
? ???·student(學(xué)生):可參加一門課程,通常擁有較少的特權(quán)。
? ???·course creator(課程創(chuàng)建者):可以創(chuàng)建課程,并可以限制在一個(gè)課程類別里。
? ???·authenticated user(認(rèn)證的用戶):任何登錄的用戶都有這個(gè)角色
? ???·guest(訪客):非登錄用戶擁有最小的權(quán)限,而且通常不能在任何地方輸入文本。
? ???這些role都可以分配給上面的一個(gè)或多個(gè)context。
? ? 每個(gè)用戶可以擁有多個(gè)角色,這些角色繼承所有適用于從用戶訪問(wèn)請(qǐng)求的context級(jí)別的權(quán)限。
Capabilities are associated with context levels, and are specific access rules that can be granted to roles.
Examples of capabilities are:
? ? ·moodle/site:manageblocks: Can manage blocks at the site context level
? ? ·moodle/user:viewdetails: Can view details of a user at the user context level
? ? ·moodle/course:view: Can view a course at the course context level
? ?每一個(gè)capability都可以assign給下列4個(gè)訪問(wèn)權(quán)限級(jí)別(access levels)的其中一個(gè):
? ? ·Not Set(沒有設(shè)置)
? ? ·Allow(允許)
? ? ·Prohibit(禁止)
? ? ·Prevent(避免)
? ?注意:開發(fā)者可以通過(guò)創(chuàng)建capabilities來(lái)控制訪問(wèn)我們的新功能。
? ?總結(jié)來(lái)說(shuō):
? ???·Contexts are specific elements in Moodle(Contexts是Moodle中的特定元素)
? ???·Roles are associated with all contexts(Roles是與所有的contexts關(guān)聯(lián)的)
? ???·Capabilities are assigned to roles in a given context(Capabilities都被分配給特定context下的角色)
? ???·Users are assigned to roles in a given context(用戶都被分配給特定context下的角色)
? ?? ?普通系統(tǒng)使用User, Role, Capability就OK了,為什么moodle還要加多一個(gè)context?
? ?? ?這是因?yàn)橥粋€(gè)user在不同的context的role不同,比如在system context,user是admin role,而他在course“foo”里是instructor role(導(dǎo)師角色)
?
3、每個(gè)user role在不同的context里的capability都不同。
? ?獲取context對(duì)象的函數(shù)是get_context_instance()。
例:
#獲取system context對(duì)象 $context = get_context_instance(CONTEXT_SYSTEM); #獲取當(dāng)前course的context global $COURSE; $context = get_context_instance(CONTEXT_COURSE, $COURSE->id);
?
獲取context之后,下列2個(gè)函數(shù)是用來(lái)check當(dāng)前l(fā)ogin的user在該context里是否有所指定的capability。
? ? ·require_capability測(cè)試當(dāng)前用戶的capabilities,看看他們是否在指定context內(nèi)有指定的capability,如果他們沒有,頁(yè)面就重定向到一個(gè)錯(cuò)誤頁(yè)面。
? ? ·has_capability功能與require_capability類似,但不會(huì)重定向到錯(cuò)誤頁(yè)面,而是return true or false
??例:
$context = get_context_instance(CONTEXT_SYSTEM); require_capability('moodle/site:doanything', $context);
?
? ?上面的例子是檢查當(dāng)前用戶在system context里是否有'moodle/site:doanything'的capability。
? ?如何為你的moodle plugin/module自定義capability?
? ?在plugin/module的root目錄下創(chuàng)建一個(gè)db目錄,然后在db目錄下創(chuàng)建一個(gè)access.php,該文件用來(lái)定義capability。
? ?下例是在helloworld block里定義一個(gè)block/helloworld:view capability,該capability的type是read,該capability是屬于system context level里,并設(shè)置只有admin role user擁有該capability,其他role沒有。
代碼如下:
<?php $block_helloworld_capabilities = array( 'block/helloworld:view' => array( 'captype' => 'read', 'contextlevel' => CONTEXT_SYSTEM, 'legacy' => array( 'guest' => CAP_PREVENT, 'student' => CAP_PREVENT, 'teacher' => CAP_PREVENT, 'editingteacher' => CAP_PREVENT, 'coursecreator' => CAP_PREVENT, 'admin' => CAP_ALLOW ) ) ); ?>
?
? ?注意:該capability適用于任何使用了該block的地方。無(wú)論你是把該block加到home page,還是admin page,還是My Moodle page,還是course page,該capability都適用。但由于該capability是定義在system context level,只有那些在system context level具有admin role的user才能夠看到這個(gè)block。
接下來(lái)將學(xué)習(xí)5種類型的Moodle plugin的開發(fā):
·block
·filter
·activity module
·theme
·course format
?
來(lái)源: http://www.aieln.com/thread-4899-1-1.html
?
?
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
