- 1、本文档共19页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Sakai与教务系统整合方案-Confluence
SAKAI与教务系统整合方案 TJU-SAKAI-GROUP 天津大学 赵满坤 zmk@ 2014.06.27 哈尔滨 动机 利于用户管理 方便教师创建课程站点 动机 选课学生自动加入课程站点 完全自动化,不需要管理员再对数据进行定期维护 任务 数据导入 将用户信息、学期信息、学院信息、课程信息、选课信息从教务系统中导入到Sakai本地数据库 数据同步更新 应对加入新的注册学生或教师、加入新的课程及班级、学生选课退课等操作造成的教务系统数据库更新问题,需要同步到Sakai本地数据库中 总体方案 官方文档 /display/SAKDEV/Course+Management+Integration 直接操作数据库 使用API导入数据 org.sakaiproject.user.cover.* (kernel) org.sakaiproject.coursemanagement.api.* (edu-service) 具体方法 Sakai提供的Webservices组件 简单方便,但效率不高 适合小规模的数据导入或修改 定时任务做增量更新 Quartz webservices.allowlogin=true webservices.allow = .* 具体方法 按需更新(实时):将信息导入过程作为用户操作的响应动作(Action) TJU方案:按需更新为主,Webservices和定时更新为辅 详细设计 按需将数据导入 本地服务器 (Sakai Server) 教务系统 (Official System) Check a trigger 已存在 返回 不存在 用户登录流程 详细设计 按需更新触发条件 用户登录 教师新建站点 站点信息-编辑学生名单 详细设计 数据同步 定时计划任务:每日凌晨3点更新Sakai数据库中本学期相关的选课名单 手动更新:教师可选择选课名单进行实时名单更新 Sakai与教务系统通信 问题 Sakai数据库与教务系统数据库的差异:MySQL与Oracle,UTF8与GBK 时效性问题:保证Sakai数据库与教务系统及时同步 权限问题:控制Sakai服务器对教务系统数据库的访问权限,仅获取必须数据,不可修改 Sakai与教务系统通信 解决方案 中间库 Webservice访问接口 Sakai数据库 中间库 教务系统数据库 增量更新 API更新 教务系统数据库 API更新 Sakai数据库 Webservices服务 String courseList = http://121.193.xxx.xx/Teaching/services/SAKAI/getTermCourseListByTeacherId?term=12131teacherId=997127; CM API使用 CM API使用 org.sakaiproject.coursemanagement.api. CourseManagementAdministration //创建学期 createAcademicSession(termId,x,x,x,x); //设置当前有效学期 setCurrentAcademicSessions(termList); //创建学院课程集合 createCourseSet(courseSetEid,x,x,x,x); //创建课程 createCanonicalCourse(CanonicalCourseEid,x,x); //设置课程与学院关系 addCanonicalCourseToCourseSet(courseSetEid,CanonicalCourseEid); //创建教师的课程 createCourseOffering(courseOfferingEid,x,x,x,termId,CanonicalCourseEid,x,x); //将CourseOffering与学院的CourseSet关联起来 addCourseOfferingToCourseSet(courseSetEid,courseOfferingEid); CM API使用 //给教师赋予I的角色,I在课程站点里指Instructor这个角色, //具体对应关系参见:providers/component/src/webapp/WEB-INF/components.xml addOrUpdateCourseOfferingMembership(teacherId,I, courseOfferingEid,x); FOR:每个平行班 ???? //创建平行班 ???? //创建班级参与者集合 ????createEnrollmentSet(enrollmentSetEid,x,x
您可能关注的文档
- 1070930反毒宣导资料-凤山商工.PPT
- 20080826师资培育与教育发展-台中教育大学.PPT
- 2010115基地公共科目-复旦大学附属肿瘤医院.PPT
- 2012012特色创建工作方案-宁波第二医院.DOC
- 2018029武汉财政学校会计实训室.DOC
- 2018年下半年上海金山区公共场所随机监督抽查结果.DOC
- 2018年中考化学考点梳理三爱护水资源-VCM仿真.DOC
- 2018年暑假法国优秀硕士暑期学校项目列表.DOC
- 2018年第6期-东城区图书馆.DOC
- 2018年黄冈重大专项项目申报书.DOC
- 2023年证券从业之证券市场基本法律法规考前冲刺模拟考试试卷附答案详解.docx
- 2023年机械员之机械员基础知识通关测试卷提供答案解析.docx
- 投资项目管理师之投资建设项目实施通关模拟卷附答案详解.docx
- 2023年教师资格之中学生物学科知识与教学能力通关模拟题库附答案详解.docx
- 2022-2023年检验类之临床医学检验技术(师)综合提升模拟卷和答案.docx
- 2023年教师资格之幼儿综合素质通关练习题库提供答案解析.docx
- 教师资格之中学综合素质考前冲刺试卷包括详细解答.docx
- 一级造价师之建设工程技术与计量(交通)练习题和答案.docx
- 2023年教师资格之中学英语学科知识与教学能力测试卷.docx
- 2023年注册工程师之公共基础综合提升模拟题库和答案.docx
文档评论(0)