项目简介

本项目是与@nameoverflow同学合作。该同学负责vue 前端的设计,我负责php后台的接口实现。本文将主要记录php后台。

本项目的Github地址:https://github.com/He11oLiu/Student_Information_management_system

本项目仅作为尝试用途,很多功能尚未实现。

使用PHP连接MySQL数据库

利用MySQLi接口库来连接MySQL数据库,连接测试如下:

<html>
<body>
<?php
//phpinfo();
$con = mysqli_connect("127.0.0.1","root","","C_test");
if(!$con){
dir('Cannot connect "' . mysql_error());
}
echo "Connect Sucess!";
echo "<br/>";
$result = mysqli_query($con,"Select * from student");
while($row = mysqli_fetch_array($result)){
echo $row['student_no']." ".$row['student_name'];
echo "<br/>";
}
mysqli_close($con);
echo "Cannect Close!";
?>
</body>
</html>

数据库设计

PHP RESTful接口

服务器端PHP提供RESTful接口的框架主要如下:

<?php
session_start();
$func = $_GET['func'];
switch($func){
case 'func1':func1();break;
case 'func2':func2();break;
default: echo 'wrong func code';break;
} function func1(){
//func1 code
}
function func2(){
//func2 code
}
?>

服务器设计

.
├── adminQuery.php #管理员功能
├── loginFunc.php #登入登出控制
├── studentQuery.php #学生功能
├── teacherQuery.php #老师功能
├── test.py #测试
└── util.php

其中功能的设计大致框架如上RESTful框架所述,接口定义见接口文件。

为了防止出现越权调用接口,每个功能利用Session做了权限检测。

接口定义

学生

POST 登录

学生/loginFunc.php?func=stuLogin

老师/loginFunc.php?func=isTeacherLoggedIn

管理员/loginFunc.php?func=isTeacherLoggedIn

GET 登录信息

/loginFunc.php?func=isXXXLoggedIn 其中 XXX=Stu | Teacher | Admin

GET 成绩信息

如果用户为学生用户则只能查同班同学

为管理员则可以查任意学号

教师用户不允许使用

参数名 类型 语义
stuid(可选) String 学号,无则返回自己成绩
semid(可选) number 学期id,无则返回所有条目

返回值:

字段名 类型 语义
cname String 课程名
cno String 课程编号
teacher String 教师姓名
grade Number 成绩(百分制)

/studentQuery.php?func=stuGrade&stuid='201408010115'&semid=2

GET 个人信息

返回登录用户的个人信息

返回值:

字段名 类型 语义
sname String 学生姓名

/studentQuery.php?func=stuInfo

GET 选课列表

用户当前可用的选课列表

如果当前不能选课,返回空[]

返回值(数组):

字段名 类型 语义
cid Number 课程数据库索引号
cno String 课程编号
cname String 课程名
teacher String 任课教师

/studentQuery.php?func=stuSel

GET 可选课程

/studentQuery.php?func=courseList

返回值:

Course.idCourse,Course.Cno,Course.Cname,Course.Ccredit,Course.Cplace,Course.Cnum,Dept.Dname,Teacher.Tname

POST 选课

参数名 类型 语义
cid Number 课程索引号

返回值:

字段名 类型 语义
status Number 0为成功;其它为失败
msg String 提示信息(失败原因)

/studentQuery.php?func=selCourse&cid=3

GET 课程安排

返回用户指定学期的课程安排列表

参数名 类型 语义
seid Number 学期索引号

返回值(数组):

字段名 类型 语义
cname String 课程名
cno String 课程号
teacher String 教师名
times [Time] 时间安排列表

其中 Time 格式为

字段名 类型 语义
day Number 一周中的天序号
tstart Number 第几节课开始
tend Number 第几节课结束
wstart Number 开始周数
wend Number 结束周数
sel Number 单双周;0 为全部,1 为单周,2 为双周
loc String 上课地点

/studentQuery.php?func=courseTime

GET 学期列表

返回当前用户入学时间以后所有的学期列表

返回值(数组):

字段名 类型 语义
year String 年份
term String 春夏秋学期
seid Number 学期索引id

GET 同班同学

url:/student/studentQuery.php?func=classmate

返回值:Sno,Sname

老师

GET 课程的学生

url : /student/teacherQuery.php?func=stuGrade`

返回值: Sno,Sname,Class.Cno,Class.Cyear,Grade

GET 授课时间

url : /student/teacherQuery.php?func=courseTime

返回值:Course.Cno,Course.Cname,Time.ds,Time.Week,Time.day,Time.section,Building,Room

POST 添加学生成绩

url:/student/teacherQuery.php?func=updateGrade

POST数据内容

字段名 类型 语义
idcourseset int Courseset的索引
sno String 学生学号
grade int 学生成绩

返回值

status
0 成功
-1 不成功带msg字段

管理员

POST Add student

url:/student/adminQuery.php?func=addStu

POST数据内容:

字段名 语义
sname 姓名
sno 学号
idclass 班级 可以用getclass获取可选id
sage 年龄
ssex 性别
iddept 专业 可以用getdept获取可选dept
idsemester 学期 可以用getSemester获取可选学期

返回值

status
0 成功
-1 不成功带msg字段

GET 学期

url:/student/adminQuery.php?func=getSemester

返回值:idSemester,Semyear,Semseason

GET 班级

url:/student/adminQuery.php?func=getClass&iddept=1

iddept为获取的专业

返回值:idClass,Cno,Cyear,Dept_idDept

GET 学期

url:/student/adminQuery.php?func=getSemester

返回值:idSemester,Semyear,Semseason

测试

利用Python写了接口测试脚本,类似如下:

import urllib2
import urllib
import cookielib ##########################
# student test #
########################## print ('=========student test==========')
data = {}
data['sno'] = '201408010113'
data['spd'] = '123'
post_data = urllib.urlencode(data)
cj = cookielib.CookieJar()
opener = urllib2.build_opener(urllib2.HTTPCookieProcessor(cj))
print('Check Login Status...')
resp = opener.open("http://localhost/student/loginFunc.php?func=isStuLoggedIn")
print (resp.read() )
print ('\n')

详细见源代码。

教学服务系统设计之PHP后台设计的更多相关文章

  1. FaaS(函数即服务) + BaaS(后台即服务)

    作者 | 黄子毅(紫益) 阿里前端技术专家 导读:前端开发者是最早享受到 “Serverless” 好处的群体,因为浏览器就是一个开箱即用.甚至无需为计算付费的环境!Serverless 把前端开发体 ...

  2. WCF分布式开发步步为赢(6):WCF服务契约继承与分解设计

    上一节我们学习了WCF分布式开发步步为赢(5)服务契约与操作重载部分.今天我们来继续学习WCF服务契约继承和服务分解设计相关的知识点.WCF服务契约继承有何优势和缺点?实际项目里契约设计有什么原则和依 ...

  3. .net core 微服务之日志落盘设计

    原文:.net core 微服务之日志落盘设计 目录 1.设计目标 2.日志流程 3.串联请求事务 3.1 请求ID 3.2 处理服务器.服务 3.3 处理接口名 3.4 日志的发生时间 3.5 接口 ...

  4. 后台设计的基石:用户权限管理(RBAC)及工作流(workflow)模型

    后台产品同学在设计后台时,会发现一般后台的各个功能模块总结起来有两大类型:功能类.流程类.在设计功能或流程前都需要预判不同的使用角色对应不同权限,设计流程前则还得思考最基本的工作流原理. 用户权限是设 ...

  5. 移动端与PHP服务端接口通信流程设计(增强版)

    前面讲过:移动端与PHP服务端接口通信流程设计(基础版) 对于 api_token 的校验,其安全性还可再增强: 增强地方一: 再增加2张表,一个接口表,一个授权表,设计参考如下: 接口表 字段名 字 ...

  6. 移动端与PHP服务端接口通信流程设计(基础版)

    针对 --->非开放性平台 --->公司内部产品 接口特点汇总: 1.因为是非开放性的,所以所有的接口都是封闭的,只对公司内部的产品有效: 2.因为是非开放性的,所以OAuth那套协议是行 ...

  7. NetCore微服务简单流程审批数据库设计及后台服务开发

    1.数据库设计 -- ---------------------------- -- Table structure for TBase_Flow -- ----------------------- ...

  8. 微服务Dubbo和SpringCloud架构设计、优劣势比较

    本文主要围绕微服务的技术选型.通讯协议.服务依赖模式.开始模式.运行模式等几方面来综合比较Dubbo和Spring Cloud 这2种开发框架.架构师可以根据公司的技术实力并结合项目的特点来选择某个合 ...

  9. ZEGO音视频服务的高可用架构设计与运营

    前言: ZEGO 即构科技作为一家实时音视频的提供商,系统稳定性直接影响用户的主观体验,如何保障服务高可用且用户体验最优是行业面临的挑战,本文结合实际业务场景进行思考,介绍 ZEGO 即构在高可用架构 ...

随机推荐

  1. Linux常用脚本命令总结

    基本操作 通用操作 1. export 显示所有的环境变量,也可以获取到某个变量的详细信息: export # 显示所有 echo $SHELL # 只显示SHELL 2. whereis 使用系统自 ...

  2. efcore 配置链接sqlserver 记录

    本文将在asp.net core api 项目中使用efcore corefirst模式 简单配置链接sqlserver数据库,以及简单的数据库迁移操作 一 新建项目 1. 首先我们先用vs2017 ...

  3. js判断空值

    { "mDataProp": 'CreationTime', 'mRender': function (date) { if (!date && typeof (d ...

  4. Java常用文件操作-1

    在我们的实际工作中经常会用到的文件操作,再此,将工作中碰到的做一个记录,以便日后查看. 1.复制文件夹到新文件夹下 /** * 复制文件夹下所有文件到指定路径 *@param oldPath *@pa ...

  5. Java 架构师之路(2)

    一.技术 J2EE技术是架构师的基础.1.<Java编程思想> 初学Java时阅读这本书觉得好难,阅读第二遍时才觉得讲的很细致.这是一本不怕多读的好书. 2.<J2EE应用与BEA ...

  6. POJ-3522 Slim Span(最小生成树)

    Slim Span Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 8633   Accepted: 4608 Descrip ...

  7. HPU--1221 Fibonacci数列

    题目描述 Fibonacci数列的递推公式为:Fn=Fn-1+Fn-2,其中F1=F2=1. 当n比较大时,Fn也非常大,现在我们想知道,Fn除以10007的余数是多少. 输入 输入包含一个整数n. ...

  8. [学习笔记] 多项式与快速傅里叶变换(FFT)基础

    引入 可能有不少OIer都知道FFT这个神奇的算法, 通过一系列玄学的变化就可以在 $O(nlog(n))$ 的总时间复杂度内计算出两个向量的卷积, 而代码量却非常小. 博主一年半前曾经因COGS的一 ...

  9. C语言内存申请与使用

    1. 使用malloc申请一块空间,模拟KV存储的一个节点存储数据信息. #include<stdio.h> #include <unistd.h> #include < ...

  10. 【物联网云端对接-2】通过MQTT协议与阿里云物联网套件进行云端通信

     在<程序员>杂志2017.4刊上,曾写过一篇<微软百度阿里三大物联网平台探析>,上面曾介绍了阿里云物联网套件的一些内容,在写该篇文章的时候,凌霄物联网网关还无法对接到此平台( ...