├── screenshot ├── 1.png ├── 2.png ├── 3.png ├── 4.png └── 5.png ├── web ├── image │ └── login_bg.jpg ├── WEB-INF │ ├── lib │ │ ├── ojdbc6.jar │ │ ├── c3p0Dbutil.jar │ │ ├── c3p0-0.9.1.2.jar │ │ ├── fastjson-1.2.74.jar │ │ ├── commons-dbutils-1.7.jar │ │ └── mysql-connector-java-5.1.7-bin.jar │ └── web.xml ├── layui │ ├── font │ │ ├── iconfont.eot │ │ ├── iconfont.ttf │ │ ├── iconfont.woff │ │ └── iconfont.woff2 │ ├── images │ │ └── face │ │ │ ├── 0.gif │ │ │ ├── 1.gif │ │ │ ├── 10.gif │ │ │ ├── 11.gif │ │ │ ├── 12.gif │ │ │ ├── 13.gif │ │ │ ├── 14.gif │ │ │ ├── 15.gif │ │ │ ├── 16.gif │ │ │ ├── 17.gif │ │ │ ├── 18.gif │ │ │ ├── 19.gif │ │ │ ├── 2.gif │ │ │ ├── 20.gif │ │ │ ├── 21.gif │ │ │ ├── 22.gif │ │ │ ├── 23.gif │ │ │ ├── 24.gif │ │ │ ├── 25.gif │ │ │ ├── 26.gif │ │ │ ├── 27.gif │ │ │ ├── 28.gif │ │ │ ├── 29.gif │ │ │ ├── 3.gif │ │ │ ├── 30.gif │ │ │ ├── 31.gif │ │ │ ├── 32.gif │ │ │ ├── 33.gif │ │ │ ├── 34.gif │ │ │ ├── 35.gif │ │ │ ├── 36.gif │ │ │ ├── 37.gif │ │ │ ├── 38.gif │ │ │ ├── 39.gif │ │ │ ├── 4.gif │ │ │ ├── 40.gif │ │ │ ├── 41.gif │ │ │ ├── 42.gif │ │ │ ├── 43.gif │ │ │ ├── 44.gif │ │ │ ├── 45.gif │ │ │ ├── 46.gif │ │ │ ├── 47.gif │ │ │ ├── 48.gif │ │ │ ├── 49.gif │ │ │ ├── 5.gif │ │ │ ├── 50.gif │ │ │ ├── 51.gif │ │ │ ├── 52.gif │ │ │ ├── 53.gif │ │ │ ├── 54.gif │ │ │ ├── 55.gif │ │ │ ├── 56.gif │ │ │ ├── 57.gif │ │ │ ├── 58.gif │ │ │ ├── 59.gif │ │ │ ├── 6.gif │ │ │ ├── 60.gif │ │ │ ├── 61.gif │ │ │ ├── 62.gif │ │ │ ├── 63.gif │ │ │ ├── 64.gif │ │ │ ├── 65.gif │ │ │ ├── 66.gif │ │ │ ├── 67.gif │ │ │ ├── 68.gif │ │ │ ├── 69.gif │ │ │ ├── 7.gif │ │ │ ├── 70.gif │ │ │ ├── 71.gif │ │ │ ├── 8.gif │ │ │ └── 9.gif │ ├── css │ │ ├── modules │ │ │ ├── layer │ │ │ │ └── default │ │ │ │ │ ├── icon.png │ │ │ │ │ ├── icon-ext.png │ │ │ │ │ ├── loading-0.gif │ │ │ │ │ ├── loading-1.gif │ │ │ │ │ └── loading-2.gif │ │ │ ├── code.css │ │ │ └── laydate │ │ │ │ └── default │ │ │ │ └── laydate.css │ │ └── layui.mobile.css │ ├── lay │ │ └── modules │ │ │ ├── code.js │ │ │ ├── laytpl.js │ │ │ ├── flow.js │ │ │ ├── rate.js │ │ │ ├── util.js │ │ │ ├── carousel.js │ │ │ ├── laypage.js │ │ │ ├── transfer.js │ │ │ ├── slider.js │ │ │ ├── upload.js │ │ │ ├── element.js │ │ │ ├── form.js │ │ │ └── tree.js │ └── layui.js ├── css │ ├── list.css │ └── login.css ├── login.html ├── register.html ├── index.html ├── teacherAdd.html ├── studentAdd.html ├── teacherEdit.html ├── studentEdit.html ├── teacherList.html └── studentList.html ├── src ├── jdbc.properties ├── com │ └── school │ │ ├── dao │ │ ├── LoginDao.java │ │ ├── StudentDao.java │ │ └── TeacherDao.java │ │ ├── service │ │ ├── LoginService.java │ │ ├── StudentService.java │ │ └── TeacherService.java │ │ ├── serviceImp │ │ ├── LoginServiceImp.java │ │ ├── StudentServiceImp.java │ │ └── TeacherServiceImp.java │ │ ├── pojo │ │ ├── Login.java │ │ ├── Teacher.java │ │ └── Student.java │ │ ├── util │ │ ├── C3p0Util.java │ │ ├── ResultUtil.java │ │ └── JDBCUtil.java │ │ ├── filter │ │ └── MyFilter.java │ │ ├── daoImp │ │ ├── LoginDaoImp.java │ │ ├── TeacherDaoImp.java │ │ └── StudentDaoImp.java │ │ └── controller │ │ ├── LoginController.java │ │ ├── TeacherController.java │ │ └── StudentController.java └── c3p0-config.xml ├── .gitignore └── README.md /screenshot/1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/screenshot/1.png -------------------------------------------------------------------------------- /screenshot/2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/screenshot/2.png -------------------------------------------------------------------------------- /screenshot/3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/screenshot/3.png -------------------------------------------------------------------------------- /screenshot/4.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/screenshot/4.png -------------------------------------------------------------------------------- /screenshot/5.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/screenshot/5.png -------------------------------------------------------------------------------- /web/image/login_bg.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/image/login_bg.jpg -------------------------------------------------------------------------------- /src/jdbc.properties: -------------------------------------------------------------------------------- 1 | driverClass=com.mysql.jdbc.Driver 2 | url=jdbc:mysql://localhost:3306/no25_crm 3 | userName=root 4 | passWord=123456 5 | -------------------------------------------------------------------------------- /web/WEB-INF/lib/ojdbc6.jar: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/WEB-INF/lib/ojdbc6.jar -------------------------------------------------------------------------------- /web/layui/font/iconfont.eot: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/font/iconfont.eot -------------------------------------------------------------------------------- /web/layui/font/iconfont.ttf: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/font/iconfont.ttf -------------------------------------------------------------------------------- /web/layui/font/iconfont.woff: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/font/iconfont.woff -------------------------------------------------------------------------------- /web/layui/images/face/0.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/0.gif -------------------------------------------------------------------------------- /web/layui/images/face/1.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/1.gif -------------------------------------------------------------------------------- /web/layui/images/face/10.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/10.gif -------------------------------------------------------------------------------- /web/layui/images/face/11.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/11.gif -------------------------------------------------------------------------------- /web/layui/images/face/12.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/12.gif -------------------------------------------------------------------------------- /web/layui/images/face/13.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/13.gif -------------------------------------------------------------------------------- /web/layui/images/face/14.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/14.gif -------------------------------------------------------------------------------- /web/layui/images/face/15.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/15.gif -------------------------------------------------------------------------------- /web/layui/images/face/16.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/16.gif -------------------------------------------------------------------------------- /web/layui/images/face/17.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/17.gif -------------------------------------------------------------------------------- /web/layui/images/face/18.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/18.gif -------------------------------------------------------------------------------- /web/layui/images/face/19.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/19.gif -------------------------------------------------------------------------------- /web/layui/images/face/2.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/2.gif -------------------------------------------------------------------------------- /web/layui/images/face/20.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/20.gif -------------------------------------------------------------------------------- /web/layui/images/face/21.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/21.gif -------------------------------------------------------------------------------- /web/layui/images/face/22.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/22.gif -------------------------------------------------------------------------------- /web/layui/images/face/23.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/23.gif -------------------------------------------------------------------------------- /web/layui/images/face/24.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/24.gif -------------------------------------------------------------------------------- /web/layui/images/face/25.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/25.gif -------------------------------------------------------------------------------- /web/layui/images/face/26.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/26.gif -------------------------------------------------------------------------------- /web/layui/images/face/27.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/27.gif -------------------------------------------------------------------------------- /web/layui/images/face/28.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/28.gif -------------------------------------------------------------------------------- /web/layui/images/face/29.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/29.gif -------------------------------------------------------------------------------- /web/layui/images/face/3.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/3.gif -------------------------------------------------------------------------------- /web/layui/images/face/30.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/30.gif -------------------------------------------------------------------------------- /web/layui/images/face/31.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/31.gif -------------------------------------------------------------------------------- /web/layui/images/face/32.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/32.gif -------------------------------------------------------------------------------- /web/layui/images/face/33.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/33.gif -------------------------------------------------------------------------------- /web/layui/images/face/34.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/34.gif -------------------------------------------------------------------------------- /web/layui/images/face/35.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/35.gif -------------------------------------------------------------------------------- /web/layui/images/face/36.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/36.gif -------------------------------------------------------------------------------- /web/layui/images/face/37.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/37.gif -------------------------------------------------------------------------------- /web/layui/images/face/38.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/38.gif -------------------------------------------------------------------------------- /web/layui/images/face/39.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/39.gif -------------------------------------------------------------------------------- /web/layui/images/face/4.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/4.gif -------------------------------------------------------------------------------- /web/layui/images/face/40.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/40.gif -------------------------------------------------------------------------------- /web/layui/images/face/41.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/41.gif -------------------------------------------------------------------------------- /web/layui/images/face/42.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/42.gif -------------------------------------------------------------------------------- /web/layui/images/face/43.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/43.gif -------------------------------------------------------------------------------- /web/layui/images/face/44.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/44.gif -------------------------------------------------------------------------------- /web/layui/images/face/45.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/45.gif -------------------------------------------------------------------------------- /web/layui/images/face/46.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/46.gif -------------------------------------------------------------------------------- /web/layui/images/face/47.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/47.gif -------------------------------------------------------------------------------- /web/layui/images/face/48.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/48.gif -------------------------------------------------------------------------------- /web/layui/images/face/49.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/49.gif -------------------------------------------------------------------------------- /web/layui/images/face/5.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/5.gif -------------------------------------------------------------------------------- /web/layui/images/face/50.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/50.gif -------------------------------------------------------------------------------- /web/layui/images/face/51.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/51.gif -------------------------------------------------------------------------------- /web/layui/images/face/52.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/52.gif -------------------------------------------------------------------------------- /web/layui/images/face/53.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/53.gif -------------------------------------------------------------------------------- /web/layui/images/face/54.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/54.gif -------------------------------------------------------------------------------- /web/layui/images/face/55.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/55.gif -------------------------------------------------------------------------------- /web/layui/images/face/56.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/56.gif -------------------------------------------------------------------------------- /web/layui/images/face/57.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/57.gif -------------------------------------------------------------------------------- /web/layui/images/face/58.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/58.gif -------------------------------------------------------------------------------- /web/layui/images/face/59.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/59.gif -------------------------------------------------------------------------------- /web/layui/images/face/6.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/6.gif -------------------------------------------------------------------------------- /web/layui/images/face/60.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/60.gif -------------------------------------------------------------------------------- /web/layui/images/face/61.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/61.gif -------------------------------------------------------------------------------- /web/layui/images/face/62.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/62.gif -------------------------------------------------------------------------------- /web/layui/images/face/63.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/63.gif -------------------------------------------------------------------------------- /web/layui/images/face/64.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/64.gif -------------------------------------------------------------------------------- /web/layui/images/face/65.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/65.gif -------------------------------------------------------------------------------- /web/layui/images/face/66.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/66.gif -------------------------------------------------------------------------------- /web/layui/images/face/67.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/67.gif -------------------------------------------------------------------------------- /web/layui/images/face/68.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/68.gif -------------------------------------------------------------------------------- /web/layui/images/face/69.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/69.gif -------------------------------------------------------------------------------- /web/layui/images/face/7.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/7.gif -------------------------------------------------------------------------------- /web/layui/images/face/70.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/70.gif -------------------------------------------------------------------------------- /web/layui/images/face/71.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/71.gif -------------------------------------------------------------------------------- /web/layui/images/face/8.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/8.gif -------------------------------------------------------------------------------- /web/layui/images/face/9.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/images/face/9.gif -------------------------------------------------------------------------------- /web/WEB-INF/lib/c3p0Dbutil.jar: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/WEB-INF/lib/c3p0Dbutil.jar -------------------------------------------------------------------------------- /web/layui/font/iconfont.woff2: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/font/iconfont.woff2 -------------------------------------------------------------------------------- /web/WEB-INF/lib/c3p0-0.9.1.2.jar: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/WEB-INF/lib/c3p0-0.9.1.2.jar -------------------------------------------------------------------------------- /web/WEB-INF/lib/fastjson-1.2.74.jar: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/WEB-INF/lib/fastjson-1.2.74.jar -------------------------------------------------------------------------------- /web/WEB-INF/lib/commons-dbutils-1.7.jar: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/WEB-INF/lib/commons-dbutils-1.7.jar -------------------------------------------------------------------------------- /web/layui/css/modules/layer/default/icon.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/css/modules/layer/default/icon.png -------------------------------------------------------------------------------- /web/layui/css/modules/layer/default/icon-ext.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/css/modules/layer/default/icon-ext.png -------------------------------------------------------------------------------- /web/WEB-INF/lib/mysql-connector-java-5.1.7-bin.jar: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/WEB-INF/lib/mysql-connector-java-5.1.7-bin.jar -------------------------------------------------------------------------------- /web/layui/css/modules/layer/default/loading-0.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/css/modules/layer/default/loading-0.gif -------------------------------------------------------------------------------- /web/layui/css/modules/layer/default/loading-1.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/css/modules/layer/default/loading-1.gif -------------------------------------------------------------------------------- /web/layui/css/modules/layer/default/loading-2.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/YuLin-Coder/No25StudentInformationManagementSystem3/HEAD/web/layui/css/modules/layer/default/loading-2.gif -------------------------------------------------------------------------------- /src/com/school/dao/LoginDao.java: -------------------------------------------------------------------------------- 1 | package com.school.dao; 2 | 3 | import com.school.pojo.Login; 4 | 5 | public interface LoginDao { 6 | Login login(String username,String password); 7 | Integer register(String username,String password); 8 | } 9 | -------------------------------------------------------------------------------- /src/com/school/service/LoginService.java: -------------------------------------------------------------------------------- 1 | package com.school.service; 2 | 3 | import com.school.pojo.Login; 4 | 5 | public interface LoginService { 6 | Login login(String username, String password); 7 | Integer register(String username,String password); 8 | } 9 | -------------------------------------------------------------------------------- /web/css/list.css: -------------------------------------------------------------------------------- 1 | .list_search{ padding:10px 10px; } 2 | .list_search .layui-inline{ margin:5px 5px 5px 0; } 3 | .news_list .layui-btn,.news_list .layui-btn+.layui-btn{ margin:2px 5px; } 4 | .news_list .layui-form-switch{ margin-top:0; } 5 | 6 | /* 数据表格复选框正常显示 */ 7 | .layui-table-cell .layui-form-checkbox[lay-skin="primary"]{ 8 | top: 50%; 9 | transform: translateY(-50%); 10 | } -------------------------------------------------------------------------------- /src/com/school/service/StudentService.java: -------------------------------------------------------------------------------- 1 | package com.school.service; 2 | 3 | import com.school.pojo.Student; 4 | import com.school.util.ResultUtil; 5 | 6 | import java.util.Map; 7 | 8 | public interface StudentService { 9 | int add(Student student); 10 | int update(Student student); 11 | int delete(Integer id); 12 | ResultUtil findAllToSys(Map map); 13 | Student findById(Integer id); 14 | } 15 | -------------------------------------------------------------------------------- /src/com/school/service/TeacherService.java: -------------------------------------------------------------------------------- 1 | package com.school.service; 2 | 3 | import com.school.pojo.Teacher; 4 | import com.school.util.ResultUtil; 5 | 6 | import java.util.Map; 7 | 8 | public interface TeacherService { 9 | int add(Teacher teacher); 10 | int update(Teacher teacher); 11 | int delete(Integer id); 12 | ResultUtil findAllToSys(Map map); 13 | Teacher findById(Integer id); 14 | } 15 | -------------------------------------------------------------------------------- /src/com/school/dao/StudentDao.java: -------------------------------------------------------------------------------- 1 | package com.school.dao; 2 | 3 | import com.school.pojo.Student; 4 | 5 | import java.util.List; 6 | import java.util.Map; 7 | 8 | public interface StudentDao { 9 | int add(Student student); 10 | int update(Student student); 11 | int delete(Integer id); 12 | List findAllToSys(Map map); 13 | Integer findAllToSysCount(Map map); 14 | Student findById(Integer id); 15 | } 16 | -------------------------------------------------------------------------------- /src/com/school/dao/TeacherDao.java: -------------------------------------------------------------------------------- 1 | package com.school.dao; 2 | 3 | import com.school.pojo.Teacher; 4 | 5 | import java.util.List; 6 | import java.util.Map; 7 | 8 | public interface TeacherDao { 9 | int add(Teacher teacher); 10 | int update(Teacher teacher); 11 | int delete(Integer id); 12 | List findAllToSys(Map map); 13 | Integer findAllToSysCount(Map map); 14 | Teacher findById(Integer id); 15 | } 16 | -------------------------------------------------------------------------------- /src/com/school/serviceImp/LoginServiceImp.java: -------------------------------------------------------------------------------- 1 | package com.school.serviceImp; 2 | 3 | import com.school.dao.LoginDao; 4 | import com.school.daoImp.LoginDaoImp; 5 | import com.school.pojo.Login; 6 | import com.school.service.LoginService; 7 | 8 | public class LoginServiceImp implements LoginService { 9 | LoginDao loginDao=new LoginDaoImp(); 10 | 11 | @Override 12 | public Login login(String username, String password) { 13 | return loginDao.login(username,password); 14 | } 15 | 16 | @Override 17 | public Integer register(String username, String password) { 18 | return loginDao.register(username,password); 19 | } 20 | } 21 | -------------------------------------------------------------------------------- /src/c3p0-config.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | jdbc:mysql://localhost:3306/graduation_25_crm 6 | com.mysql.jdbc.Driver 7 | root 8 | 123456 9 | 10 | 11 | 3 12 | 20 13 | 2 14 | 50 15 | 16 | 17 | 18 | -------------------------------------------------------------------------------- /src/com/school/pojo/Login.java: -------------------------------------------------------------------------------- 1 | package com.school.pojo; 2 | 3 | public class Login { 4 | private Integer id; 5 | private String username; 6 | private String password; 7 | 8 | public Integer getId() { 9 | return id; 10 | } 11 | 12 | public void setId(Integer id) { 13 | this.id = id; 14 | } 15 | 16 | public String getUsername() { 17 | return username; 18 | } 19 | 20 | public void setUsername(String username) { 21 | this.username = username; 22 | } 23 | 24 | public String getPassword() { 25 | return password; 26 | } 27 | 28 | public void setPassword(String password) { 29 | this.password = password; 30 | } 31 | } 32 | -------------------------------------------------------------------------------- /web/WEB-INF/web.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | Denglu 4 | 5 | login.html 6 | 7 | 8 | 9 | 10 | myfilter 11 | com.school.filter.MyFilter 12 | 13 | 14 | myfilter 15 | *.do 16 | 17 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | ###################################################################### 2 | # Build Tools 3 | 4 | .gradle 5 | /build/ 6 | !gradle/wrapper/gradle-wrapper.jar 7 | 8 | target/ 9 | !.mvn/wrapper/maven-wrapper.jar 10 | 11 | out/ 12 | 13 | ###################################################################### 14 | # IDE 15 | 16 | ### STS ### 17 | .apt_generated 18 | .classpath 19 | .factorypath 20 | .project 21 | .settings 22 | .springBeans 23 | 24 | ### IntelliJ IDEA ### 25 | .idea 26 | *.iws 27 | *.iml 28 | *.ipr 29 | 30 | ### NetBeans ### 31 | nbproject/private/ 32 | build/* 33 | nbbuild/ 34 | dist/ 35 | nbdist/ 36 | .nb-gradle/ 37 | 38 | ###################################################################### 39 | # Others 40 | *.log 41 | *.xml.versionsBackup 42 | *.swp 43 | 44 | !*/build/*.java 45 | !*/build/*.html 46 | !*/build/*.xml 47 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 |

25.基于servlet的学生信息管理

2 | 3 | - 完整代码获取地址:从戎源码网 ([https://armycodes.com/](https://armycodes.com/)) 4 | - 技术探讨、资料分享,请加QQ群:692619798 5 | - 作者微信:19941326836 QQ:952045282 6 | - 承接计算机毕业设计、Java毕业设计、Python毕业设计、深度学习、机器学习 7 | - 选题+开题报告+任务书+程序定制+安装调试+论文+答辩ppt 一条龙服务 8 | - 所有选题地址 ([https://github.com/YuLin-Coder/AllProjectCatalog](https://github.com/YuLin-Coder/AllProjectCatalog)) 9 | 10 | ## 项目介绍 11 | 12 | 基于servlet的学生信息管理系统:前端 html、jquery、layui,后端 servlet,一个简洁的学生信息、教师信息管理系统 13 | 14 | ## 主要功能 15 | 16 | - 基本功能:登录、退出、注册 17 | - 学生信息管理:根据学号查询、学生列表、添加学生、学生信息修改、学生信息删除、学生信息导出 18 | - 教师信息管理:根据姓名查询、教师列表查询、添加教师、教师信息修改、教师信息删除 19 | 20 | ## 环境 21 | 22 | - IntelliJ IDEA 2009.3 23 | 24 | - Mysql 5.7.26 25 | 26 | - Tomcat 7.0.73 27 | 28 | - JDK 1.8 29 | 30 | ## 运行截图 31 | ![](screenshot/1.png) 32 | 33 | ![](screenshot/2.png) 34 | 35 | ![](screenshot/3.png) 36 | 37 | ![](screenshot/4.png) 38 | 39 | ![](screenshot/5.png) 40 | -------------------------------------------------------------------------------- /web/layui/css/modules/code.css: -------------------------------------------------------------------------------- 1 | /** layui-v2.5.6 MIT License By https://www.layui.com */ 2 | html #layuicss-skincodecss{display:none;position:absolute;width:1989px}.layui-code-h3,.layui-code-view{position:relative;font-size:12px}.layui-code-view{display:block;margin:10px 0;padding:0;border:1px solid #e2e2e2;border-left-width:6px;background-color:#F2F2F2;color:#333;font-family:Courier New}.layui-code-h3{padding:0 10px;height:32px;line-height:32px;border-bottom:1px solid #e2e2e2}.layui-code-h3 a{position:absolute;right:10px;top:0;color:#999}.layui-code-view .layui-code-ol{position:relative;overflow:auto}.layui-code-view .layui-code-ol li{position:relative;margin-left:45px;line-height:20px;padding:0 5px;border-left:1px solid #e2e2e2;list-style-type:decimal-leading-zero;*list-style-type:decimal;background-color:#fff}.layui-code-view pre{margin:0}.layui-code-notepad{border:1px solid #0C0C0C;border-left-color:#3F3F3F;background-color:#0C0C0C;color:#C2BE9E}.layui-code-notepad .layui-code-h3{border-bottom:none}.layui-code-notepad .layui-code-ol li{background-color:#3F3F3F;border-left:none} -------------------------------------------------------------------------------- /web/css/login.css: -------------------------------------------------------------------------------- 1 | body { 2 | overflow: hidden; 3 | } 4 | 5 | .video-player { 6 | background-color: transparent; 7 | display: block; 8 | position: absolute; 9 | z-index: 1; 10 | top: 0; 11 | } 12 | 13 | .video_mask { 14 | width: 100%; 15 | height: 100%; 16 | position: absolute; 17 | left: 0; 18 | top: 0; 19 | z-index: 90; 20 | background-image: url("../image/login_bg.jpg"); 21 | } 22 | 23 | .login { 24 | height: 260px; 25 | width: 260px; 26 | padding: 20px; 27 | background-color: rgba(0, 0, 0, 0.3); 28 | border-radius: 4px; 29 | position: absolute; 30 | left: 50%; 31 | top: 50%; 32 | margin: -150px 0 0 -150px; 33 | z-index: 99; 34 | } 35 | 36 | .login h1 { 37 | text-align: center; 38 | color: #fff; 39 | font-size: 24px; 40 | margin-bottom: 20px; 41 | } 42 | 43 | .form_code { 44 | position: relative; 45 | } 46 | 47 | .form_code .code { 48 | position: absolute; 49 | right: 0; 50 | top: 1px; 51 | cursor: pointer; 52 | } 53 | 54 | .login_btn { 55 | width: 100%; 56 | } -------------------------------------------------------------------------------- /web/layui/lay/modules/code.js: -------------------------------------------------------------------------------- 1 | /** layui-v2.5.6 MIT License By https://www.layui.com */ 2 | ;layui.define("jquery",function(e){"use strict";var a=layui.$,l="http://www.layui.com/doc/modules/code.html";e("code",function(e){var t=[];e=e||{},e.elem=a(e.elem||".layui-code"),e.about=!("about"in e)||e.about,e.elem.each(function(){t.push(this)}),layui.each(t.reverse(),function(t,i){var c=a(i),o=c.html();(c.attr("lay-encode")||e.encode)&&(o=o.replace(/&(?!#?[a-zA-Z0-9]+;)/g,"&").replace(//g,">").replace(/'/g,"'").replace(/"/g,""")),c.html('
  1. '+o.replace(/[\r\t\n]+/g,"
  2. ")+"
"),c.find(">.layui-code-h3")[0]||c.prepend('

'+(c.attr("lay-title")||e.title||"code")+(e.about?'layui.code':"")+"

");var d=c.find(">.layui-code-ol");c.addClass("layui-box layui-code-view"),(c.attr("lay-skin")||e.skin)&&c.addClass("layui-code-"+(c.attr("lay-skin")||e.skin)),(d.find("li").length/100|0)>0&&d.css("margin-left",(d.find("li").length/100|0)+"px"),(c.attr("lay-height")||e.height)&&d.css("max-height",c.attr("lay-height")||e.height)})})}).addcss("modules/code.css","skincodecss"); -------------------------------------------------------------------------------- /src/com/school/pojo/Teacher.java: -------------------------------------------------------------------------------- 1 | package com.school.pojo; 2 | 3 | public class Teacher { 4 | private Integer id; 5 | private String name; 6 | private String professional; 7 | private String degree; 8 | private String course; 9 | private Integer sex; 10 | 11 | 12 | public Integer getId() { 13 | return id; 14 | } 15 | 16 | public void setId(Integer id) { 17 | this.id = id; 18 | } 19 | 20 | public String getName() { 21 | return name; 22 | } 23 | 24 | public void setName(String name) { 25 | this.name = name; 26 | } 27 | 28 | public String getProfessional() { 29 | return professional; 30 | } 31 | 32 | public void setProfessional(String professional) { 33 | this.professional = professional; 34 | } 35 | 36 | public String getDegree() { 37 | return degree; 38 | } 39 | 40 | public void setDegree(String degree) { 41 | this.degree = degree; 42 | } 43 | 44 | public String getCourse() { 45 | return course; 46 | } 47 | 48 | public void setCourse(String course) { 49 | this.course = course; 50 | } 51 | 52 | public Integer getSex() { 53 | return sex; 54 | } 55 | 56 | public void setSex(Integer sex) { 57 | this.sex = sex; 58 | } 59 | } 60 | -------------------------------------------------------------------------------- /src/com/school/util/C3p0Util.java: -------------------------------------------------------------------------------- 1 | package com.school.util; 2 | 3 | import com.mchange.v2.c3p0.ComboPooledDataSource; 4 | 5 | import javax.sql.DataSource; 6 | import java.sql.Connection; 7 | import java.sql.ResultSet; 8 | import java.sql.SQLException; 9 | import java.sql.Statement; 10 | 11 | 12 | public class C3p0Util { 13 | 14 | //C3p0工具类单列 15 | private static ComboPooledDataSource dataSource = new ComboPooledDataSource("mysql"); 16 | public static DataSource getDataSource(){ 17 | return dataSource; 18 | } 19 | private C3p0Util() { 20 | } 21 | 22 | // 命名一个公共的获取连接方法 23 | public static Connection getConnection(){ 24 | try { 25 | return dataSource.getConnection(); 26 | } catch (SQLException e) { 27 | e.printStackTrace(); 28 | } 29 | return null; 30 | } 31 | 32 | public static void release(Connection conn, Statement st, ResultSet rs){ 33 | // 关闭结果集资源 34 | if(rs != null){ 35 | try { 36 | rs.close(); 37 | } catch (SQLException e) { 38 | e.printStackTrace(); 39 | } 40 | } 41 | 42 | // 关闭st对象 43 | if(st != null){ 44 | try { 45 | st.close(); 46 | } catch (SQLException e) { 47 | e.printStackTrace(); 48 | } 49 | } 50 | 51 | // 关闭连接 52 | if(conn != null){ 53 | try { 54 | conn.close(); 55 | } catch (SQLException e) { 56 | e.printStackTrace(); 57 | } 58 | } 59 | } 60 | } 61 | -------------------------------------------------------------------------------- /src/com/school/serviceImp/StudentServiceImp.java: -------------------------------------------------------------------------------- 1 | package com.school.serviceImp; 2 | 3 | import com.school.dao.StudentDao; 4 | import com.school.daoImp.StudentDaoImp; 5 | import com.school.pojo.Student; 6 | import com.school.service.StudentService; 7 | import com.school.util.ResultUtil; 8 | 9 | import java.util.List; 10 | import java.util.Map; 11 | 12 | public class StudentServiceImp implements StudentService { 13 | private StudentDao studentDao=new StudentDaoImp(); 14 | 15 | @Override 16 | public int add(Student student) { 17 | return studentDao.add(student); 18 | } 19 | 20 | @Override 21 | public int update(Student student) { 22 | return studentDao.update(student); 23 | } 24 | 25 | @Override 26 | public int delete(Integer id) { 27 | return studentDao.delete(id); 28 | } 29 | 30 | @Override 31 | public ResultUtil findAllToSys(Map map) { 32 | 33 | List studentList = studentDao.findAllToSys(map); 34 | Integer count = studentDao.findAllToSysCount(map); 35 | ResultUtil resultUtil = new ResultUtil(); 36 | resultUtil.setCode(0); 37 | resultUtil.setCount(count); 38 | resultUtil.setData(studentList); 39 | return resultUtil; 40 | } 41 | 42 | 43 | @Override 44 | public Student findById(Integer id) { 45 | return studentDao.findById(id); 46 | } 47 | } 48 | -------------------------------------------------------------------------------- /src/com/school/serviceImp/TeacherServiceImp.java: -------------------------------------------------------------------------------- 1 | package com.school.serviceImp; 2 | 3 | import com.school.dao.TeacherDao; 4 | import com.school.daoImp.TeacherDaoImp; 5 | import com.school.pojo.Teacher; 6 | import com.school.service.TeacherService; 7 | import com.school.util.ResultUtil; 8 | 9 | import java.util.List; 10 | import java.util.Map; 11 | 12 | public class TeacherServiceImp implements TeacherService { 13 | private TeacherDao teacherDao=new TeacherDaoImp() ; 14 | 15 | @Override 16 | public int add(Teacher teacher) { 17 | return teacherDao.add(teacher); 18 | } 19 | 20 | @Override 21 | public int update(Teacher teacher) { 22 | return teacherDao.update(teacher); 23 | } 24 | 25 | @Override 26 | public int delete(Integer id) { 27 | return teacherDao.delete(id); 28 | } 29 | 30 | @Override 31 | public ResultUtil findAllToSys(Map map) { 32 | 33 | List teacherList = teacherDao.findAllToSys(map); 34 | Integer count = teacherDao.findAllToSysCount(map); 35 | ResultUtil resultUtil = new ResultUtil(); 36 | resultUtil.setCode(0); 37 | resultUtil.setCount(count); 38 | resultUtil.setData(teacherList); 39 | return resultUtil; 40 | } 41 | 42 | 43 | @Override 44 | public Teacher findById(Integer id) { 45 | return teacherDao.findById(id); 46 | } 47 | } 48 | -------------------------------------------------------------------------------- /src/com/school/pojo/Student.java: -------------------------------------------------------------------------------- 1 | package com.school.pojo; 2 | 3 | public class Student { 4 | private Integer id; 5 | private String name; 6 | private String no; 7 | private Integer age; 8 | private String classes; 9 | private String address; 10 | private String nation;//民族 11 | private Integer sex; 12 | 13 | public Integer getSex() { 14 | return sex; 15 | } 16 | 17 | public void setSex(Integer sex) { 18 | this.sex = sex; 19 | } 20 | 21 | public String getNo() { 22 | return no; 23 | } 24 | 25 | public void setNo(String no) { 26 | this.no = no; 27 | } 28 | 29 | public Integer getId() { 30 | return id; 31 | } 32 | 33 | public void setId(Integer id) { 34 | this.id = id; 35 | } 36 | 37 | public String getName() { 38 | return name; 39 | } 40 | 41 | public void setName(String name) { 42 | this.name = name; 43 | } 44 | 45 | public Integer getAge() { 46 | return age; 47 | } 48 | 49 | public void setAge(Integer age) { 50 | this.age = age; 51 | } 52 | 53 | public String getClasses() { 54 | return classes; 55 | } 56 | 57 | public void setClasses(String classes) { 58 | this.classes = classes; 59 | } 60 | 61 | public String getAddress() { 62 | return address; 63 | } 64 | 65 | public void setAddress(String address) { 66 | this.address = address; 67 | } 68 | 69 | public String getNation() { 70 | return nation; 71 | } 72 | 73 | public void setNation(String nation) { 74 | this.nation = nation; 75 | } 76 | } 77 | -------------------------------------------------------------------------------- /src/com/school/filter/MyFilter.java: -------------------------------------------------------------------------------- 1 | package com.school.filter; 2 | 3 | import com.alibaba.fastjson.JSON; 4 | 5 | import javax.servlet.*; 6 | import javax.servlet.http.HttpServletRequest; 7 | import javax.servlet.http.HttpServletResponse; 8 | import java.io.IOException; 9 | import java.io.PrintWriter; 10 | import java.util.HashMap; 11 | import java.util.Map; 12 | 13 | public class MyFilter implements Filter{ 14 | @Override 15 | public void destroy() { 16 | 17 | } 18 | @Override 19 | public void doFilter(ServletRequest req, ServletResponse res, FilterChain filter) 20 | throws IOException, ServletException { 21 | HttpServletRequest request = (HttpServletRequest)req; 22 | HttpServletResponse response = (HttpServletResponse)res; 23 | response.setHeader("Access-Control-Allow-Origin", request.getHeader("Origin")); 24 | response.setHeader("Access-Control-Allow-Methods", "POST,GET,OPTIONS,DELETE"); 25 | response.setHeader("Access-Control-Max-Age", "3600"); 26 | response.setHeader("Access-Control-Allow-Header", "x-requested-with"); 27 | response.setHeader("Access-Control-Allow-Credentials", "true");//是否支持cookie 28 | 29 | String sessionid = (String) request.getSession().getAttribute("userid"); 30 | System.out.println("sessionID"+sessionid); 31 | 32 | String userid = request.getHeader("userid"); 33 | if(userid != null && userid != ""){// 判断是否有userid 34 | filter.doFilter(req, res); 35 | }else{ 36 | PrintWriter writer = response.getWriter(); 37 | Map map = new HashMap(); 38 | map.put("flag", "false"); 39 | writer.write(JSON.toJSONString(map)); 40 | } 41 | } 42 | @Override 43 | public void init(FilterConfig arg0) throws ServletException { 44 | } 45 | } 46 | -------------------------------------------------------------------------------- /src/com/school/util/ResultUtil.java: -------------------------------------------------------------------------------- 1 | package com.school.util; 2 | 3 | 4 | 5 | import java.io.Serializable; 6 | 7 | public class ResultUtil implements Serializable { 8 | private Integer code; 9 | private String msg=""; 10 | private Integer count= 0; 11 | private Object data; 12 | 13 | public ResultUtil() { 14 | super(); 15 | } 16 | 17 | public ResultUtil(Integer code) { 18 | super(); 19 | this.code = code; 20 | } 21 | 22 | public ResultUtil(Integer code, String msg) { 23 | super(); 24 | this.code = code; 25 | this.msg = msg; 26 | } 27 | 28 | public Integer getCode() { 29 | return code; 30 | } 31 | 32 | public void setCode(Integer code) { 33 | this.code = code; 34 | } 35 | 36 | public String getMsg() { 37 | return msg; 38 | } 39 | 40 | public void setMsg(String msg) { 41 | this.msg = msg; 42 | } 43 | 44 | 45 | public Integer getCount() { 46 | return count; 47 | } 48 | 49 | public void setCount(Integer count) { 50 | this.count = count; 51 | } 52 | 53 | public Object getData() { 54 | return data; 55 | } 56 | 57 | public void setData(Object data) { 58 | this.data = data; 59 | } 60 | 61 | public static ResultUtil success(){ 62 | return new ResultUtil(200); 63 | } 64 | 65 | public static ResultUtil success(Object list){ 66 | ResultUtil result = new ResultUtil(); 67 | result.setCode(200); 68 | result.setData(list);; 69 | return result; 70 | } 71 | public static ResultUtil success(String msg){ 72 | ResultUtil result = new ResultUtil(); 73 | result.setCode(200); 74 | result.setMsg(msg); 75 | return result; 76 | } 77 | 78 | public static ResultUtil error(){ 79 | return new ResultUtil(500,"没有此权限,请联系超管!"); 80 | } 81 | public static ResultUtil error(String str){ 82 | return new ResultUtil(500,str); 83 | } 84 | } 85 | -------------------------------------------------------------------------------- /web/layui/lay/modules/laytpl.js: -------------------------------------------------------------------------------- 1 | /** layui-v2.5.6 MIT License By https://www.layui.com */ 2 | ;layui.define(function(e){"use strict";var r={open:"{{",close:"}}"},c={exp:function(e){return new RegExp(e,"g")},query:function(e,c,t){var o=["#([\\s\\S])+?","([^{#}])*?"][e||0];return n((c||"")+r.open+o+r.close+(t||""))},escape:function(e){return String(e||"").replace(/&(?!#?[a-zA-Z0-9]+;)/g,"&").replace(//g,">").replace(/'/g,"'").replace(/"/g,""")},error:function(e,r){var c="Laytpl Error:";return"object"==typeof console&&console.error(c+e+"\n"+(r||"")),c+e}},n=c.exp,t=function(e){this.tpl=e};t.pt=t.prototype,window.errors=0,t.pt.parse=function(e,t){var o=this,p=e,a=n("^"+r.open+"#",""),l=n(r.close+"$","");e=e.replace(/\s+|\r|\t|\n/g," ").replace(n(r.open+"#"),r.open+"# ").replace(n(r.close+"}"),"} "+r.close).replace(/\\/g,"\\\\").replace(n(r.open+"!(.+?)!"+r.close),function(e){return e=e.replace(n("^"+r.open+"!"),"").replace(n("!"+r.close),"").replace(n(r.open+"|"+r.close),function(e){return e.replace(/(.)/g,"\\$1")})}).replace(/(?="|')/g,"\\").replace(c.query(),function(e){return e=e.replace(a,"").replace(l,""),'";'+e.replace(/\\/g,"")+';view+="'}).replace(c.query(1),function(e){var c='"+(';return e.replace(/\s/g,"")===r.open+r.close?"":(e=e.replace(n(r.open+"|"+r.close),""),/^=/.test(e)&&(e=e.replace(/^=/,""),c='"+_escape_('),c+e.replace(/\\/g,"")+')+"')}),e='"use strict";var view = "'+e+'";return view;';try{return o.cache=e=new Function("d, _escape_",e),e(t,c.escape)}catch(u){return delete o.cache,c.error(u,p)}},t.pt.render=function(e,r){var n,t=this;return e?(n=t.cache?t.cache(e,c.escape):t.parse(t.tpl,e),r?void r(n):n):c.error("no data")};var o=function(e){return"string"!=typeof e?c.error("Template not found"):new t(e)};o.config=function(e){e=e||{};for(var c in e)r[c]=e[c]},o.v="1.2.0",e("laytpl",o)}); -------------------------------------------------------------------------------- /web/layui/lay/modules/flow.js: -------------------------------------------------------------------------------- 1 | /** layui-v2.5.6 MIT License By https://www.layui.com */ 2 | ;layui.define("jquery",function(e){"use strict";var l=layui.$,o=function(e){},t='';o.prototype.load=function(e){var o,i,n,r,a=this,c=0;e=e||{};var f=l(e.elem);if(f[0]){var m=l(e.scrollElem||document),u=e.mb||50,s=!("isAuto"in e)||e.isAuto,v=e.end||"没有更多了",y=e.scrollElem&&e.scrollElem!==document,d="加载更多",h=l('");f.find(".layui-flow-more")[0]||f.append(h);var p=function(e,t){e=l(e),h.before(e),t=0==t||null,t?h.html(v):h.find("a").html(d),i=t,o=null,n&&n()},g=function(){o=!0,h.find("a").html(t),"function"==typeof e.done&&e.done(++c,p)};if(g(),h.find("a").on("click",function(){l(this);i||o||g()}),e.isLazyimg)var n=a.lazyimg({elem:e.elem+" img",scrollElem:e.scrollElem});return s?(m.on("scroll",function(){var e=l(this),t=e.scrollTop();r&&clearTimeout(r),!i&&f.width()&&(r=setTimeout(function(){var i=y?e.height():l(window).height(),n=y?e.prop("scrollHeight"):document.documentElement.scrollHeight;n-t-i<=u&&(o||g())},100))}),a):a}},o.prototype.lazyimg=function(e){var o,t=this,i=0;e=e||{};var n=l(e.scrollElem||document),r=e.elem||"img",a=e.scrollElem&&e.scrollElem!==document,c=function(e,l){var o=n.scrollTop(),r=o+l,c=a?function(){return e.offset().top-n.offset().top+o}():e.offset().top;if(c>=o&&c<=r&&!e.attr("src")){var m=e.attr("lay-src");layui.img(m,function(){var l=t.lazyimg.elem.eq(i);e.attr("src",m).removeAttr("lay-src"),l[0]&&f(l),i++})}},f=function(e,o){var f=a?(o||n).height():l(window).height(),m=n.scrollTop(),u=m+f;if(t.lazyimg.elem=l(r),e)c(e,f);else for(var s=0;su)break}};if(f(),!o){var m;n.on("scroll",function(){var e=l(this);m&&clearTimeout(m),m=setTimeout(function(){f(null,e)},50)}),o=!0}return f},e("flow",new o)}); -------------------------------------------------------------------------------- /src/com/school/daoImp/LoginDaoImp.java: -------------------------------------------------------------------------------- 1 | package com.school.daoImp; 2 | 3 | import com.school.dao.LoginDao; 4 | import com.school.pojo.Login; 5 | import com.school.util.JDBCUtil; 6 | 7 | import java.sql.Connection; 8 | import java.sql.PreparedStatement; 9 | import java.sql.ResultSet; 10 | import java.sql.SQLException; 11 | 12 | 13 | public class LoginDaoImp implements LoginDao { 14 | 15 | 16 | 17 | @Override 18 | public Login login(String username, String password) { 19 | Connection conn = JDBCUtil.getConn(); 20 | PreparedStatement ps = null; 21 | ResultSet rs = null; 22 | 23 | String sql = "select username,password from login where username=? and password=?"; 24 | Login login=null; 25 | try { 26 | 27 | ps = conn.prepareStatement(sql); 28 | ps.setString(1, username); 29 | ps.setString(2, password); 30 | rs = ps.executeQuery(); 31 | if(rs.next()){ 32 | login=new Login(); 33 | login.setUsername(rs.getString(1)); 34 | login.setPassword(rs.getString(2)); 35 | } 36 | } catch (SQLException e) { 37 | e.printStackTrace(); 38 | throw new RuntimeException("出现错误!"); 39 | }finally{ 40 | JDBCUtil.release(conn, ps, rs); 41 | } 42 | return login; 43 | } 44 | 45 | @Override 46 | public Integer register(String username, String password) { 47 | 48 | Connection conn = JDBCUtil.getConn(); 49 | PreparedStatement ps = null; 50 | ResultSet rs = null; 51 | String sql ="insert into login(username,password) values(?,?)"; 52 | int affectedLine = 0;//受影响的行数 53 | try { 54 | 55 | ps = conn.prepareStatement(sql); 56 | ps.setString(1, username); 57 | ps.setString(2, password); 58 | affectedLine = ps.executeUpdate(); 59 | 60 | } catch (SQLException e) { 61 | e.printStackTrace(); 62 | throw new RuntimeException("出现错误!"); 63 | }finally{ 64 | JDBCUtil.release(conn, ps, rs); 65 | } 66 | return affectedLine; 67 | 68 | } 69 | } 70 | -------------------------------------------------------------------------------- /src/com/school/util/JDBCUtil.java: -------------------------------------------------------------------------------- 1 | package com.school.util; 2 | 3 | import java.io.FileInputStream; 4 | import java.io.FileNotFoundException; 5 | import java.io.IOException; 6 | import java.io.InputStream; 7 | import java.net.URISyntaxException; 8 | import java.sql.*; 9 | import java.util.Properties; 10 | 11 | public class JDBCUtil { 12 | 13 | private static String DriverClass=null; 14 | private static String URL=null; 15 | private static String userName=null; 16 | private static String passWord=null; 17 | private static final ThreadLocal thread_local_db=new ThreadLocal(); 18 | 19 | static{ 20 | try { 21 | Properties ps = new Properties(); 22 | String path = JDBCUtil.class.getClassLoader().getResource("").toURI().getPath(); 23 | InputStream is = new FileInputStream(path+"jdbc.properties"); 24 | ps.load(is); 25 | DriverClass = ps.getProperty("driverClass"); 26 | URL = ps.getProperty("url"); 27 | userName = ps.getProperty("userName"); 28 | passWord = ps.getProperty("passWord"); 29 | } catch (FileNotFoundException e) { 30 | e.printStackTrace(); 31 | } catch (IOException e) { 32 | e.printStackTrace(); 33 | } catch (URISyntaxException e) { 34 | e.printStackTrace(); 35 | } 36 | } 37 | 38 | // 获取连接 39 | public static Connection getConn(){ 40 | Connection Conn=null; 41 | try { 42 | if(Conn == null){//&& Conn.isClosed() 43 | Class.forName(DriverClass); 44 | Conn = DriverManager.getConnection(URL, userName, passWord); 45 | //Conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/sales", "root", "123"); 46 | thread_local_db.set(Conn);// 把连接对象放入线程池 47 | } 48 | Conn = (Connection) thread_local_db.get(); 49 | } catch (ClassNotFoundException e) { 50 | e.printStackTrace(); 51 | } catch (SQLException e) { 52 | e.printStackTrace(); 53 | } 54 | return Conn; 55 | } 56 | 57 | // 关闭资源 58 | public static void release(Connection Conn, Statement st, ResultSet rs){ 59 | try { 60 | if(rs != null){ 61 | rs.close(); 62 | } 63 | if(st != null){ 64 | st.close(); 65 | } 66 | if(Conn != null){ 67 | Conn.close(); 68 | } 69 | } catch (SQLException e) { 70 | e.printStackTrace(); 71 | } finally{ 72 | rs=null; 73 | st=null; 74 | Conn=null; 75 | } 76 | } 77 | 78 | } 79 | -------------------------------------------------------------------------------- /web/login.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 登录--后台管理 6 | 7 | 8 | 13 | 14 | 15 | 16 | 17 |
18 | 36 | 37 | 38 | 39 | 40 | 66 | 67 | -------------------------------------------------------------------------------- /web/layui/lay/modules/rate.js: -------------------------------------------------------------------------------- 1 | /** layui-v2.5.6 MIT License By https://www.layui.com */ 2 | ;layui.define("jquery",function(e){"use strict";var a=layui.jquery,i={config:{},index:layui.rate?layui.rate.index+1e4:0,set:function(e){var i=this;return i.config=a.extend({},i.config,e),i},on:function(e,a){return layui.onevent.call(this,n,e,a)}},l=function(){var e=this,a=e.config;return{setvalue:function(a){e.setvalue.call(e,a)},config:a}},n="rate",t="layui-rate",o="layui-icon-rate",s="layui-icon-rate-solid",u="layui-icon-rate-half",r="layui-icon-rate-solid layui-icon-rate-half",c="layui-icon-rate-solid layui-icon-rate",f="layui-icon-rate layui-icon-rate-half",v=function(e){var l=this;l.index=++i.index,l.config=a.extend({},l.config,i.config,e),l.render()};v.prototype.config={length:5,text:!1,readonly:!1,half:!1,value:0,theme:""},v.prototype.render=function(){var e=this,i=e.config,l=i.theme?'style="color: '+i.theme+';"':"";i.elem=a(i.elem),parseInt(i.value)!==i.value&&(i.half||(i.value=Math.ceil(i.value)-i.value<.5?Math.ceil(i.value):Math.floor(i.value)));for(var n='
    ",u=1;u<=i.length;u++){var r='
  • ";i.half&&parseInt(i.value)!==i.value&&u==Math.ceil(i.value)?n=n+'
  • ":n+=r}n+="
"+(i.text?''+i.value+"星":"")+"";var c=i.elem,f=c.next("."+t);f[0]&&f.remove(),e.elemTemp=a(n),i.span=e.elemTemp.next("span"),i.setText&&i.setText(i.value),c.html(e.elemTemp),c.addClass("layui-inline"),i.readonly||e.action()},v.prototype.setvalue=function(e){var a=this,i=a.config;i.value=e,a.render()},v.prototype.action=function(){var e=this,i=e.config,l=e.elemTemp,n=l.find("i").width();l.children("li").each(function(e){var t=e+1,v=a(this);v.on("click",function(e){if(i.value=t,i.half){var o=e.pageX-a(this).offset().left;o<=n/2&&(i.value=i.value-.5)}i.text&&l.next("span").text(i.value+"星"),i.choose&&i.choose(i.value),i.setText&&i.setText(i.value)}),v.on("mousemove",function(e){if(l.find("i").each(function(){a(this).addClass(o).removeClass(r)}),l.find("i:lt("+t+")").each(function(){a(this).addClass(s).removeClass(f)}),i.half){var c=e.pageX-a(this).offset().left;c<=n/2&&v.children("i").addClass(u).removeClass(s)}}),v.on("mouseleave",function(){l.find("i").each(function(){a(this).addClass(o).removeClass(r)}),l.find("i:lt("+Math.floor(i.value)+")").each(function(){a(this).addClass(s).removeClass(f)}),i.half&&parseInt(i.value)!==i.value&&l.children("li:eq("+Math.floor(i.value)+")").children("i").addClass(u).removeClass(c)})})},v.prototype.events=function(){var e=this;e.config},i.render=function(e){var a=new v(e);return l.call(a)},e(n,i)}); -------------------------------------------------------------------------------- /web/register.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 注册--后台管理 6 | 7 | 8 | 13 | 14 | 15 | 16 | 17 |
18 | 39 | 40 | 41 | 42 | 43 | 72 | 73 | -------------------------------------------------------------------------------- /web/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 信息后台管理 7 | 8 | 9 | 10 |
11 |
12 | 13 | 14 | 18 |
19 | 20 |
21 |
22 | 23 | 33 |
34 |
35 | 36 |
37 | 38 | 39 |
40 | 41 | 45 |
46 | 47 | 48 | 77 | 78 | -------------------------------------------------------------------------------- /src/com/school/controller/LoginController.java: -------------------------------------------------------------------------------- 1 | package com.school.controller; 2 | 3 | 4 | import com.alibaba.fastjson.JSON; 5 | import com.school.pojo.Login; 6 | import com.school.service.LoginService; 7 | import com.school.serviceImp.LoginServiceImp; 8 | import com.school.util.ResultUtil; 9 | 10 | import javax.servlet.ServletException; 11 | import javax.servlet.annotation.WebServlet; 12 | import javax.servlet.http.HttpServlet; 13 | import javax.servlet.http.HttpServletRequest; 14 | import javax.servlet.http.HttpServletResponse; 15 | import java.io.IOException; 16 | 17 | @WebServlet("/loginController") 18 | public class LoginController extends HttpServlet { 19 | protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 20 | response.setContentType("text/javascript;charset=UTF-8"); 21 | LoginService loginService=new LoginServiceImp(); 22 | 23 | String method = (String)request.getParameter("method"); 24 | try { 25 | if("login".equals(method)){ 26 | String username=(String)request.getParameter("username"); 27 | String password=(String)request.getParameter("password"); 28 | Login login= loginService.login(username,password); 29 | if(login!=null){ 30 | request.getSession().setAttribute("user",login); 31 | response.getWriter().write(JSON.toJSONString( ResultUtil.success("登录成功!"))); 32 | }else{ 33 | response.getWriter().write(JSON.toJSONString( ResultUtil.error("登录失败!"))); 34 | } 35 | } 36 | if("register".equals(method)){ 37 | String username=(String)request.getParameter("username"); 38 | String password=(String)request.getParameter("password"); 39 | Login login= loginService.login(username,password); 40 | if(login!=null){ 41 | response.getWriter().write(JSON.toJSONString( ResultUtil.error("用户名已经被注册!"))); 42 | }else{ 43 | Integer num= loginService.register(username,password); 44 | if(num ==1){ 45 | response.getWriter().write(JSON.toJSONString( ResultUtil.success("注册成功!"))); 46 | ; 47 | }else{ 48 | response.getWriter().write(JSON.toJSONString( ResultUtil.success("注册失败!"))); 49 | ; 50 | } 51 | } 52 | } 53 | if("loginOut".equals(method)){ 54 | request.getSession().removeAttribute("user"); 55 | response.getWriter().write(JSON.toJSONString( ResultUtil.success("退出成功!"))); 56 | } 57 | } catch (Exception e) { 58 | e.printStackTrace(); 59 | } 60 | } 61 | protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 62 | doGet(request, response); 63 | } 64 | 65 | 66 | } 67 | -------------------------------------------------------------------------------- /web/layui/lay/modules/util.js: -------------------------------------------------------------------------------- 1 | /** layui-v2.5.6 MIT License By https://www.layui.com */ 2 | ;layui.define("jquery",function(e){"use strict";var t=layui.$,i={fixbar:function(e){var i,n,a="layui-fixbar",o="layui-fixbar-top",r=t(document),l=t("body");e=t.extend({showHeight:200},e),e.bar1=e.bar1===!0?"":e.bar1,e.bar2=e.bar2===!0?"":e.bar2,e.bgcolor=e.bgcolor?"background-color:"+e.bgcolor:"";var c=[e.bar1,e.bar2,""],u=t(['
    ',e.bar1?'
  • '+c[0]+"
  • ":"",e.bar2?'
  • '+c[1]+"
  • ":"",'
  • '+c[2]+"
  • ","
"].join("")),g=u.find("."+o),s=function(){var t=r.scrollTop();t>=e.showHeight?i||(g.show(),i=1):i&&(g.hide(),i=0)};t("."+a)[0]||("object"==typeof e.css&&u.css(e.css),l.append(u),s(),u.find("li").on("click",function(){var i=t(this),n=i.attr("lay-type");"top"===n&&t("html,body").animate({scrollTop:0},200),e.click&&e.click.call(this,n)}),r.on("scroll",function(){clearTimeout(n),n=setTimeout(function(){s()},100)}))},countdown:function(e,t,i){var n=this,a="function"==typeof t,o=new Date(e).getTime(),r=new Date(!t||a?(new Date).getTime():t).getTime(),l=o-r,c=[Math.floor(l/864e5),Math.floor(l/36e5)%24,Math.floor(l/6e4)%60,Math.floor(l/1e3)%60];a&&(i=t);var u=setTimeout(function(){n.countdown(e,r+1e3,i)},1e3);return i&&i(l>0?c:[0,0,0,0],t,u),l<=0&&clearTimeout(u),u},timeAgo:function(e,t){var i=this,n=[[],[]],a=(new Date).getTime()-new Date(e).getTime();return a>26784e5?(a=new Date(e),n[0][0]=i.digit(a.getFullYear(),4),n[0][1]=i.digit(a.getMonth()+1),n[0][2]=i.digit(a.getDate()),t||(n[1][0]=i.digit(a.getHours()),n[1][1]=i.digit(a.getMinutes()),n[1][2]=i.digit(a.getSeconds())),n[0].join("-")+" "+n[1].join(":")):a>=864e5?(a/1e3/60/60/24|0)+"天前":a>=36e5?(a/1e3/60/60|0)+"小时前":a>=18e4?(a/1e3/60|0)+"分钟前":a<0?"未来":"刚刚"},digit:function(e,t){var i="";e=String(e),t=t||2;for(var n=e.length;n/g,">").replace(/'/g,"'").replace(/"/g,""")},event:function(e,n,a){var o=t("body");return a=a||"click",n=i.event[e]=t.extend(!0,i.event[e],n)||{},i.event.UTIL_EVENT_CALLBACK=i.event.UTIL_EVENT_CALLBACK||{},o.off(a,"*["+e+"]",i.event.UTIL_EVENT_CALLBACK[e]),i.event.UTIL_EVENT_CALLBACK[e]=function(){var i=t(this),a=i.attr(e);"function"==typeof n[a]&&n[a].call(this,i)},o.on(a,"*["+e+"]",i.event.UTIL_EVENT_CALLBACK[e]),n}};!function(e,t,i){"$:nomunge";function n(){a=t[l](function(){o.each(function(){var t=e(this),i=t.width(),n=t.height(),a=e.data(this,u);(i!==a.w||n!==a.h)&&t.trigger(c,[a.w=i,a.h=n])}),n()},r[g])}var a,o=e([]),r=e.resize=e.extend(e.resize,{}),l="setTimeout",c="resize",u=c+"-special-event",g="delay",s="throttleWindow";r[g]=250,r[s]=!0,e.event.special[c]={setup:function(){if(!r[s]&&this[l])return!1;var t=e(this);o=o.add(t),e.data(this,u,{w:t.width(),h:t.height()}),1===o.length&&n()},teardown:function(){if(!r[s]&&this[l])return!1;var t=e(this);o=o.not(t),t.removeData(u),o.length||clearTimeout(a)},add:function(t){function n(t,n,o){var r=e(this),l=e.data(this,u)||{};l.w=n!==i?n:r.width(),l.h=o!==i?o:r.height(),a.apply(this,arguments)}if(!r[s]&&this[l])return!1;var a;return e.isFunction(t)?(a=t,n):(a=t.handler,void(t.handler=n))}}}(t,window),e("util",i)}); -------------------------------------------------------------------------------- /web/layui/lay/modules/carousel.js: -------------------------------------------------------------------------------- 1 | /** layui-v2.5.6 MIT License By https://www.layui.com */ 2 | ;layui.define("jquery",function(e){"use strict";var i=layui.$,n=(layui.hint(),layui.device(),{config:{},set:function(e){var n=this;return n.config=i.extend({},n.config,e),n},on:function(e,i){return layui.onevent.call(this,t,e,i)}}),t="carousel",a="layui-this",l=">*[carousel-item]>*",o="layui-carousel-left",r="layui-carousel-right",d="layui-carousel-prev",s="layui-carousel-next",u="layui-carousel-arrow",c="layui-carousel-ind",m=function(e){var t=this;t.config=i.extend({},t.config,n.config,e),t.render()};m.prototype.config={width:"600px",height:"280px",full:!1,arrow:"hover",indicator:"inside",autoplay:!0,interval:3e3,anim:"",trigger:"click",index:0},m.prototype.render=function(){var e=this,n=e.config;n.elem=i(n.elem),n.elem[0]&&(e.elemItem=n.elem.find(l),n.index<0&&(n.index=0),n.index>=e.elemItem.length&&(n.index=e.elemItem.length-1),n.interval<800&&(n.interval=800),n.full?n.elem.css({position:"fixed",width:"100%",height:"100%",zIndex:9999}):n.elem.css({width:n.width,height:n.height}),n.elem.attr("lay-anim",n.anim),e.elemItem.eq(n.index).addClass(a),e.elemItem.length<=1||(e.indicator(),e.arrow(),e.autoplay(),e.events()))},m.prototype.reload=function(e){var n=this;clearInterval(n.timer),n.config=i.extend({},n.config,e),n.render()},m.prototype.prevIndex=function(){var e=this,i=e.config,n=i.index-1;return n<0&&(n=e.elemItem.length-1),n},m.prototype.nextIndex=function(){var e=this,i=e.config,n=i.index+1;return n>=e.elemItem.length&&(n=0),n},m.prototype.addIndex=function(e){var i=this,n=i.config;e=e||1,n.index=n.index+e,n.index>=i.elemItem.length&&(n.index=0)},m.prototype.subIndex=function(e){var i=this,n=i.config;e=e||1,n.index=n.index-e,n.index<0&&(n.index=i.elemItem.length-1)},m.prototype.autoplay=function(){var e=this,i=e.config;i.autoplay&&(clearInterval(e.timer),e.timer=setInterval(function(){e.slide()},i.interval))},m.prototype.arrow=function(){var e=this,n=e.config,t=i(['",'"].join(""));n.elem.attr("lay-arrow",n.arrow),n.elem.find("."+u)[0]&&n.elem.find("."+u).remove(),n.elem.append(t),t.on("click",function(){var n=i(this),t=n.attr("lay-type");e.slide(t)})},m.prototype.indicator=function(){var e=this,n=e.config,t=e.elemInd=i(['
    ',function(){var i=[];return layui.each(e.elemItem,function(e){i.push("")}),i.join("")}(),"
"].join(""));n.elem.attr("lay-indicator",n.indicator),n.elem.find("."+c)[0]&&n.elem.find("."+c).remove(),n.elem.append(t),"updown"===n.anim&&t.css("margin-top",-(t.height()/2)),t.find("li").on("hover"===n.trigger?"mouseover":n.trigger,function(){var t=i(this),a=t.index();a>n.index?e.slide("add",a-n.index):aa.pages&&(a.curr=a.pages),t<0?t=1:t>a.pages&&(t=a.pages),a.prev="prev"in a?a.prev:"上一页",a.next="next"in a?a.next:"下一页";var n=a.pages>t?Math.ceil((a.curr+(t>1?1:0))/(t>0?t:1)):1,i={prev:function(){return a.prev?''+a.prev+"":""}(),page:function(){var e=[];if(a.count<1)return"";n>1&&a.first!==!1&&0!==t&&e.push(''+(a.first||1)+"");var i=Math.floor((t-1)/2),r=n>1?a.curr-i:1,u=n>1?function(){var e=a.curr+(t-i-1);return e>a.pages?a.pages:e}():t;for(u-r2&&e.push('');r<=u;r++)r===a.curr?e.push('"+r+""):e.push(''+r+"");return a.pages>t&&a.pages>u&&a.last!==!1&&(u+1…'),0!==t&&e.push(''+(a.last||a.pages)+"")),e.join("")}(),next:function(){return a.next?''+a.next+"":""}(),count:'共 '+a.count+" 条",limit:function(){var e=['"}(),refresh:['','',""].join(""),skip:function(){return['到第','','页',""].join("")}()};return['
',function(){var e=[];return layui.each(a.layout,function(a,t){i[t]&&e.push(i[t])}),e.join("")}(),"
"].join("")},u.prototype.jump=function(e,a){if(e){var t=this,i=t.config,r=e.children,u=e[n]("button")[0],l=e[n]("input")[0],p=e[n]("select")[0],c=function(){var e=0|l.value.replace(/\s|\D/g,"");e&&(i.curr=e,t.render())};if(a)return c();for(var o=0,y=r.length;oi.pages||(i.curr=e,t.render())});p&&s.on(p,"change",function(){var e=this.value;i.curr*e>i.count&&(i.curr=Math.ceil(i.count/e)),i.limit=e,t.render()}),u&&s.on(u,"click",function(){c()})}},u.prototype.skip=function(e){if(e){var a=this,t=e[n]("input")[0];t&&s.on(t,"keyup",function(t){var n=this.value,i=t.keyCode;/^(37|38|39|40)$/.test(i)||(/\D/.test(n)&&(this.value=n.replace(/\D/,"")),13===i&&a.jump(e,!0))})}},u.prototype.render=function(e){var n=this,i=n.config,r=n.type(),u=n.view();2===r?i.elem&&(i.elem.innerHTML=u):3===r?i.elem.html(u):a[t](i.elem)&&(a[t](i.elem).innerHTML=u),i.jump&&i.jump(i,e);var s=a[t]("layui-laypage-"+i.index);n.jump(s),i.hash&&!e&&(location.hash="!"+i.hash+"="+i.curr),n.skip(s)};var s={render:function(e){var a=new u(e);return a.index},index:layui.laypage?layui.laypage.index+1e4:0,on:function(e,a,t){return e.attachEvent?e.attachEvent("on"+a,function(a){a.target=a.srcElement,t.call(e,a)}):e.addEventListener(a,t,!1),this}};e(i,s)}); -------------------------------------------------------------------------------- /src/com/school/controller/TeacherController.java: -------------------------------------------------------------------------------- 1 | package com.school.controller; 2 | 3 | 4 | import com.alibaba.fastjson.JSON; 5 | import com.school.pojo.Teacher; 6 | import com.school.service.TeacherService; 7 | import com.school.serviceImp.TeacherServiceImp; 8 | import com.school.util.ResultUtil; 9 | 10 | import javax.servlet.ServletException; 11 | import javax.servlet.annotation.WebServlet; 12 | import javax.servlet.http.HttpServlet; 13 | import javax.servlet.http.HttpServletRequest; 14 | import javax.servlet.http.HttpServletResponse; 15 | import java.io.IOException; 16 | import java.util.HashMap; 17 | import java.util.Map; 18 | 19 | @WebServlet("/teacherController") 20 | public class TeacherController extends HttpServlet { 21 | protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 22 | response.setContentType("text/javascript;charset=UTF-8"); 23 | TeacherService teacherService = new TeacherServiceImp(); 24 | 25 | String method = (String) request.getParameter("method"); 26 | try { 27 | if ("add".equals(method)) { 28 | Teacher teacher = new Teacher(); 29 | teacher.setName(request.getParameter("name")); 30 | teacher.setProfessional(request.getParameter("professional")); 31 | teacher.setDegree(request.getParameter("degree")); 32 | teacher.setCourse(request.getParameter("course")); 33 | teacher.setSex(Integer.valueOf(request.getParameter("sex"))); 34 | Integer num = teacherService.add(teacher); 35 | if (num == 1) { 36 | response.getWriter().write(JSON.toJSONString(ResultUtil.success("添加成功!"))); 37 | } else { 38 | response.getWriter().write(JSON.toJSONString(ResultUtil.success("添加失败!"))); 39 | } 40 | } 41 | if ("update".equals(method)) { 42 | Teacher teacher = new Teacher(); 43 | teacher.setName(request.getParameter("name")); 44 | teacher.setProfessional(request.getParameter("professional")); 45 | teacher.setDegree(request.getParameter("degree")); 46 | teacher.setCourse(request.getParameter("course")); 47 | teacher.setSex(Integer.valueOf(request.getParameter("sex"))); 48 | teacher.setId(Integer.valueOf(request.getParameter("id"))); 49 | Integer num = teacherService.update(teacher); 50 | if (num == 1) { 51 | response.getWriter().write(JSON.toJSONString(ResultUtil.success("更新成功!"))); 52 | } else { 53 | response.getWriter().write(JSON.toJSONString(ResultUtil.success("更新失败!"))); 54 | } 55 | } 56 | if ("delete".equals(method)) { 57 | Integer id = Integer.valueOf(request.getParameter("id")); 58 | Integer num = teacherService.delete(id); 59 | if (num == 1) { 60 | response.getWriter().write(JSON.toJSONString(ResultUtil.success("删除成功!"))); 61 | } else { 62 | response.getWriter().write(JSON.toJSONString(ResultUtil.success("删除失败!"))); 63 | } 64 | } 65 | if ("findAllToSys".equals(method)) { 66 | Integer page = Integer.valueOf(request.getParameter("page")); 67 | Integer limit = Integer.valueOf(request.getParameter("limit")); 68 | String nameSearch = (String)request.getParameter("nameSearch"); 69 | Map map=new HashMap(); 70 | map.put("page", (page-1)*limit); 71 | map.put("limit",limit); 72 | map.put("nameSearch",nameSearch); 73 | ResultUtil resultUtil = teacherService.findAllToSys(map); 74 | response.getWriter().write(JSON.toJSONString(resultUtil)); 75 | } 76 | 77 | if ("findById".equals(method)) { 78 | Integer id = Integer.valueOf(request.getParameter("id")); 79 | Teacher teacher = teacherService.findById(id); 80 | response.getWriter().write(JSON.toJSONString(ResultUtil.success(teacher))); 81 | } 82 | 83 | 84 | } catch (Exception e) { 85 | e.printStackTrace(); 86 | } 87 | } 88 | 89 | protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 90 | doGet(request, response); 91 | } 92 | 93 | 94 | } 95 | -------------------------------------------------------------------------------- /web/teacherAdd.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 添加学生信息 6 | 7 | 8 | 10 | 11 | 12 | 13 | 14 | 32 | 33 | 34 |
35 |
36 | 37 |
38 | 40 |
41 |
42 |
43 | 44 |
45 | 47 |
48 |
49 |
50 | 51 |
52 | 54 |
55 |
56 |
57 | 58 |
59 | 63 |
64 |
65 |
66 | 67 |
68 | 70 |
71 |
72 | 73 |
74 |
75 | 76 |
77 |
78 |
79 | 80 | 139 | 140 | -------------------------------------------------------------------------------- /web/studentAdd.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 添加学生信息 6 | 7 | 8 | 10 | 11 | 12 | 13 | 14 | 32 | 33 | 34 |
35 |
36 | 37 |
38 | 40 |
41 |
42 |
43 | 44 |
45 | 47 |
48 |
49 |
50 | 51 |
52 | 54 |
55 |
56 |
57 | 58 |
59 | 63 |
64 |
65 |
66 | 67 |
68 | 70 |
71 |
72 |
73 | 74 |
75 | 77 |
78 |
79 |
80 | 81 |
82 | 84 |
85 |
86 | 87 |
88 |
89 | 90 |
91 |
92 |
93 | 94 | 153 | 154 | -------------------------------------------------------------------------------- /web/teacherEdit.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 编辑教师 6 | 7 | 8 | 10 | 11 | 12 | 13 | 14 | 32 | 33 | 34 |
35 | 36 |
37 | 38 |
39 | 41 |
42 |
43 |
44 | 45 |
46 | 48 |
49 |
50 |
51 | 52 |
53 | 55 |
56 |
57 |
58 | 59 |
60 | 64 |
65 |
66 |
67 | 68 |
69 | 71 |
72 |
73 | 74 | 75 |
76 |
77 | 78 |
79 |
80 |
81 | 82 | 83 | 84 | 85 | 86 | 166 | 167 | -------------------------------------------------------------------------------- /web/layui/lay/modules/transfer.js: -------------------------------------------------------------------------------- 1 | /** layui-v2.5.6 MIT License By https://www.layui.com */ 2 | ;layui.define(["laytpl","form"],function(e){"use strict";var a=layui.$,t=layui.laytpl,n=layui.form,i="transfer",l={config:{},index:layui[i]?layui[i].index+1e4:0,set:function(e){var t=this;return t.config=a.extend({},t.config,e),t},on:function(e,a){return layui.onevent.call(this,i,e,a)}},r=function(){var e=this,a=e.config,t=a.id||e.index;return r.that[t]=e,r.config[t]=a,{config:a,reload:function(a){e.reload.call(e,a)},getData:function(){return e.getData.call(e)}}},c="layui-hide",o="layui-btn-disabled",d="layui-none",s="layui-transfer-box",u="layui-transfer-header",h="layui-transfer-search",f="layui-transfer-active",y="layui-transfer-data",p=function(e){return e=e||{},['
','
','","
","{{# if(d.data.showSearch){ }}",'","{{# } }}",'
    ',"
    "].join("")},v=['
    ',p({index:0,checkAllName:"layTransferLeftCheckAll"}),'
    ','",'","
    ",p({index:1,checkAllName:"layTransferRightCheckAll"}),"
    "].join(""),x=function(e){var t=this;t.index=++l.index,t.config=a.extend({},t.config,l.config,e),t.render()};x.prototype.config={title:["列表一","列表二"],width:200,height:360,data:[],value:[],showSearch:!1,id:"",text:{none:"无数据",searchNone:"无匹配数据"}},x.prototype.reload=function(e){var t=this;layui.each(e,function(e,a){a.constructor===Array&&delete t.config[e]}),t.config=a.extend(!0,{},t.config,e),t.render()},x.prototype.render=function(){var e=this,n=e.config,i=e.elem=a(t(v).render({data:n,index:e.index})),l=n.elem=a(n.elem);l[0]&&(n.data=n.data||[],n.value=n.value||[],e.key=n.id||e.index,l.html(e.elem),e.layBox=e.elem.find("."+s),e.layHeader=e.elem.find("."+u),e.laySearch=e.elem.find("."+h),e.layData=i.find("."+y),e.layBtn=i.find("."+f+" .layui-btn"),e.layBox.css({width:n.width,height:n.height}),e.layData.css({height:function(){return n.height-e.layHeader.outerHeight()-e.laySearch.outerHeight()-2}()}),e.renderData(),e.events())},x.prototype.renderData=function(){var e=this,a=(e.config,[{checkName:"layTransferLeftCheck",views:[]},{checkName:"layTransferRightCheck",views:[]}]);e.parseData(function(e){var t=e.selected?1:0,n=["
  • ",'',"
  • "].join("");a[t].views.push(n),delete e.selected}),e.layData.eq(0).html(a[0].views.join("")),e.layData.eq(1).html(a[1].views.join("")),e.renderCheckBtn()},x.prototype.renderForm=function(e){n.render(e,"LAY-transfer-"+this.index)},x.prototype.renderCheckBtn=function(e){var t=this,n=t.config;e=e||{},t.layBox.each(function(i){var l=a(this),r=l.find("."+y),d=l.find("."+u).find('input[type="checkbox"]'),s=r.find('input[type="checkbox"]'),h=0,f=!1;if(s.each(function(){var e=a(this).data("hide");(this.checked||this.disabled||e)&&h++,this.checked&&!e&&(f=!0)}),d.prop("checked",f&&h===s.length),t.layBtn.eq(i)[f?"removeClass":"addClass"](o),!e.stopNone){var p=r.children("li:not(."+c+")").length;t.noneView(r,p?"":n.text.none)}}),t.renderForm("checkbox")},x.prototype.noneView=function(e,t){var n=a('

    '+(t||"")+"

    ");e.find("."+d)[0]&&e.find("."+d).remove(),t.replace(/\s/g,"")&&e.append(n)},x.prototype.setValue=function(){var e=this,t=e.config,n=[];return e.layBox.eq(1).find("."+y+' input[type="checkbox"]').each(function(){var e=a(this).data("hide");e||n.push(this.value)}),t.value=n,e},x.prototype.parseData=function(e){var t=this,n=t.config,i=[];return layui.each(n.data,function(t,l){l=("function"==typeof n.parseData?n.parseData(l):l)||l,i.push(l=a.extend({},l)),layui.each(n.value,function(e,a){a==l.value&&(l.selected=!0)}),e&&e(l)}),n.data=i,t},x.prototype.getData=function(e){var a=this,t=a.config,n=[];return a.setValue(),layui.each(e||t.value,function(e,a){layui.each(t.data,function(e,t){delete t.selected,a==t.value&&n.push(t)})}),n},x.prototype.events=function(){var e=this,t=e.config;e.elem.on("click",'input[lay-filter="layTransferCheckbox"]+',function(){var t=a(this).prev(),n=t[0].checked,i=t.parents("."+s).eq(0).find("."+y);t[0].disabled||("all"===t.attr("lay-type")&&i.find('input[type="checkbox"]').each(function(){this.disabled||(this.checked=n)}),e.renderCheckBtn({stopNone:!0}))}),e.layBtn.on("click",function(){var n=a(this),i=n.data("index"),l=e.layBox.eq(i),r=[];if(!n.hasClass(o)){e.layBox.eq(i).each(function(t){var n=a(this),i=n.find("."+y);i.children("li").each(function(){var t=a(this),n=t.find('input[type="checkbox"]'),i=n.data("hide");n[0].checked&&!i&&(n[0].checked=!1,l.siblings("."+s).find("."+y).append(t.clone()),t.remove(),r.push(n[0].value)),e.setValue()})}),e.renderCheckBtn();var c=l.siblings("."+s).find("."+h+" input");""===c.val()||c.trigger("keyup"),t.onchange&&t.onchange(e.getData(r),i)}}),e.laySearch.find("input").on("keyup",function(){var n=this.value,i=a(this).parents("."+h).eq(0).siblings("."+y),l=i.children("li");l.each(function(){var e=a(this),t=e.find('input[type="checkbox"]'),i=t[0].title.indexOf(n)!==-1;e[i?"removeClass":"addClass"](c),t.data("hide",!i)}),e.renderCheckBtn();var r=l.length===i.children("li."+c).length;e.noneView(i,r?t.text.searchNone:"")})},r.that={},r.config={},l.reload=function(e,a){var t=r.that[e];return t.reload(a),r.call(t)},l.getData=function(e){var a=r.that[e];return a.getData()},l.render=function(e){var a=new x(e);return r.call(a)},e(i,l)}); -------------------------------------------------------------------------------- /web/studentEdit.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 编辑教师 6 | 7 | 8 | 10 | 11 | 12 | 13 | 14 | 32 | 33 | 34 |
    35 | 36 | 37 |
    38 | 39 |
    40 | 42 |
    43 |
    44 |
    45 | 46 |
    47 | 49 |
    50 |
    51 |
    52 | 53 |
    54 | 56 |
    57 |
    58 |
    59 | 60 |
    61 | 65 |
    66 |
    67 |
    68 | 69 |
    70 | 72 |
    73 |
    74 |
    75 | 76 |
    77 | 79 |
    80 |
    81 |
    82 | 83 |
    84 | 86 |
    87 |
    88 | 89 | 90 |
    91 |
    92 | 93 |
    94 |
    95 |
    96 | 97 | 98 | 99 | 100 | 101 | 184 | 185 | -------------------------------------------------------------------------------- /web/layui/lay/modules/slider.js: -------------------------------------------------------------------------------- 1 | /** layui-v2.5.6 MIT License By https://www.layui.com */ 2 | ;layui.define("jquery",function(e){"use strict";var i=layui.jquery,t={config:{},index:layui.slider?layui.slider.index+1e4:0,set:function(e){var t=this;return t.config=i.extend({},t.config,e),t},on:function(e,i){return layui.onevent.call(this,n,e,i)}},a=function(){var e=this,i=e.config;return{setValue:function(i,t){return e.slide("set",i,t||0)},config:i}},n="slider",l="layui-disabled",s="layui-slider",r="layui-slider-bar",o="layui-slider-wrap",u="layui-slider-wrap-btn",d="layui-slider-tips",v="layui-slider-input",c="layui-slider-input-txt",m="layui-slider-input-btn",p="layui-slider-hover",f=function(e){var a=this;a.index=++t.index,a.config=i.extend({},a.config,t.config,e),a.render()};f.prototype.config={type:"default",min:0,max:100,value:0,step:1,showstep:!1,tips:!0,input:!1,range:!1,height:200,disabled:!1,theme:"#009688"},f.prototype.render=function(){var e=this,t=e.config;if(t.step<1&&(t.step=1),t.maxt.min?a:t.min,t.value[1]=n>t.min?n:t.min,t.value[0]=t.value[0]>t.max?t.max:t.value[0],t.value[1]=t.value[1]>t.max?t.max:t.value[1];var r=Math.floor((t.value[0]-t.min)/(t.max-t.min)*100),v=Math.floor((t.value[1]-t.min)/(t.max-t.min)*100),m=v-r+"%";r+="%",v+="%"}else{"object"==typeof t.value&&(t.value=Math.min.apply(null,t.value)),t.valuet.max&&(t.value=t.max);var m=Math.floor((t.value-t.min)/(t.max-t.min)*100)+"%"}var p=t.disabled?"#c2c2c2":t.theme,f='
    '+(t.tips?'
    ':"")+'
    '+(t.range?'
    ':"")+"
    ",h=i(t.elem),y=h.next("."+s);if(y[0]&&y.remove(),e.elemTemp=i(f),t.range?(e.elemTemp.find("."+o).eq(0).data("value",t.value[0]),e.elemTemp.find("."+o).eq(1).data("value",t.value[1])):e.elemTemp.find("."+o).data("value",t.value),h.html(e.elemTemp),"vertical"===t.type&&e.elemTemp.height(t.height+"px"),t.showstep){for(var g=(t.max-t.min)/t.step,b="",x=1;x')}e.elemTemp.append(b)}if(t.input&&!t.range){var w=i('
    ');h.css("position","relative"),h.append(w),h.find("."+c).children("input").val(t.value),"vertical"===t.type?w.css({left:0,top:-48}):e.elemTemp.css("margin-right",w.outerWidth()+15)}t.disabled?(e.elemTemp.addClass(l),e.elemTemp.find("."+u).addClass(l)):e.slide(),e.elemTemp.find("."+u).on("mouseover",function(){var a="vertical"===t.type?t.height:e.elemTemp[0].offsetWidth,n=e.elemTemp.find("."+o),l="vertical"===t.type?a-i(this).parent()[0].offsetTop-n.height():i(this).parent()[0].offsetLeft,s=l/a*100,r=i(this).parent().data("value"),u=t.setTips?t.setTips(r):r;e.elemTemp.find("."+d).html(u),"vertical"===t.type?e.elemTemp.find("."+d).css({bottom:s+"%","margin-bottom":"20px",display:"inline-block"}):e.elemTemp.find("."+d).css({left:s+"%",display:"inline-block"})}).on("mouseout",function(){e.elemTemp.find("."+d).css("display","none")})},f.prototype.slide=function(e,t,a){var n=this,l=n.config,s=n.elemTemp,f=function(){return"vertical"===l.type?l.height:s[0].offsetWidth},h=s.find("."+o),y=s.next("."+v),g=y.children("."+c).children("input").val(),b=100/((l.max-l.min)/Math.ceil(l.step)),x=function(e,i){e=Math.ceil(e)*b>100?Math.ceil(e)*b:Math.round(e)*b,e=e>100?100:e,h.eq(i).css("vertical"===l.type?"bottom":"left",e+"%");var t=T(h[0].offsetLeft),a=l.range?T(h[1].offsetLeft):0;"vertical"===l.type?(s.find("."+d).css({bottom:e+"%","margin-bottom":"20px"}),t=T(f()-h[0].offsetTop-h.height()),a=l.range?T(f()-h[1].offsetTop-h.height()):0):s.find("."+d).css("left",e+"%"),t=t>100?100:t,a=a>100?100:a;var n=Math.min(t,a),o=Math.abs(t-a);"vertical"===l.type?s.find("."+r).css({height:o+"%",bottom:n+"%"}):s.find("."+r).css({width:o+"%",left:n+"%"});var u=l.min+Math.round((l.max-l.min)*e/100);if(g=u,y.children("."+c).children("input").val(g),h.eq(i).data("value",u),u=l.setTips?l.setTips(u):u,s.find("."+d).html(u),l.range){var v=[h.eq(0).data("value"),h.eq(1).data("value")];v[0]>v[1]&&v.reverse()}l.change&&l.change(l.range?v:u)},T=function(e){var i=e/f()*100/b,t=Math.round(i)*b;return e==f()&&(t=Math.ceil(i)*b),t},w=i(['
    f()&&(r=f());var o=r/f()*100/b;x(o,e),t.addClass(p),s.find("."+d).show(),i.preventDefault()},o=function(){t.removeClass(p),s.find("."+d).hide()};M(r,o)})}),s.on("click",function(e){var t=i("."+u);if(!t.is(event.target)&&0===t.has(event.target).length&&t.length){var a,n="vertical"===l.type?f()-e.clientY+i(this).offset().top:e.clientX-i(this).offset().left;n<0&&(n=0),n>f()&&(n=f());var s=n/f()*100/b;a=l.range?"vertical"===l.type?Math.abs(n-parseInt(i(h[0]).css("bottom")))>Math.abs(n-parseInt(i(h[1]).css("bottom")))?1:0:Math.abs(n-h[0].offsetLeft)>Math.abs(n-h[1].offsetLeft)?1:0:0,x(s,a),e.preventDefault()}}),y.hover(function(){var e=i(this);e.children("."+m).fadeIn("fast")},function(){var e=i(this);e.children("."+m).fadeOut("fast")}),y.children("."+m).children("i").each(function(e){i(this).on("click",function(){g=1==e?g-l.stepl.max?l.max:Number(g)+l.step;var i=(g-l.min)/(l.max-l.min)*100/b;x(i,0)})});var q=function(){var e=this.value;e=isNaN(e)?0:e,e=el.max?l.max:e,this.value=e;var i=(e-l.min)/(l.max-l.min)*100/b;x(i,0)};y.children("."+c).children("input").on("keydown",function(e){13===e.keyCode&&(e.preventDefault(),q.call(this))}).on("change",q)},f.prototype.events=function(){var e=this;e.config},t.render=function(e){var i=new f(e);return a.call(i)},e(n,t)}); -------------------------------------------------------------------------------- /web/layui/lay/modules/upload.js: -------------------------------------------------------------------------------- 1 | /** layui-v2.5.6 MIT License By https://www.layui.com */ 2 | ;layui.define("layer",function(e){"use strict";var t=layui.$,i=layui.layer,n=layui.hint(),o=layui.device(),a={config:{},set:function(e){var i=this;return i.config=t.extend({},i.config,e),i},on:function(e,t){return layui.onevent.call(this,r,e,t)}},l=function(){var e=this;return{upload:function(t){e.upload.call(e,t)},reload:function(t){e.reload.call(e,t)},config:e.config}},r="upload",u="layui-upload-file",c="layui-upload-form",f="layui-upload-iframe",s="layui-upload-choose",p=function(e){var i=this;i.config=t.extend({},i.config,a.config,e),i.render()};p.prototype.config={accept:"images",exts:"",auto:!0,bindAction:"",url:"",field:"file",acceptMime:"",method:"post",data:{},drag:!0,size:0,number:0,multiple:!1},p.prototype.render=function(e){var i=this,e=i.config;e.elem=t(e.elem),e.bindAction=t(e.bindAction),i.file(),i.events()},p.prototype.file=function(){var e=this,i=e.config,n=e.elemFile=t(['"].join("")),a=i.elem.next();(a.hasClass(u)||a.hasClass(c))&&a.remove(),o.ie&&o.ie<10&&i.elem.wrap('
    '),e.isFile()?(e.elemFile=i.elem,i.field=i.elem[0].name):i.elem.after(n),o.ie&&o.ie<10&&e.initIE()},p.prototype.initIE=function(){var e=this,i=e.config,n=t(''),o=t(['
    ',"
    "].join(""));t("#"+f)[0]||t("body").append(n),i.elem.next().hasClass(c)||(e.elemFile.wrap(o),i.elem.next("."+c).append(function(){var e=[];return layui.each(i.data,function(t,i){i="function"==typeof i?i():i,e.push('')}),e.join("")}()))},p.prototype.msg=function(e){return i.msg(e,{icon:2,shift:6})},p.prototype.isFile=function(){var e=this.config.elem[0];if(e)return"input"===e.tagName.toLocaleLowerCase()&&"file"===e.type},p.prototype.preview=function(e){var t=this;window.FileReader&&layui.each(t.chooseFiles,function(t,i){var n=new FileReader;n.readAsDataURL(i),n.onload=function(){e&&e(t,i,this.result)}})},p.prototype.upload=function(e,i){var n,a=this,l=a.config,r=a.elemFile[0],u=function(){var i=0,n=0,o=e||a.files||a.chooseFiles||r.files,u=function(){l.multiple&&i+n===a.fileLength&&"function"==typeof l.allDone&&l.allDone({total:a.fileLength,successful:i,aborted:n})};layui.each(o,function(e,o){var r=new FormData;r.append(l.field,o),layui.each(l.data,function(e,t){t="function"==typeof t?t():t,r.append(e,t)});var c={url:l.url,type:"post",data:r,contentType:!1,processData:!1,dataType:"json",headers:l.headers||{},success:function(t){i++,d(e,t),u()},error:function(){n++,a.msg("请求上传接口出现异常"),m(e),u()}};"function"==typeof l.progress&&(c.xhr=function(){var e=t.ajaxSettings.xhr();return e.upload.addEventListener("progress",function(e){if(e.lengthComputable){var t=Math.floor(e.loaded/e.total*100);l.progress(t,l.item[0],e)}}),e}),t.ajax(c)})},c=function(){var e=t("#"+f);a.elemFile.parent().submit(),clearInterval(p.timer),p.timer=setInterval(function(){var t,i=e.contents().find("body");try{t=i.text()}catch(n){a.msg("获取上传后的响应信息出现异常"),clearInterval(p.timer),m()}t&&(clearInterval(p.timer),i.html(""),d(0,t))},30)},d=function(e,t){if(a.elemFile.next("."+s).remove(),r.value="","object"!=typeof t)try{t=JSON.parse(t)}catch(i){return t={},a.msg("请对上传接口返回有效JSON")}"function"==typeof l.done&&l.done(t,e||0,function(e){a.upload(e)})},m=function(e){l.auto&&(r.value=""),"function"==typeof l.error&&l.error(e||0,function(e){a.upload(e)})},h=l.exts,v=function(){var t=[];return layui.each(e||a.chooseFiles,function(e,i){t.push(i.name)}),t}(),g={preview:function(e){a.preview(e)},upload:function(e,t){var i={};i[e]=t,a.upload(i)},pushFile:function(){return a.files=a.files||{},layui.each(a.chooseFiles,function(e,t){a.files[e]=t}),a.files},resetFile:function(e,t,i){var n=new File([t],i);a.files=a.files||{},a.files[e]=n}},y=function(){if("choose"!==i&&!l.auto||(l.choose&&l.choose(g),"choose"!==i))return l.before&&l.before(g),o.ie?o.ie>9?u():c():void u()};if(v=0===v.length?r.value.match(/[^\/\\]+\..+/g)||[]||"":v,0!==v.length){switch(l.accept){case"file":if(h&&!RegExp("\\w\\.("+h+")$","i").test(escape(v)))return a.msg("选择的文件中包含不支持的格式"),r.value="";break;case"video":if(!RegExp("\\w\\.("+(h||"avi|mp4|wma|rmvb|rm|flash|3gp|flv")+")$","i").test(escape(v)))return a.msg("选择的视频中包含不支持的格式"),r.value="";break;case"audio":if(!RegExp("\\w\\.("+(h||"mp3|wav|mid")+")$","i").test(escape(v)))return a.msg("选择的音频中包含不支持的格式"),r.value="";break;default:if(layui.each(v,function(e,t){RegExp("\\w\\.("+(h||"jpg|png|gif|bmp|jpeg$")+")","i").test(escape(t))||(n=!0)}),n)return a.msg("选择的图片中包含不支持的格式"),r.value=""}if(a.fileLength=function(){var t=0,i=e||a.files||a.chooseFiles||r.files;return layui.each(i,function(){t++}),t}(),l.number&&a.fileLength>l.number)return a.msg("同时最多只能上传的数量为:"+l.number);if(l.size>0&&!(o.ie&&o.ie<10)){var F;if(layui.each(a.chooseFiles,function(e,t){if(t.size>1024*l.size){var i=l.size/1024;i=i>=1?i.toFixed(2)+"MB":l.size+"KB",r.value="",F=i}}),F)return a.msg("文件不能超过"+F)}y()}},p.prototype.reload=function(e){e=e||{},delete e.elem,delete e.bindAction;var i=this,e=i.config=t.extend({},i.config,a.config,e),n=e.elem.next();n.attr({name:e.name,accept:e.acceptMime,multiple:e.multiple})},p.prototype.events=function(){var e=this,i=e.config,a=function(t){e.chooseFiles={},layui.each(t,function(t,i){var n=(new Date).getTime();e.chooseFiles[n+"-"+t]=i})},l=function(t,n){var o=e.elemFile,a=t.length>1?t.length+"个文件":(t[0]||{}).name||o[0].value.match(/[^\/\\]+\..+/g)||[]||"";o.next().hasClass(s)&&o.next().remove(),e.upload(null,"choose"),e.isFile()||i.choose||o.after(''+a+"")};i.elem.off("upload.start").on("upload.start",function(){var o=t(this),a=o.attr("lay-data");if(a)try{a=new Function("return "+a)(),e.config=t.extend({},i,a)}catch(l){n.error("Upload element property lay-data configuration item has a syntax error: "+a)}e.config.item=o,e.elemFile[0].click()}),o.ie&&o.ie<10||i.elem.off("upload.over").on("upload.over",function(){var e=t(this);e.attr("lay-over","")}).off("upload.leave").on("upload.leave",function(){var e=t(this);e.removeAttr("lay-over")}).off("upload.drop").on("upload.drop",function(n,o){var r=t(this),u=o.originalEvent.dataTransfer.files||[];r.removeAttr("lay-over"),a(u),i.auto?e.upload(u):l(u)}),e.elemFile.off("upload.change").on("upload.change",function(){var t=this.files||[];a(t),i.auto?e.upload():l(t)}),i.bindAction.off("upload.action").on("upload.action",function(){e.upload()}),i.elem.data("haveEvents")||(e.elemFile.on("change",function(){t(this).trigger("upload.change")}),i.elem.on("click",function(){e.isFile()||t(this).trigger("upload.start")}),i.drag&&i.elem.on("dragover",function(e){e.preventDefault(),t(this).trigger("upload.over")}).on("dragleave",function(e){t(this).trigger("upload.leave")}).on("drop",function(e){e.preventDefault(),t(this).trigger("upload.drop",e)}),i.bindAction.on("click",function(){t(this).trigger("upload.action")}),i.elem.data("haveEvents",!0))},a.render=function(e){var t=new p(e);return l.call(t)},e(r,a)}); -------------------------------------------------------------------------------- /web/layui/lay/modules/element.js: -------------------------------------------------------------------------------- 1 | /** layui-v2.5.6 MIT License By https://www.layui.com */ 2 | ;layui.define("jquery",function(t){"use strict";var a=layui.$,i=(layui.hint(),layui.device()),e="element",l="layui-this",n="layui-show",s=function(){this.config={}};s.prototype.set=function(t){var i=this;return a.extend(!0,i.config,t),i},s.prototype.on=function(t,a){return layui.onevent.call(this,e,t,a)},s.prototype.tabAdd=function(t,i){var e=".layui-tab-title",l=a(".layui-tab[lay-filter="+t+"]"),n=l.children(e),s=n.children(".layui-tab-bar"),o=l.children(".layui-tab-content"),r='
  • "+(i.title||"unnaming")+"
  • ";return s[0]?s.before(r):n.append(r),o.append('
    '+(i.content||"")+"
    "),f.hideTabMore(!0),f.tabAuto(),this},s.prototype.tabDelete=function(t,i){var e=".layui-tab-title",l=a(".layui-tab[lay-filter="+t+"]"),n=l.children(e),s=n.find('>li[lay-id="'+i+'"]');return f.tabDelete(null,s),this},s.prototype.tabChange=function(t,i){var e=".layui-tab-title",l=a(".layui-tab[lay-filter="+t+"]"),n=l.children(e),s=n.find('>li[lay-id="'+i+'"]');return f.tabClick.call(s[0],null,null,s),this},s.prototype.tab=function(t){t=t||{},b.on("click",t.headerElem,function(i){var e=a(this).index();f.tabClick.call(this,i,e,null,t)})},s.prototype.progress=function(t,i){var e="layui-progress",l=a("."+e+"[lay-filter="+t+"]"),n=l.find("."+e+"-bar"),s=n.find("."+e+"-text");return n.css("width",i),s.text(i),this};var o=".layui-nav",r="layui-nav-item",c="layui-nav-bar",u="layui-nav-tree",d="layui-nav-child",y="layui-nav-more",h="layui-anim layui-anim-upbit",f={tabClick:function(t,i,s,o){o=o||{};var r=s||a(this),i=i||r.parent().children("li").index(r),c=o.headerElem?r.parent():r.parents(".layui-tab").eq(0),u=o.bodyElem?a(o.bodyElem):c.children(".layui-tab-content").children(".layui-tab-item"),d=r.find("a"),y=c.attr("lay-filter");"javascript:;"!==d.attr("href")&&"_blank"===d.attr("target")||(r.addClass(l).siblings().removeClass(l),u.eq(i).addClass(n).siblings().removeClass(n)),layui.event.call(this,e,"tab("+y+")",{elem:c,index:i})},tabDelete:function(t,i){var n=i||a(this).parent(),s=n.index(),o=n.parents(".layui-tab").eq(0),r=o.children(".layui-tab-content").children(".layui-tab-item"),c=o.attr("lay-filter");n.hasClass(l)&&(n.next()[0]?f.tabClick.call(n.next()[0],null,s+1):n.prev()[0]&&f.tabClick.call(n.prev()[0],null,s-1)),n.remove(),r.eq(s).remove(),setTimeout(function(){f.tabAuto()},50),layui.event.call(this,e,"tabDelete("+c+")",{elem:o,index:s})},tabAuto:function(){var t="layui-tab-more",e="layui-tab-bar",l="layui-tab-close",n=this;a(".layui-tab").each(function(){var s=a(this),o=s.children(".layui-tab-title"),r=(s.children(".layui-tab-content").children(".layui-tab-item"),'lay-stope="tabmore"'),c=a('');if(n===window&&8!=i.ie&&f.hideTabMore(!0),s.attr("lay-allowClose")&&o.find("li").each(function(){var t=a(this);if(!t.find("."+l)[0]){var i=a('');i.on("click",f.tabDelete),t.append(i)}}),"string"!=typeof s.attr("lay-unauto"))if(o.prop("scrollWidth")>o.outerWidth()+1){if(o.find("."+e)[0])return;o.append(c),s.attr("overflow",""),c.on("click",function(a){o[this.title?"removeClass":"addClass"](t),this.title=this.title?"":"收缩"})}else o.find("."+e).remove(),s.removeAttr("overflow")})},hideTabMore:function(t){var i=a(".layui-tab-title");t!==!0&&"tabmore"===a(t.target).attr("lay-stope")||(i.removeClass("layui-tab-more"),i.find(".layui-tab-bar").attr("title",""))},clickThis:function(){var t=a(this),i=t.parents(o),n=i.attr("lay-filter"),s=t.parent(),c=t.siblings("."+d),y="string"==typeof s.attr("lay-unselect");"javascript:;"!==t.attr("href")&&"_blank"===t.attr("target")||y||c[0]||(i.find("."+l).removeClass(l),s.addClass(l)),i.hasClass(u)&&(c.removeClass(h),c[0]&&(s["none"===c.css("display")?"addClass":"removeClass"](r+"ed"),"all"===i.attr("lay-shrink")&&s.siblings().removeClass(r+"ed"))),layui.event.call(this,e,"nav("+n+")",t)},collapse:function(){var t=a(this),i=t.find(".layui-colla-icon"),l=t.siblings(".layui-colla-content"),s=t.parents(".layui-collapse").eq(0),o=s.attr("lay-filter"),r="none"===l.css("display");if("string"==typeof s.attr("lay-accordion")){var c=s.children(".layui-colla-item").children("."+n);c.siblings(".layui-colla-title").children(".layui-colla-icon").html(""),c.removeClass(n)}l[r?"addClass":"removeClass"](n),i.html(r?"":""),layui.event.call(this,e,"collapse("+o+")",{title:t,content:l,show:r})}};s.prototype.init=function(t,e){var l=function(){return e?'[lay-filter="'+e+'"]':""}(),s={tab:function(){f.tabAuto.call({})},nav:function(){var t=200,e={},s={},p={},b=function(l,o,r){var c=a(this),f=c.find("."+d);o.hasClass(u)?l.css({top:c.position().top,height:c.children("a").outerHeight(),opacity:1}):(f.addClass(h),l.css({left:c.position().left+parseFloat(c.css("marginLeft")),top:c.position().top+c.height()-l.height()}),e[r]=setTimeout(function(){l.css({width:c.width(),opacity:1})},i.ie&&i.ie<10?0:t),clearTimeout(p[r]),"block"===f.css("display")&&clearTimeout(s[r]),s[r]=setTimeout(function(){f.addClass(n),c.find("."+y).addClass(y+"d")},300))};a(o+l).each(function(i){var l=a(this),o=a(''),h=l.find("."+r);l.find("."+c)[0]||(l.append(o),h.on("mouseenter",function(){b.call(this,o,l,i)}).on("mouseleave",function(){l.hasClass(u)||(clearTimeout(s[i]),s[i]=setTimeout(function(){l.find("."+d).removeClass(n),l.find("."+y).removeClass(y+"d")},300))}),l.on("mouseleave",function(){clearTimeout(e[i]),p[i]=setTimeout(function(){l.hasClass(u)?o.css({height:0,top:o.position().top+o.height()/2,opacity:0}):o.css({width:0,left:o.position().left+o.width()/2,opacity:0})},t)})),h.find("a").each(function(){var t=a(this),i=(t.parent(),t.siblings("."+d));i[0]&&!t.children("."+y)[0]&&t.append(''),t.off("click",f.clickThis).on("click",f.clickThis)})})},breadcrumb:function(){var t=".layui-breadcrumb";a(t+l).each(function(){var t=a(this),i="lay-separator",e=t.attr(i)||"/",l=t.find("a");l.next("span["+i+"]")[0]||(l.each(function(t){t!==l.length-1&&a(this).after(""+e+"")}),t.css("visibility","visible"))})},progress:function(){var t="layui-progress";a("."+t+l).each(function(){var i=a(this),e=i.find(".layui-progress-bar"),l=e.attr("lay-percent");e.css("width",function(){return/^.+\/.+$/.test(l)?100*new Function("return "+l)()+"%":l}()),i.attr("lay-showPercent")&&setTimeout(function(){e.html(''+l+"")},350)})},collapse:function(){var t="layui-collapse";a("."+t+l).each(function(){var t=a(this).find(".layui-colla-item");t.each(function(){var t=a(this),i=t.find(".layui-colla-title"),e=t.find(".layui-colla-content"),l="none"===e.css("display");i.find(".layui-colla-icon").remove(),i.append(''+(l?"":"")+""),i.off("click",f.collapse).on("click",f.collapse)})})}};return s[t]?s[t]():layui.each(s,function(t,a){a()})},s.prototype.render=s.prototype.init;var p=new s,b=a(document);p.render();var v=".layui-tab-title li";b.on("click",v,f.tabClick),b.on("click",f.hideTabMore),a(window).on("resize",f.tabAuto),t(e,p)}); -------------------------------------------------------------------------------- /web/layui/layui.js: -------------------------------------------------------------------------------- 1 | /** layui-v2.5.6 MIT License By https://www.layui.com */ 2 | ;!function(e){"use strict";var t=document,n={modules:{},status:{},timeout:10,event:{}},r=function(){this.v="2.5.6"},o=function(){var e=t.currentScript?t.currentScript.src:function(){for(var e,n=t.scripts,r=n.length-1,o=r;o>0;o--)if("interactive"===n[o].readyState){e=n[o].src;break}return e||n[r].src}();return e.substring(0,e.lastIndexOf("/")+1)}(),a=function(t){e.console&&console.error&&console.error("Layui hint: "+t)},i="undefined"!=typeof opera&&"[object Opera]"===opera.toString(),u={layer:"modules/layer",laydate:"modules/laydate",laypage:"modules/laypage",laytpl:"modules/laytpl",layim:"modules/layim",layedit:"modules/layedit",form:"modules/form",upload:"modules/upload",transfer:"modules/transfer",tree:"modules/tree",table:"modules/table",element:"modules/element",rate:"modules/rate",colorpicker:"modules/colorpicker",slider:"modules/slider",carousel:"modules/carousel",flow:"modules/flow",util:"modules/util",code:"modules/code",jquery:"modules/jquery",mobile:"modules/mobile","layui.all":"../layui.all"};r.prototype.cache=n,r.prototype.define=function(e,t){var r=this,o="function"==typeof e,a=function(){var e=function(e,t){layui[e]=t,n.status[e]=!0};return"function"==typeof t&&t(function(r,o){e(r,o),n.callback[r]=function(){t(e)}}),this};return o&&(t=e,e=[]),!layui["layui.all"]&&layui["layui.mobile"]?a.call(r):(r.use(e,a),r)},r.prototype.use=function(e,r,l){function c(e,t){var r="PLaySTATION 3"===navigator.platform?/^complete$/:/^(complete|loaded)$/;("load"===e.type||r.test((e.currentTarget||e.srcElement).readyState))&&(n.modules[d]=t,y.removeChild(h),function o(){return++m>1e3*n.timeout/4?a(d+" is not a valid module"):void(n.status[d]?s():setTimeout(o,4))}())}function s(){l.push(layui[d]),e.length>1?p.use(e.slice(1),r,l):"function"==typeof r&&r.apply(layui,l)}var p=this,f=n.dir=n.dir?n.dir:o,y=t.getElementsByTagName("head")[0];e="string"==typeof e?[e]:e,window.jQuery&&jQuery.fn.on&&(p.each(e,function(t,n){"jquery"===n&&e.splice(t,1)}),layui.jquery=layui.$=jQuery);var d=e[0],m=0;if(l=l||[],n.host=n.host||(f.match(/\/\/([\s\S]+?)\//)||["//"+location.host+"/"])[0],0===e.length||layui["layui.all"]&&u[d]||!layui["layui.all"]&&layui["layui.mobile"]&&u[d])return s(),p;var v=(u[d]?f+"lay/":/^\{\/\}/.test(p.modules[d])?"":n.base||"")+(p.modules[d]||d)+".js";if(v=v.replace(/^\{\/\}/,""),!n.modules[d]&&layui[d]&&(n.modules[d]=v),n.modules[d])!function g(){return++m>1e3*n.timeout/4?a(d+" is not a valid module"):void("string"==typeof n.modules[d]&&n.status[d]?s():setTimeout(g,4))}();else{var h=t.createElement("script");h.async=!0,h.charset="utf-8",h.src=v+function(){var e=n.version===!0?n.v||(new Date).getTime():n.version||"";return e?"?v="+e:""}(),y.appendChild(h),!h.attachEvent||h.attachEvent.toString&&h.attachEvent.toString().indexOf("[native code")<0||i?h.addEventListener("load",function(e){c(e,v)},!1):h.attachEvent("onreadystatechange",function(e){c(e,v)}),n.modules[d]=v}return p},r.prototype.getStyle=function(t,n){var r=t.currentStyle?t.currentStyle:e.getComputedStyle(t,null);return r[r.getPropertyValue?"getPropertyValue":"getAttribute"](n)},r.prototype.link=function(e,r,o){var i=this,u=t.createElement("link"),l=t.getElementsByTagName("head")[0];"string"==typeof r&&(o=r);var c=(o||e).replace(/\.|\//g,""),s=u.id="layuicss-"+c,p=0;return u.rel="stylesheet",u.href=e+(n.debug?"?v="+(new Date).getTime():""),u.media="all",t.getElementById(s)||l.appendChild(u),"function"!=typeof r?i:(function f(){return++p>1e3*n.timeout/100?a(e+" timeout"):void(1989===parseInt(i.getStyle(t.getElementById(s),"width"))?function(){r()}():setTimeout(f,100))}(),i)},n.callback={},r.prototype.factory=function(e){if(layui[e])return"function"==typeof n.callback[e]?n.callback[e]:null},r.prototype.addcss=function(e,t,r){return layui.link(n.dir+"css/"+e,t,r)},r.prototype.img=function(e,t,n){var r=new Image;return r.src=e,r.complete?t(r):(r.onload=function(){r.onload=null,"function"==typeof t&&t(r)},void(r.onerror=function(e){r.onerror=null,"function"==typeof n&&n(e)}))},r.prototype.config=function(e){e=e||{};for(var t in e)n[t]=e[t];return this},r.prototype.modules=function(){var e={};for(var t in u)e[t]=u[t];return e}(),r.prototype.extend=function(e){var t=this;e=e||{};for(var n in e)t[n]||t.modules[n]?a("模块名 "+n+" 已被占用"):t.modules[n]=e[n];return t},r.prototype.router=function(e){var t=this,e=e||location.hash,n={path:[],search:{},hash:(e.match(/[^#](#.*$)/)||[])[1]||""};return/^#\//.test(e)?(e=e.replace(/^#\//,""),n.href="/"+e,e=e.replace(/([^#])(#.*$)/,"$1").split("/")||[],t.each(e,function(e,t){/^\w+=/.test(t)?function(){t=t.split("="),n.search[t[0]]=t[1]}():n.path.push(t)}),n):n},r.prototype.url=function(e){var t=this,n={pathname:function(){var t=e?function(){var t=(e.match(/\.[^.]+?\/.+/)||[])[0]||"";return t.replace(/^[^\/]+/,"").replace(/\?.+/,"")}():location.pathname;return t.replace(/^\//,"").split("/")}(),search:function(){var n={},r=(e?function(){var t=(e.match(/\?.+/)||[])[0]||"";return t.replace(/\#.+/,"")}():location.search).replace(/^\?+/,"").split("&");return t.each(r,function(e,t){var r=t.indexOf("="),o=function(){return r<0?t.substr(0,t.length):0!==r&&t.substr(0,r)}();o&&(n[o]=r>0?t.substr(r+1):null)}),n}(),hash:t.router(function(){return e?(e.match(/#.+/)||[])[0]||"":location.hash}())};return n},r.prototype.data=function(t,n,r){if(t=t||"layui",r=r||localStorage,e.JSON&&e.JSON.parse){if(null===n)return delete r[t];n="object"==typeof n?n:{key:n};try{var o=JSON.parse(r[t])}catch(a){var o={}}return"value"in n&&(o[n.key]=n.value),n.remove&&delete o[n.key],r[t]=JSON.stringify(o),n.key?o[n.key]:o}},r.prototype.sessionData=function(e,t){return this.data(e,t,sessionStorage)},r.prototype.device=function(t){var n=navigator.userAgent.toLowerCase(),r=function(e){var t=new RegExp(e+"/([^\\s\\_\\-]+)");return e=(n.match(t)||[])[1],e||!1},o={os:function(){return/windows/.test(n)?"windows":/linux/.test(n)?"linux":/iphone|ipod|ipad|ios/.test(n)?"ios":/mac/.test(n)?"mac":void 0}(),ie:function(){return!!(e.ActiveXObject||"ActiveXObject"in e)&&((n.match(/msie\s(\d+)/)||[])[1]||"11")}(),weixin:r("micromessenger")};return t&&!o[t]&&(o[t]=r(t)),o.android=/android/.test(n),o.ios="ios"===o.os,o.mobile=!(!o.android&&!o.ios),o},r.prototype.hint=function(){return{error:a}},r.prototype.each=function(e,t){var n,r=this;if("function"!=typeof t)return r;if(e=e||[],e.constructor===Object){for(n in e)if(t.call(e[n],n,e[n]))break}else for(n=0;na?1:oli,.layui-laydate-range .layui-laydate-main{display:inline-block;vertical-align:middle}.layui-laydate-list{position:absolute;left:0;top:0;width:100%;height:100%;padding:10px;background-color:#fff}.layui-laydate-list>li{position:relative;width:33.3%;height:36px;line-height:36px;margin:3px 0;text-align:center;cursor:pointer}.laydate-month-list>li{width:25%;margin:17px 0}.laydate-time-list>li{height:100%;margin:0;line-height:normal;cursor:default}.laydate-time-list p{position:relative;top:-4px;line-height:29px}.laydate-time-list ol{height:181px;overflow:hidden}.laydate-time-list>li:hover ol{overflow-y:auto}.laydate-time-list ol li{width:130%;padding-left:33px;line-height:30px;text-align:left;cursor:pointer}.layui-laydate-hint{position:absolute;top:115px;left:50%;width:250px;margin-left:-125px;line-height:20px;padding:15px;text-align:center;font-size:12px}.layui-laydate-range{width:546px}.layui-laydate-range .laydate-main-list-0 .laydate-next-m,.layui-laydate-range .laydate-main-list-0 .laydate-next-y,.layui-laydate-range .laydate-main-list-1 .laydate-prev-m,.layui-laydate-range .laydate-main-list-1 .laydate-prev-y{display:none}.layui-laydate-range .laydate-main-list-1 .layui-laydate-content{border-left:1px solid #e2e2e2}.layui-laydate,.layui-laydate-hint{border:1px solid #d2d2d2;box-shadow:0 2px 4px rgba(0,0,0,.12);background-color:#fff;color:#666}.layui-laydate-header{border-bottom:1px solid #e2e2e2}.layui-laydate-header i:hover,.layui-laydate-header span:hover{color:#5FB878}.layui-laydate-content{border-top:none 0;border-bottom:none 0}.layui-laydate-content th{font-weight:400;color:#333}.layui-laydate-content td{color:#666}.layui-laydate-content td.laydate-selected{background-color:#00F7DE}.laydate-selected:hover{background-color:#00F7DE!important}.layui-laydate-content td:hover,.layui-laydate-list li:hover{background-color:#eaeaea;color:#333}.laydate-time-list li ol{margin:0;padding:0;border:1px solid #e2e2e2;border-left-width:0}.laydate-time-list li:first-child ol{border-left-width:1px}.laydate-time-list>li:hover{background:0 0}.layui-laydate-content .laydate-day-next,.layui-laydate-content .laydate-day-prev{color:#d2d2d2}.laydate-selected.laydate-day-next,.laydate-selected.laydate-day-prev{background-color:#f8f8f8!important}.layui-laydate-footer{border-top:1px solid #e2e2e2}.layui-laydate-hint{color:#FF5722}.laydate-day-mark::after{background-color:#5FB878}.layui-laydate-content td.layui-this .laydate-day-mark::after{display:none}.layui-laydate-footer span[lay-type=date]{color:#5FB878}.layui-laydate .layui-this{background-color:#009688!important;color:#fff!important}.layui-laydate .laydate-disabled,.layui-laydate .laydate-disabled:hover{background:0 0!important;color:#d2d2d2!important;cursor:not-allowed!important;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none}.laydate-theme-molv{border:none}.laydate-theme-molv.layui-laydate-range{width:548px}.laydate-theme-molv .layui-laydate-main{width:274px}.laydate-theme-molv .layui-laydate-header{border:none;background-color:#009688}.laydate-theme-molv .layui-laydate-header i,.laydate-theme-molv .layui-laydate-header span{color:#f6f6f6}.laydate-theme-molv .layui-laydate-header i:hover,.laydate-theme-molv .layui-laydate-header span:hover{color:#fff}.laydate-theme-molv .layui-laydate-content{border:1px solid #e2e2e2;border-top:none;border-bottom:none}.laydate-theme-molv .laydate-main-list-1 .layui-laydate-content{border-left:none}.laydate-theme-grid .laydate-month-list>li,.laydate-theme-grid .laydate-year-list>li,.laydate-theme-grid .layui-laydate-content td,.laydate-theme-grid .layui-laydate-content thead,.laydate-theme-molv .layui-laydate-footer{border:1px solid #e2e2e2}.laydate-theme-grid .laydate-selected,.laydate-theme-grid .laydate-selected:hover{background-color:#f2f2f2!important;color:#009688!important}.laydate-theme-grid .laydate-selected.laydate-day-next,.laydate-theme-grid .laydate-selected.laydate-day-prev{color:#d2d2d2!important}.laydate-theme-grid .laydate-month-list,.laydate-theme-grid .laydate-year-list{margin:1px 0 0 1px}.laydate-theme-grid .laydate-month-list>li,.laydate-theme-grid .laydate-year-list>li{margin:0 -1px -1px 0}.laydate-theme-grid .laydate-year-list>li{height:43px;line-height:43px}.laydate-theme-grid .laydate-month-list>li{height:71px;line-height:71px} -------------------------------------------------------------------------------- /src/com/school/controller/StudentController.java: -------------------------------------------------------------------------------- 1 | package com.school.controller; 2 | 3 | 4 | import com.alibaba.fastjson.JSON; 5 | import com.school.pojo.Student; 6 | import com.school.service.StudentService; 7 | import com.school.serviceImp.StudentServiceImp; 8 | import com.school.util.ResultUtil; 9 | 10 | import javax.servlet.ServletException; 11 | import javax.servlet.annotation.WebServlet; 12 | import javax.servlet.http.HttpServlet; 13 | import javax.servlet.http.HttpServletRequest; 14 | import javax.servlet.http.HttpServletResponse; 15 | import java.io.IOException; 16 | import java.io.OutputStreamWriter; 17 | import java.util.HashMap; 18 | import java.util.List; 19 | import java.util.Map; 20 | 21 | @WebServlet("/studentController") 22 | public class StudentController extends HttpServlet { 23 | protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 24 | response.setContentType("text/javascript;charset=UTF-8"); 25 | StudentService studentService = new StudentServiceImp(); 26 | 27 | String method = (String) request.getParameter("method"); 28 | try { 29 | if ("add".equals(method)) { 30 | Student student = new Student(); 31 | student.setName(request.getParameter("name")); 32 | student.setAddress(request.getParameter("address")); 33 | student.setClasses(request.getParameter("classes")); 34 | student.setNation(request.getParameter("nation")); 35 | student.setNo(request.getParameter("no")); 36 | student.setSex(Integer.valueOf(request.getParameter("sex"))); 37 | student.setAge(Integer.valueOf(request.getParameter("age"))); 38 | 39 | Integer num = studentService.add(student); 40 | if (num == 1) { 41 | response.getWriter().write(JSON.toJSONString(ResultUtil.success("添加成功!"))); 42 | } else { 43 | response.getWriter().write(JSON.toJSONString(ResultUtil.success("添加失败!"))); 44 | } 45 | } 46 | if ("update".equals(method)) { 47 | Student student = new Student(); 48 | student.setName(request.getParameter("name")); 49 | student.setAddress(request.getParameter("address")); 50 | student.setClasses(request.getParameter("classes")); 51 | student.setNation(request.getParameter("nation")); 52 | student.setNo(request.getParameter("no")); 53 | student.setSex(Integer.valueOf(request.getParameter("sex"))); 54 | student.setAge(Integer.valueOf(request.getParameter("age"))); 55 | student.setId(Integer.valueOf(request.getParameter("id"))); 56 | Integer num = studentService.update(student); 57 | if (num == 1) { 58 | response.getWriter().write(JSON.toJSONString(ResultUtil.success("更新成功!"))); 59 | } else { 60 | response.getWriter().write(JSON.toJSONString(ResultUtil.success("更新失败!"))); 61 | } 62 | } 63 | if ("delete".equals(method)) { 64 | Integer id = Integer.valueOf(request.getParameter("id")); 65 | Integer num = studentService.delete(id); 66 | if (num == 1) { 67 | response.getWriter().write(JSON.toJSONString(ResultUtil.success("删除成功!"))); 68 | } else { 69 | response.getWriter().write(JSON.toJSONString(ResultUtil.success("删除失败!"))); 70 | } 71 | } 72 | if ("findAllToSys".equals(method)) { 73 | Integer page = Integer.valueOf(request.getParameter("page")); 74 | Integer limit = Integer.valueOf(request.getParameter("limit")); 75 | String noSearch = (String)request.getParameter("noSearch"); 76 | Map map=new HashMap(); 77 | map.put("page", (page-1)*limit); 78 | map.put("limit",limit); 79 | map.put("noSearch",noSearch); 80 | ResultUtil resultUtil = studentService.findAllToSys(map); 81 | response.getWriter().write(JSON.toJSONString(resultUtil)); 82 | } 83 | 84 | if ("findById".equals(method)) { 85 | Integer id = Integer.valueOf(request.getParameter("id")); 86 | Student student = studentService.findById(id); 87 | response.getWriter().write(JSON.toJSONString(ResultUtil.success(student))); 88 | } 89 | 90 | if("updateStudentList".equals(method)){ 91 | Integer page = 1; 92 | Integer limit = 60000; 93 | String noSearch = (String)request.getParameter("noSearch"); 94 | Map map=new HashMap(); 95 | map.put("page", (page-1)*limit); 96 | map.put("limit",limit); 97 | map.put("noSearch",noSearch); 98 | ResultUtil resultUtil = studentService.findAllToSys(map); 99 | List studentList=(List)resultUtil.getData(); 100 | 101 | 102 | StringBuffer stringBuffer = new StringBuffer(); 103 | //添加表头 104 | stringBuffer.append("姓名,学号,年龄,性别,班级,出生地,民族"); 105 | stringBuffer.append("\r\n"); 106 | for (Student student : studentList) { 107 | stringBuffer.append(student.getName()+ ","); 108 | stringBuffer.append(student.getNo()+ ","); 109 | stringBuffer.append(student.getAge()+ ","); 110 | if ("0".equals(student.getSex().toString())) { 111 | stringBuffer.append("男,"); 112 | } else if ("1".equals(student.getSex().toString())) { 113 | stringBuffer.append("女,"); 114 | } 115 | stringBuffer.append(student.getClasses()+ ","); 116 | stringBuffer.append(student.getAddress()+ ","); 117 | stringBuffer.append(student.getNation()+ ","); 118 | stringBuffer.append("\r\n"); 119 | } 120 | 121 | 122 | 123 | response.setCharacterEncoding("gbk"); 124 | response.setContentType("text/csv"); 125 | response.setHeader("Content-Disposition", "attachment; filename=student.csv"); 126 | try { 127 | OutputStreamWriter outputStream = new OutputStreamWriter(response.getOutputStream(), "gbk"); 128 | 129 | 130 | outputStream.write(new String(new byte[] { (byte) 0xEF, (byte) 0xBB,(byte) 0xBF })); 131 | outputStream.write(stringBuffer.toString()); //result是要导出的csv的字符串 132 | outputStream.flush(); 133 | outputStream.close(); 134 | } catch (Exception e) { 135 | System.out.println(e.toString()); 136 | } 137 | 138 | response.getWriter().write(JSON.toJSONString(resultUtil)); 139 | } 140 | 141 | 142 | } catch (Exception e) { 143 | e.printStackTrace(); 144 | } 145 | } 146 | 147 | protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 148 | doGet(request, response); 149 | } 150 | 151 | 152 | } 153 | -------------------------------------------------------------------------------- /src/com/school/daoImp/TeacherDaoImp.java: -------------------------------------------------------------------------------- 1 | package com.school.daoImp; 2 | 3 | import com.school.dao.TeacherDao; 4 | import com.school.pojo.Teacher; 5 | import com.school.util.JDBCUtil; 6 | 7 | import java.sql.Connection; 8 | import java.sql.PreparedStatement; 9 | import java.sql.ResultSet; 10 | import java.sql.SQLException; 11 | import java.util.ArrayList; 12 | import java.util.List; 13 | import java.util.Map; 14 | 15 | public class TeacherDaoImp implements TeacherDao { 16 | @Override 17 | public int add(Teacher teacher) { 18 | Connection conn = JDBCUtil.getConn(); 19 | PreparedStatement ps = null; 20 | ResultSet rs = null; 21 | String sql ="insert into teacher(name,professional,degree,sex,course) values(?,?,?,?,?)"; 22 | int affectedLine = 0;//受影响的行数 23 | try { 24 | ps = conn.prepareStatement(sql); 25 | ps.setString(1, teacher.getName()); 26 | ps.setString(2, teacher.getProfessional()); 27 | ps.setString(3, teacher.getDegree()); 28 | ps.setInt(4, teacher.getSex()); 29 | ps.setString(5, teacher.getCourse()); 30 | affectedLine = ps.executeUpdate(); 31 | } catch (SQLException e) { 32 | e.printStackTrace(); 33 | throw new RuntimeException("出现错误!"); 34 | }finally{ 35 | JDBCUtil.release(conn, ps, rs); 36 | } 37 | return affectedLine; 38 | } 39 | 40 | @Override 41 | public int update(Teacher teacher) { 42 | Connection conn = JDBCUtil.getConn(); 43 | PreparedStatement ps = null; 44 | ResultSet rs = null; 45 | String sql ="update teacher set name = ?,professional = ?,degree =? ,sex = ?,course = ? where id = ? "; 46 | int affectedLine = 0;//受影响的行数 47 | try { 48 | ps = conn.prepareStatement(sql); 49 | ps.setString(1, teacher.getName()); 50 | ps.setString(2, teacher.getProfessional()); 51 | ps.setString(3, teacher.getDegree()); 52 | ps.setInt(4, teacher.getSex()); 53 | ps.setString(5, teacher.getCourse()); 54 | ps.setInt(6, teacher.getId()); 55 | affectedLine = ps.executeUpdate(); 56 | } catch (SQLException e) { 57 | e.printStackTrace(); 58 | throw new RuntimeException("出现错误!"); 59 | }finally{ 60 | JDBCUtil.release(conn, ps, rs); 61 | } 62 | return affectedLine; 63 | } 64 | 65 | @Override 66 | public int delete(Integer id) { 67 | Connection conn = JDBCUtil.getConn(); 68 | PreparedStatement ps = null; 69 | ResultSet rs = null; 70 | String sql ="delete from teacher where id = ? "; 71 | int affectedLine = 0;//受影响的行数 72 | try { 73 | ps = conn.prepareStatement(sql); 74 | ps.setInt(1, id); 75 | affectedLine = ps.executeUpdate(); 76 | } catch (SQLException e) { 77 | e.printStackTrace(); 78 | throw new RuntimeException("出现错误!"); 79 | }finally{ 80 | JDBCUtil.release(conn, ps, rs); 81 | } 82 | return affectedLine; 83 | } 84 | 85 | @Override 86 | public List findAllToSys(Map map) { 87 | Connection conn = JDBCUtil.getConn(); 88 | PreparedStatement ps = null; 89 | ResultSet rs = null; 90 | 91 | StringBuffer sql = new StringBuffer( "select id,name,professional,degree,course,sex from teacher where 1=1") ; 92 | if(map.get("nameSearch")!=null&& !"".equals(map.get("nameSearch"))){ 93 | sql.append(" and (name LIKE concat(concat(\"%\",?),\"%\")) "); 94 | } 95 | sql.append(" limit ? , ? "); 96 | 97 | Teacher teacher=null; 98 | List teacherList=new ArrayList<>(); 99 | try { 100 | 101 | ps = conn.prepareStatement(sql.toString()); 102 | if(map.get("nameSearch")!=null&& !"".equals(map.get("nameSearch"))){ 103 | ps.setString(1,map.get("nameSearch").toString()); 104 | ps.setInt(2, Integer.valueOf(map.get("page").toString())); 105 | ps.setInt(3, Integer.valueOf(map.get("limit").toString())); 106 | }else{ 107 | ps.setInt(1, Integer.valueOf(map.get("page").toString())); 108 | ps.setInt(2, Integer.valueOf(map.get("limit").toString())); 109 | } 110 | rs = ps.executeQuery(); 111 | while(rs.next()){ 112 | teacher=new Teacher(); 113 | teacher.setId(rs.getInt(1)); 114 | teacher.setName(rs.getString(2)); 115 | teacher.setProfessional(rs.getString(3)); 116 | teacher.setDegree(rs.getString(4)); 117 | teacher.setCourse(rs.getString(5)); 118 | teacher.setSex(rs.getInt(6)); 119 | 120 | teacherList.add(teacher); 121 | } 122 | } catch (SQLException e) { 123 | e.printStackTrace(); 124 | throw new RuntimeException("出现错误!"); 125 | }finally{ 126 | JDBCUtil.release(conn, ps, rs); 127 | } 128 | return teacherList; 129 | 130 | } 131 | 132 | @Override 133 | public Integer findAllToSysCount(Map map) { 134 | 135 | Connection conn = JDBCUtil.getConn(); 136 | PreparedStatement ps = null; 137 | ResultSet rs = null; 138 | 139 | StringBuffer sql = new StringBuffer( "select count(*) from teacher where 1=1") ; 140 | if(map.get("nameSearch")!=null&& !"".equals(map.get("nameSearch"))){ 141 | sql.append(" and (name LIKE concat(concat(\"%\",?),\"%\")) "); 142 | } 143 | Integer count=0; 144 | try { 145 | 146 | ps = conn.prepareStatement(sql.toString()); 147 | if(map.get("nameSearch")!=null&& !"".equals(map.get("nameSearch"))){ 148 | ps.setString(1,map.get("nameSearch").toString()); 149 | } 150 | rs = ps.executeQuery(); 151 | while(rs.next()){ 152 | count=rs.getInt(1); 153 | } 154 | } catch (SQLException e) { 155 | e.printStackTrace(); 156 | throw new RuntimeException("出现错误!"); 157 | }finally{ 158 | JDBCUtil.release(conn, ps, rs); 159 | } 160 | return count; 161 | } 162 | 163 | @Override 164 | public Teacher findById(Integer id) { 165 | Connection conn = JDBCUtil.getConn(); 166 | PreparedStatement ps = null; 167 | ResultSet rs = null; 168 | 169 | String sql = "select id,name,professional,degree,course,sex from teacher where id = ? "; 170 | Teacher teacher=null; 171 | try { 172 | 173 | ps = conn.prepareStatement(sql); 174 | ps.setInt(1, id); 175 | 176 | rs = ps.executeQuery(); 177 | if(rs.next()){ 178 | teacher=new Teacher(); 179 | teacher.setId(rs.getInt(1)); 180 | teacher.setName(rs.getString(2)); 181 | teacher.setProfessional(rs.getString(3)); 182 | teacher.setDegree(rs.getString(4)); 183 | teacher.setCourse(rs.getString(5)); 184 | teacher.setSex(rs.getInt(6)); 185 | } 186 | } catch (SQLException e) { 187 | e.printStackTrace(); 188 | throw new RuntimeException("出现错误!"); 189 | }finally{ 190 | JDBCUtil.release(conn, ps, rs); 191 | } 192 | return teacher; 193 | } 194 | } 195 | -------------------------------------------------------------------------------- /src/com/school/daoImp/StudentDaoImp.java: -------------------------------------------------------------------------------- 1 | package com.school.daoImp; 2 | 3 | import com.school.dao.StudentDao; 4 | import com.school.pojo.Student; 5 | import com.school.util.JDBCUtil; 6 | 7 | import java.sql.Connection; 8 | import java.sql.PreparedStatement; 9 | import java.sql.ResultSet; 10 | import java.sql.SQLException; 11 | import java.util.ArrayList; 12 | import java.util.List; 13 | import java.util.Map; 14 | 15 | public class StudentDaoImp implements StudentDao { 16 | @Override 17 | public int add(Student student) { 18 | Connection conn = JDBCUtil.getConn(); 19 | PreparedStatement ps = null; 20 | ResultSet rs = null; 21 | String sql ="insert into student(name,no,age,sex,classes,address,nation) values(?,?,?,?,?,?,?)"; 22 | int affectedLine = 0;//受影响的行数 23 | try { 24 | ps = conn.prepareStatement(sql); 25 | ps.setString(1, student.getName()); 26 | ps.setString(2, student.getNo()); 27 | ps.setInt(3, student.getAge()); 28 | ps.setInt(4, student.getSex()); 29 | ps.setString(5, student.getClasses()); 30 | ps.setString(6, student.getAddress()); 31 | ps.setString(7, student.getNation()); 32 | affectedLine = ps.executeUpdate(); 33 | } catch (SQLException e) { 34 | e.printStackTrace(); 35 | throw new RuntimeException("出现错误!"); 36 | }finally{ 37 | JDBCUtil.release(conn, ps, rs); 38 | } 39 | return affectedLine; 40 | } 41 | 42 | @Override 43 | public int update(Student student) { 44 | Connection conn = JDBCUtil.getConn(); 45 | PreparedStatement ps = null; 46 | ResultSet rs = null; 47 | String sql ="update student set name = ?,no = ?,age =? ,sex = ?,classes = ?,address = ?,nation = ? where id = ? "; 48 | int affectedLine = 0;//受影响的行数 49 | try { 50 | ps = conn.prepareStatement(sql); 51 | ps.setString(1, student.getName()); 52 | ps.setString(2, student.getNo()); 53 | ps.setInt(3, student.getAge()); 54 | ps.setInt(4, student.getSex()); 55 | ps.setString(5, student.getClasses()); 56 | ps.setString(6, student.getAddress()); 57 | ps.setString(7, student.getNation()); 58 | ps.setInt(8, student.getId()); 59 | affectedLine = ps.executeUpdate(); 60 | } catch (SQLException e) { 61 | e.printStackTrace(); 62 | throw new RuntimeException("出现错误!"); 63 | }finally{ 64 | JDBCUtil.release(conn, ps, rs); 65 | } 66 | return affectedLine; 67 | } 68 | 69 | @Override 70 | public int delete(Integer id) { 71 | Connection conn = JDBCUtil.getConn(); 72 | PreparedStatement ps = null; 73 | ResultSet rs = null; 74 | String sql ="delete from student where id = ? "; 75 | int affectedLine = 0;//受影响的行数 76 | try { 77 | ps = conn.prepareStatement(sql); 78 | ps.setInt(1, id); 79 | affectedLine = ps.executeUpdate(); 80 | } catch (SQLException e) { 81 | e.printStackTrace(); 82 | throw new RuntimeException("出现错误!"); 83 | }finally{ 84 | JDBCUtil.release(conn, ps, rs); 85 | } 86 | return affectedLine; 87 | } 88 | 89 | @Override 90 | public List findAllToSys(Map map) { 91 | Connection conn = JDBCUtil.getConn(); 92 | PreparedStatement ps = null; 93 | ResultSet rs = null; 94 | 95 | StringBuffer sql = new StringBuffer( "select id,name,no,age,sex,classes,address,nation from student where 1=1") ; 96 | if(map.get("noSearch")!=null&& !"".equals(map.get("noSearch"))){ 97 | sql.append(" and (no LIKE concat(concat(\"%\",?),\"%\")) "); 98 | } 99 | sql.append(" limit ? , ? "); 100 | 101 | Student student=null; 102 | List studentList=new ArrayList<>(); 103 | try { 104 | 105 | ps = conn.prepareStatement(sql.toString()); 106 | if(map.get("noSearch")!=null&& !"".equals(map.get("noSearch"))){ 107 | ps.setString(1,map.get("noSearch").toString()); 108 | ps.setInt(2, Integer.valueOf(map.get("page").toString())); 109 | ps.setInt(3, Integer.valueOf(map.get("limit").toString())); 110 | }else{ 111 | ps.setInt(1, Integer.valueOf(map.get("page").toString())); 112 | ps.setInt(2, Integer.valueOf(map.get("limit").toString())); 113 | } 114 | rs = ps.executeQuery(); 115 | while(rs.next()){ 116 | student=new Student(); 117 | student.setId(rs.getInt(1)); 118 | student.setName(rs.getString(2)); 119 | student.setNo(rs.getString(3)); 120 | student.setAge(rs.getInt(4)); 121 | student.setSex(rs.getInt(5)); 122 | student.setClasses(rs.getString(6)); 123 | student.setAddress(rs.getString(7)); 124 | student.setNation(rs.getString(8)); 125 | studentList.add(student); 126 | } 127 | } catch (SQLException e) { 128 | e.printStackTrace(); 129 | throw new RuntimeException("出现错误!"); 130 | }finally{ 131 | JDBCUtil.release(conn, ps, rs); 132 | } 133 | return studentList; 134 | 135 | } 136 | 137 | @Override 138 | public Integer findAllToSysCount(Map map) { 139 | 140 | Connection conn = JDBCUtil.getConn(); 141 | PreparedStatement ps = null; 142 | ResultSet rs = null; 143 | 144 | StringBuffer sql = new StringBuffer( "select count(*) from student where 1=1") ; 145 | if(map.get("noSearch")!=null&& !"".equals(map.get("noSearch"))){ 146 | sql.append(" and (no LIKE concat(concat(\"%\",?),\"%\")) "); 147 | } 148 | Integer count=0; 149 | try { 150 | 151 | ps = conn.prepareStatement(sql.toString()); 152 | if(map.get("noSearch")!=null&& !"".equals(map.get("noSearch"))){ 153 | ps.setString(1,map.get("noSearch").toString()); 154 | } 155 | rs = ps.executeQuery(); 156 | while(rs.next()){ 157 | count=rs.getInt(1); 158 | } 159 | } catch (SQLException e) { 160 | e.printStackTrace(); 161 | throw new RuntimeException("出现错误!"); 162 | }finally{ 163 | JDBCUtil.release(conn, ps, rs); 164 | } 165 | return count; 166 | } 167 | 168 | @Override 169 | public Student findById(Integer id) { 170 | Connection conn = JDBCUtil.getConn(); 171 | PreparedStatement ps = null; 172 | ResultSet rs = null; 173 | 174 | String sql = "select id,name,no,age,sex,classes,address,nation from student where id = ? "; 175 | Student student=null; 176 | try { 177 | 178 | ps = conn.prepareStatement(sql); 179 | ps.setInt(1, id); 180 | 181 | rs = ps.executeQuery(); 182 | if(rs.next()){ 183 | student=new Student(); 184 | student.setId(rs.getInt(1)); 185 | student.setName(rs.getString(2)); 186 | student.setNo(rs.getString(3)); 187 | student.setAge(rs.getInt(4)); 188 | student.setSex(rs.getInt(5)); 189 | student.setClasses(rs.getString(6)); 190 | student.setAddress(rs.getString(7)); 191 | student.setNation(rs.getString(8)); 192 | } 193 | } catch (SQLException e) { 194 | e.printStackTrace(); 195 | throw new RuntimeException("出现错误!"); 196 | }finally{ 197 | JDBCUtil.release(conn, ps, rs); 198 | } 199 | return student; 200 | } 201 | } 202 | -------------------------------------------------------------------------------- /web/layui/lay/modules/form.js: -------------------------------------------------------------------------------- 1 | /** layui-v2.5.6 MIT License By https://www.layui.com */ 2 | ;layui.define("layer",function(e){"use strict";var t=layui.$,i=layui.layer,a=layui.hint(),n=layui.device(),l="form",r=".layui-form",s="layui-this",o="layui-hide",c="layui-disabled",u=function(){this.config={verify:{required:[/[\S]+/,"必填项不能为空"],phone:[/^1\d{10}$/,"请输入正确的手机号"],email:[/^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/,"邮箱格式不正确"],url:[/(^#)|(^http(s*):\/\/[^\s]+\.[^\s]+)/,"链接格式不正确"],number:function(e){if(!e||isNaN(e))return"只能填写数字"},date:[/^(\d{4})[-\/](\d{1}|0\d{1}|1[0-2])([-\/](\d{1}|0\d{1}|[1-2][0-9]|3[0-1]))*$/,"日期格式不正确"],identity:[/(^\d{15}$)|(^\d{17}(x|X|\d)$)/,"请输入正确的身份证号"]}}};u.prototype.set=function(e){var i=this;return t.extend(!0,i.config,e),i},u.prototype.verify=function(e){var i=this;return t.extend(!0,i.config.verify,e),i},u.prototype.on=function(e,t){return layui.onevent.call(this,l,e,t)},u.prototype.val=function(e,i){var a=this,n=t(r+'[lay-filter="'+e+'"]');return n.each(function(e,a){var n=t(this);layui.each(i,function(e,t){var i,a=n.find('[name="'+e+'"]');a[0]&&(i=a[0].type,"checkbox"===i?a[0].checked=t:"radio"===i?a.each(function(){this.value==t&&(this.checked=!0)}):a.val(t))})}),f.render(null,e),a.getValue(e)},u.prototype.getValue=function(e,i){i=i||t(r+'[lay-filter="'+e+'"]').eq(0);var a={},n={},l=i.find("input,select,textarea");return layui.each(l,function(e,t){if(t.name=(t.name||"").replace(/^\s*|\s*&/,""),t.name){if(/^.*\[\]$/.test(t.name)){var i=t.name.match(/^(.*)\[\]$/g)[0];a[i]=0|a[i],t.name=t.name.replace(/^(.*)\[\]$/,"$1["+a[i]++ +"]")}/^checkbox|radio$/.test(t.type)&&!t.checked||(n[t.name]=t.value)}}),n},u.prototype.render=function(e,i){var n=this,u=t(r+function(){return i?'[lay-filter="'+i+'"]':""}()),d={select:function(){var e,i="请选择",a="layui-form-select",n="layui-select-title",r="layui-select-none",d="",f=u.find("select"),v=function(i,l){t(i.target).parent().hasClass(n)&&!l||(t("."+a).removeClass(a+"ed "+a+"up"),e&&d&&e.val(d)),e=null},y=function(i,u,f){var y,p=t(this),m=i.find("."+n),k=m.find("input"),g=i.find("dl"),x=g.children("dd"),b=this.selectedIndex;if(!u){var C=function(){var e=i.offset().top+i.outerHeight()+5-h.scrollTop(),t=g.outerHeight();b=p[0].selectedIndex,i.addClass(a+"ed"),x.removeClass(o),y=null,x.eq(b).addClass(s).siblings().removeClass(s),e+t>h.height()&&e>=t&&i.addClass(a+"up"),T()},w=function(e){i.removeClass(a+"ed "+a+"up"),k.blur(),y=null,e||$(k.val(),function(e){var i=p[0].selectedIndex;e&&(d=t(p[0].options[i]).html(),0===i&&d===k.attr("placeholder")&&(d=""),k.val(d||""))})},T=function(){var e=g.children("dd."+s);if(e[0]){var t=e.position().top,i=g.height(),a=e.height();t>i&&g.scrollTop(t+g.scrollTop()-i+a-5),t<0&&g.scrollTop(t+g.scrollTop()-5)}};m.on("click",function(e){i.hasClass(a+"ed")?w():(v(e,!0),C()),g.find("."+r).remove()}),m.find(".layui-edge").on("click",function(){k.focus()}),k.on("keyup",function(e){var t=e.keyCode;9===t&&C()}).on("keydown",function(e){var t=e.keyCode;9===t&&w();var i=function(t,a){var n,l;e.preventDefault();var r=function(){var e=g.children("dd."+s);if(g.children("dd."+o)[0]&&"next"===t){var i=g.children("dd:not(."+o+",."+c+")"),n=i.eq(0).index();if(n>=0&&n无匹配项

    '):g.find("."+r).remove()},"keyup"),""===t&&g.find("."+r).remove(),void T())};f&&k.on("keyup",q).on("blur",function(i){var a=p[0].selectedIndex;e=k,d=t(p[0].options[a]).html(),0===a&&d===k.attr("placeholder")&&(d=""),setTimeout(function(){$(k.val(),function(e){d||k.val("")},"blur")},200)}),x.on("click",function(){var e=t(this),a=e.attr("lay-value"),n=p.attr("lay-filter");return!e.hasClass(c)&&(e.hasClass("layui-select-tips")?k.val(""):(k.val(e.text()),e.addClass(s)),e.siblings().removeClass(s),p.val(a).removeClass("layui-form-danger"),layui.event.call(this,l,"select("+n+")",{elem:p[0],value:a,othis:i}),w(!0),!1)}),i.find("dl>dt").on("click",function(e){return!1}),t(document).off("click",v).on("click",v)}};f.each(function(e,l){var r=t(this),o=r.next("."+a),u=this.disabled,d=l.value,f=t(l.options[l.selectedIndex]),v=l.options[0];if("string"==typeof r.attr("lay-ignore"))return r.show();var h="string"==typeof r.attr("lay-search"),p=v?v.value?i:v.innerHTML||i:i,m=t(['
    ','
    ','','
    ','
    ',function(e){var t=[];return layui.each(e,function(e,a){0!==e||a.value?"optgroup"===a.tagName.toLowerCase()?t.push("
    "+a.label+"
    "):t.push('
    '+a.innerHTML+"
    "):t.push('
    '+(a.innerHTML||i)+"
    ")}),0===t.length&&t.push('
    没有选项
    '),t.join("")}(r.find("*"))+"
    ","
    "].join(""));o[0]&&o.remove(),r.after(m),y.call(this,m,u,h)})},checkbox:function(){var e={checkbox:["layui-form-checkbox","layui-form-checked","checkbox"],_switch:["layui-form-switch","layui-form-onswitch","switch"]},i=u.find("input[type=checkbox]"),a=function(e,i){var a=t(this);e.on("click",function(){var t=a.attr("lay-filter"),n=(a.attr("lay-text")||"").split("|");a[0].disabled||(a[0].checked?(a[0].checked=!1,e.removeClass(i[1]).find("em").text(n[1])):(a[0].checked=!0,e.addClass(i[1]).find("em").text(n[0])),layui.event.call(a[0],l,i[2]+"("+t+")",{elem:a[0],value:a[0].value,othis:e}))})};i.each(function(i,n){var l=t(this),r=l.attr("lay-skin"),s=(l.attr("lay-text")||"").split("|"),o=this.disabled;"switch"===r&&(r="_"+r);var u=e[r]||e.checkbox;if("string"==typeof l.attr("lay-ignore"))return l.show();var d=l.next("."+u[0]),f=t(['
    ",function(){var e=n.title.replace(/\s/g,""),t={checkbox:[e?""+n.title+"":"",''].join(""),_switch:""+((n.checked?s[0]:s[1])||"")+""};return t[r]||t.checkbox}(),"
    "].join(""));d[0]&&d.remove(),l.after(f),a.call(this,f,u)})},radio:function(){var e="layui-form-radio",i=["",""],a=u.find("input[type=radio]"),n=function(a){var n=t(this),s="layui-anim-scaleSpring";a.on("click",function(){var o=n[0].name,c=n.parents(r),u=n.attr("lay-filter"),d=c.find("input[name="+o.replace(/(\.|#|\[|\])/g,"\\$1")+"]");n[0].disabled||(layui.each(d,function(){var a=t(this).next("."+e);this.checked=!1,a.removeClass(e+"ed"),a.find(".layui-icon").removeClass(s).html(i[1])}),n[0].checked=!0,a.addClass(e+"ed"),a.find(".layui-icon").addClass(s).html(i[0]),layui.event.call(n[0],l,"radio("+u+")",{elem:n[0],value:n[0].value,othis:a}))})};a.each(function(a,l){var r=t(this),s=r.next("."+e),o=this.disabled;if("string"==typeof r.attr("lay-ignore"))return r.show();s[0]&&s.remove();var u=t(['
    ',''+i[l.checked?0:1]+"","
    "+function(){var e=l.title||"";return"string"==typeof r.next().attr("lay-radio")&&(e=r.next().html(),r.next().remove()),e}()+"
    ","
    "].join(""));r.after(u),n.call(this,u)})}};return e?d[e]?d[e]():a.error("不支持的"+e+"表单渲染"):layui.each(d,function(e,t){t()}),n};var d=function(){var e=null,a=f.config.verify,s="layui-form-danger",o={},c=t(this),u=c.parents(r),d=u.find("*[lay-verify]"),v=c.parents("form")[0],h=c.attr("lay-filter");return layui.each(d,function(l,r){var o=t(this),c=o.attr("lay-verify").split("|"),u=o.attr("lay-verType"),d=o.val();if(o.removeClass(s),layui.each(c,function(t,l){var c,f="",v="function"==typeof a[l];if(a[l]){var c=v?f=a[l](d,r):!a[l][0].test(d);if(f=f||a[l][1],"required"===l&&(f=o.attr("lay-reqText")||f),c)return"tips"===u?i.tips(f,function(){return"string"==typeof o.attr("lay-ignore")||"select"!==r.tagName.toLowerCase()&&!/^checkbox|radio$/.test(r.type)?o:o.next()}(),{tips:1}):"alert"===u?i.alert(f,{title:"提示",shadeClose:!0}):i.msg(f,{icon:5,shift:6}),n.android||n.ios||setTimeout(function(){r.focus()},7),o.addClass(s),e=!0}}),e)return e}),!e&&(o=f.getValue(null,u),layui.event.call(this,l,"submit("+h+")",{elem:this,form:v,field:o}))},f=new u,v=t(document),h=t(window);f.render(),v.on("reset",r,function(){var e=t(this).attr("lay-filter");setTimeout(function(){f.render(null,e)},50)}),v.on("submit",r,d).on("click","*[lay-submit]",d),e(l,f)}); -------------------------------------------------------------------------------- /web/layui/css/layui.mobile.css: -------------------------------------------------------------------------------- 1 | /** layui-v2.5.6 MIT License By https://www.layui.com */ 2 | blockquote,body,button,dd,div,dl,dt,form,h1,h2,h3,h4,h5,h6,input,legend,li,ol,p,td,textarea,th,ul{margin:0;padding:0;-webkit-tap-highlight-color:rgba(0,0,0,0)}html{font:12px 'Helvetica Neue','PingFang SC',STHeitiSC-Light,Helvetica,Arial,sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}a,button,input{-webkit-tap-highlight-color:rgba(255,0,0,0)}a{text-decoration:none;background:0 0}a:active,a:hover{outline:0}table{border-collapse:collapse;border-spacing:0}li{list-style:none}b,strong{font-weight:700}h1,h2,h3,h4,h5,h6{font-weight:500}address,cite,dfn,em,var{font-style:normal}dfn{font-style:italic}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}img{border:0;vertical-align:bottom}.layui-inline,input,label{vertical-align:middle}button,input,optgroup,select,textarea{color:inherit;font:inherit;margin:0;outline:0}button,select{text-transform:none}select{-webkit-appearance:none;border:none}input{line-height:normal}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{height:auto}input[type=search]{-webkit-appearance:textfield;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;box-sizing:content-box}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}@font-face{font-family:layui-icon;src:url(../font/iconfont.eot?v=1.0.7);src:url(../font/iconfont.eot?v=1.0.7#iefix) format('embedded-opentype'),url(../font/iconfont.woff?v=1.0.7) format('woff'),url(../font/iconfont.ttf?v=1.0.7) format('truetype'),url(../font/iconfont.svg?v=1.0.7#iconfont) format('svg')}.layui-icon{font-family:layui-icon!important;font-size:16px;font-style:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.layui-box,.layui-box *{-webkit-box-sizing:content-box!important;-moz-box-sizing:content-box!important;box-sizing:content-box!important}.layui-border-box,.layui-border-box *{-webkit-box-sizing:border-box!important;-moz-box-sizing:border-box!important;box-sizing:border-box!important}.layui-inline{position:relative;display:inline-block;*display:inline;*zoom:1}.layui-edge,.layui-upload-iframe{position:absolute;width:0;height:0}.layui-edge{border-style:dashed;border-color:transparent;overflow:hidden}.layui-elip{text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.layui-unselect{-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none}.layui-disabled,.layui-disabled:active{background-color:#d2d2d2!important;color:#fff!important;cursor:not-allowed!important}.layui-circle{border-radius:100%}.layui-show{display:block!important}.layui-hide{display:none!important}.layui-upload-iframe{border:0;visibility:hidden}.layui-upload-enter{border:1px solid #009E94;background-color:#009E94;color:#fff;-webkit-transform:scale(1.1);transform:scale(1.1)}@-webkit-keyframes layui-m-anim-scale{0%{opacity:0;-webkit-transform:scale(.5);transform:scale(.5)}100%{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}@keyframes layui-m-anim-scale{0%{opacity:0;-webkit-transform:scale(.5);transform:scale(.5)}100%{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}.layui-m-anim-scale{animation-name:layui-m-anim-scale;-webkit-animation-name:layui-m-anim-scale}@-webkit-keyframes layui-m-anim-up{0%{opacity:0;-webkit-transform:translateY(800px);transform:translateY(800px)}100%{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}@keyframes layui-m-anim-up{0%{opacity:0;-webkit-transform:translateY(800px);transform:translateY(800px)}100%{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}.layui-m-anim-up{-webkit-animation-name:layui-m-anim-up;animation-name:layui-m-anim-up}@-webkit-keyframes layui-m-anim-left{0%{-webkit-transform:translateX(100%);transform:translateX(100%)}100%{-webkit-transform:translateX(0);transform:translateX(0)}}@keyframes layui-m-anim-left{0%{-webkit-transform:translateX(100%);transform:translateX(100%)}100%{-webkit-transform:translateX(0);transform:translateX(0)}}.layui-m-anim-left{-webkit-animation-name:layui-m-anim-left;animation-name:layui-m-anim-left}@-webkit-keyframes layui-m-anim-right{0%{-webkit-transform:translateX(-100%);transform:translateX(-100%)}100%{-webkit-transform:translateX(0);transform:translateX(0)}}@keyframes layui-m-anim-right{0%{-webkit-transform:translateX(-100%);transform:translateX(-100%)}100%{-webkit-transform:translateX(0);transform:translateX(0)}}.layui-m-anim-right{-webkit-animation-name:layui-m-anim-right;animation-name:layui-m-anim-right}@-webkit-keyframes layui-m-anim-lout{0%{-webkit-transform:translateX(0);transform:translateX(0)}100%{-webkit-transform:translateX(-100%);transform:translateX(-100%)}}@keyframes layui-m-anim-lout{0%{-webkit-transform:translateX(0);transform:translateX(0)}100%{-webkit-transform:translateX(-100%);transform:translateX(-100%)}}.layui-m-anim-lout{-webkit-animation-name:layui-m-anim-lout;animation-name:layui-m-anim-lout}@-webkit-keyframes layui-m-anim-rout{0%{-webkit-transform:translateX(0);transform:translateX(0)}100%{-webkit-transform:translateX(100%);transform:translateX(100%)}}@keyframes layui-m-anim-rout{0%{-webkit-transform:translateX(0);transform:translateX(0)}100%{-webkit-transform:translateX(100%);transform:translateX(100%)}}.layui-m-anim-rout{-webkit-animation-name:layui-m-anim-rout;animation-name:layui-m-anim-rout}.layui-m-layer{position:relative;z-index:19891014}.layui-m-layer *{-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box}.layui-m-layermain,.layui-m-layershade{position:fixed;left:0;top:0;width:100%;height:100%}.layui-m-layershade{background-color:rgba(0,0,0,.7);pointer-events:auto}.layui-m-layermain{display:table;font-family:Helvetica,arial,sans-serif;pointer-events:none}.layui-m-layermain .layui-m-layersection{display:table-cell;vertical-align:middle;text-align:center}.layui-m-layerchild{position:relative;display:inline-block;text-align:left;background-color:#fff;font-size:14px;border-radius:5px;box-shadow:0 0 8px rgba(0,0,0,.1);pointer-events:auto;-webkit-overflow-scrolling:touch;-webkit-animation-fill-mode:both;animation-fill-mode:both;-webkit-animation-duration:.2s;animation-duration:.2s}.layui-m-layer0 .layui-m-layerchild{width:90%;max-width:640px}.layui-m-layer1 .layui-m-layerchild{border:none;border-radius:0}.layui-m-layer2 .layui-m-layerchild{width:auto;max-width:260px;min-width:40px;border:none;background:0 0;box-shadow:none;color:#fff}.layui-m-layerchild h3{padding:0 10px;height:60px;line-height:60px;font-size:16px;font-weight:400;border-radius:5px 5px 0 0;text-align:center}.layui-m-layerbtn span,.layui-m-layerchild h3{text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.layui-m-layercont{padding:50px 30px;line-height:22px;text-align:center}.layui-m-layer1 .layui-m-layercont{padding:0;text-align:left}.layui-m-layer2 .layui-m-layercont{text-align:center;padding:0;line-height:0}.layui-m-layer2 .layui-m-layercont i{width:25px;height:25px;margin-left:8px;display:inline-block;background-color:#fff;border-radius:100%;-webkit-animation:layui-m-anim-loading 1.4s infinite ease-in-out;animation:layui-m-anim-loading 1.4s infinite ease-in-out;-webkit-animation-fill-mode:both;animation-fill-mode:both}.layui-m-layerbtn,.layui-m-layerbtn span{position:relative;text-align:center;border-radius:0 0 5px 5px}.layui-m-layer2 .layui-m-layercont p{margin-top:20px}@-webkit-keyframes layui-m-anim-loading{0%,100%,80%{transform:scale(0);-webkit-transform:scale(0)}40%{transform:scale(1);-webkit-transform:scale(1)}}@keyframes layui-m-anim-loading{0%,100%,80%{transform:scale(0);-webkit-transform:scale(0)}40%{transform:scale(1);-webkit-transform:scale(1)}}.layui-m-layer2 .layui-m-layercont i:first-child{margin-left:0;-webkit-animation-delay:-.32s;animation-delay:-.32s}.layui-m-layer2 .layui-m-layercont i.layui-m-layerload{-webkit-animation-delay:-.16s;animation-delay:-.16s}.layui-m-layer2 .layui-m-layercont>div{line-height:22px;padding-top:7px;margin-bottom:20px;font-size:14px}.layui-m-layerbtn{display:box;display:-moz-box;display:-webkit-box;width:100%;height:50px;line-height:50px;font-size:0;border-top:1px solid #D0D0D0;background-color:#F2F2F2}.layui-m-layerbtn span{display:block;-moz-box-flex:1;box-flex:1;-webkit-box-flex:1;font-size:14px;cursor:pointer}.layui-m-layerbtn span[yes]{color:#40AFFE}.layui-m-layerbtn span[no]{border-right:1px solid #D0D0D0;border-radius:0 0 0 5px}.layui-m-layerbtn span:active{background-color:#F6F6F6}.layui-m-layerend{position:absolute;right:7px;top:10px;width:30px;height:30px;border:0;font-weight:400;background:0 0;cursor:pointer;-webkit-appearance:none;font-size:30px}.layui-m-layerend::after,.layui-m-layerend::before{position:absolute;left:5px;top:15px;content:'';width:18px;height:1px;background-color:#999;transform:rotate(45deg);-webkit-transform:rotate(45deg);border-radius:3px}.layui-m-layerend::after{transform:rotate(-45deg);-webkit-transform:rotate(-45deg)}body .layui-m-layer .layui-m-layer-footer{position:fixed;width:95%;max-width:100%;margin:0 auto;left:0;right:0;bottom:10px;background:0 0}.layui-m-layer-footer .layui-m-layercont{padding:20px;border-radius:5px 5px 0 0;background-color:rgba(255,255,255,.8)}.layui-m-layer-footer .layui-m-layerbtn{display:block;height:auto;background:0 0;border-top:none}.layui-m-layer-footer .layui-m-layerbtn span{background-color:rgba(255,255,255,.8)}.layui-m-layer-footer .layui-m-layerbtn span[no]{color:#FD482C;border-top:1px solid #c2c2c2;border-radius:0 0 5px 5px}.layui-m-layer-footer .layui-m-layerbtn span[yes]{margin-top:10px;border-radius:5px}body .layui-m-layer .layui-m-layer-msg{width:auto;max-width:90%;margin:0 auto;bottom:-150px;background-color:rgba(0,0,0,.7);color:#fff}.layui-m-layer-msg .layui-m-layercont{padding:10px 20px} -------------------------------------------------------------------------------- /web/teacherList.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 教师列表 6 | 7 | 8 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 41 |
    42 |
    43 |
    44 | 45 | 49 | 50 | 57 | 58 | 261 | 262 | -------------------------------------------------------------------------------- /web/studentList.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 学生列表 6 | 7 | 8 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 42 |
    43 |
    44 |
    45 | 46 | 47 | 51 | 58 | 59 | 284 | 285 | -------------------------------------------------------------------------------- /web/layui/lay/modules/tree.js: -------------------------------------------------------------------------------- 1 | /** layui-v2.5.6 MIT License By https://www.layui.com */ 2 | ;layui.define("form",function(e){"use strict";var i=layui.$,a=layui.form,n=layui.layer,t="tree",r={config:{},index:layui[t]?layui[t].index+1e4:0,set:function(e){var a=this;return a.config=i.extend({},a.config,e),a},on:function(e,i){return layui.onevent.call(this,t,e,i)}},l=function(){var e=this,i=e.config,a=i.id||e.index;return l.that[a]=e,l.config[a]=i,{config:i,reload:function(i){e.reload.call(e,i)},getChecked:function(){return e.getChecked.call(e)},setChecked:function(i){return e.setChecked.call(e,i)}}},c="layui-hide",d="layui-disabled",s="layui-tree-set",o="layui-tree-iconClick",h="layui-icon-addition",u="layui-icon-subtraction",p="layui-tree-entry",f="layui-tree-main",y="layui-tree-txt",v="layui-tree-pack",C="layui-tree-spread",k="layui-tree-setLineShort",m="layui-tree-showLine",x="layui-tree-lineExtend",b=function(e){var a=this;a.index=++r.index,a.config=i.extend({},a.config,r.config,e),a.render()};b.prototype.config={data:[],showCheckbox:!1,showLine:!0,accordion:!1,onlyIconControl:!1,isJump:!1,edit:!1,text:{defaultNodeName:"未命名",none:"无数据"}},b.prototype.reload=function(e){var a=this;layui.each(e,function(e,i){i.constructor===Array&&delete a.config[e]}),a.config=i.extend(!0,{},a.config,e),a.render()},b.prototype.render=function(){var e=this,a=e.config;e.checkids=[];var n=i('
    ');e.tree(n);var t=a.elem=i(a.elem);if(t[0]){if(e.key=a.id||e.index,e.elem=n,e.elemNone=i('
    '+a.text.none+"
    "),t.html(e.elem),0==e.elem.find(".layui-tree-set").length)return e.elem.append(e.elemNone);a.showCheckbox&&e.renderForm("checkbox"),e.elem.find(".layui-tree-set").each(function(){var e=i(this);e.parent(".layui-tree-pack")[0]||e.addClass("layui-tree-setHide"),!e.next()[0]&&e.parents(".layui-tree-pack").eq(1).hasClass("layui-tree-lineExtend")&&e.addClass(k),e.next()[0]||e.parents(".layui-tree-set").eq(0).next()[0]||e.addClass(k)}),e.events()}},b.prototype.renderForm=function(e){a.render(e,"LAY-tree-"+this.index)},b.prototype.tree=function(e,a){var n=this,t=n.config,r=a||t.data;layui.each(r,function(a,r){var l=r.children&&r.children.length>0,o=i('
    '),h=i(['
    ','
    ','
    ',function(){return t.showLine?l?'':'':''}(),function(){return t.showCheckbox?'':""}(),function(){return t.isJump&&r.href?''+(r.title||r.label||t.text.defaultNodeName)+"":''+(r.title||r.label||t.text.defaultNodeName)+""}(),"
    ",function(){if(!t.edit)return"";var e={add:'',update:'',del:''},i=['
    '];return t.edit===!0&&(t.edit=["update","del"]),"object"==typeof t.edit?(layui.each(t.edit,function(a,n){i.push(e[n]||"")}),i.join("")+"
    "):void 0}(),"
    "].join(""));l&&(h.append(o),n.tree(o,r.children)),e.append(h),h.prev("."+s)[0]&&h.prev().children(".layui-tree-pack").addClass("layui-tree-showLine"),l||h.parent(".layui-tree-pack").addClass("layui-tree-lineExtend"),n.spread(h,r),t.showCheckbox&&(r.checked&&n.checkids.push(r.id),n.checkClick(h,r)),t.edit&&n.operate(h,r)})},b.prototype.spread=function(e,a){var n=this,t=n.config,r=e.children("."+p),l=r.children("."+f),c=r.find("."+o),k=r.find("."+y),m=t.onlyIconControl?c:l,x="";m.on("click",function(i){var a=e.children("."+v),n=m.children(".layui-icon")[0]?m.children(".layui-icon"):m.find(".layui-tree-icon").children(".layui-icon");if(a[0]){if(e.hasClass(C))e.removeClass(C),a.slideUp(200),n.removeClass(u).addClass(h);else if(e.addClass(C),a.slideDown(200),n.addClass(u).removeClass(h),t.accordion){var r=e.siblings("."+s);r.removeClass(C),r.children("."+v).slideUp(200),r.find(".layui-tree-icon").children(".layui-icon").removeClass(u).addClass(h)}}else x="normal"}),k.on("click",function(){var n=i(this);n.hasClass(d)||(x=e.hasClass(C)?t.onlyIconControl?"open":"close":t.onlyIconControl?"close":"open",t.click&&t.click({elem:e,state:x,data:a}))})},b.prototype.setCheckbox=function(e,i,a){var n=this,t=(n.config,a.prop("checked"));if(!a.prop("disabled")){if("object"==typeof i.children||e.find("."+v)[0]){var r=e.find("."+v).find('input[same="layuiTreeCheck"]');r.each(function(){this.disabled||(this.checked=t)})}var l=function(e){if(e.parents("."+s)[0]){var i,a=e.parent("."+v),n=a.parent(),r=a.prev().find('input[same="layuiTreeCheck"]');t?r.prop("checked",t):(a.find('input[same="layuiTreeCheck"]').each(function(){this.checked&&(i=!0)}),i||r.prop("checked",!1)),l(n)}};l(e),n.renderForm("checkbox")}},b.prototype.checkClick=function(e,a){var n=this,t=n.config,r=e.children("."+p),l=r.children("."+f);l.on("click",'input[same="layuiTreeCheck"]+',function(r){layui.stope(r);var l=i(this).prev(),c=l.prop("checked");l.prop("disabled")||(n.setCheckbox(e,a,l),t.oncheck&&t.oncheck({elem:e,checked:c,data:a}))})},b.prototype.operate=function(e,a){var t=this,r=t.config,l=e.children("."+p),d=l.children("."+f);l.children(".layui-tree-btnGroup").on("click",".layui-icon",function(l){layui.stope(l);var f=i(this).data("type"),b=e.children("."+v),g={data:a,type:f,elem:e};if("add"==f){b[0]||(r.showLine?(d.find("."+o).addClass("layui-tree-icon"),d.find("."+o).children(".layui-icon").addClass(h).removeClass("layui-icon-file")):d.find(".layui-tree-iconArrow").removeClass(c),e.append('
    '));var w=r.operate&&r.operate(g),N={};if(N.title=r.text.defaultNodeName,N.id=w,t.tree(e.children("."+v),[N]),r.showLine)if(b[0])b.hasClass(x)||b.addClass(x),e.find("."+v).each(function(){i(this).children("."+s).last().addClass(k)}),b.children("."+s).last().prev().hasClass(k)?b.children("."+s).last().prev().removeClass(k):b.children("."+s).last().removeClass(k),!e.parent("."+v)[0]&&e.next()[0]&&b.children("."+s).last().removeClass(k);else{var T=e.siblings("."+s),L=1,A=e.parent("."+v);layui.each(T,function(e,a){i(a).children("."+v)[0]||(L=0)}),1==L?(T.children("."+v).addClass(m),T.children("."+v).children("."+s).removeClass(k),e.children("."+v).addClass(m),A.removeClass(x),A.children("."+s).last().children("."+v).children("."+s).last().addClass(k)):e.children("."+v).children("."+s).addClass(k)}if(!r.showCheckbox)return;if(d.find('input[same="layuiTreeCheck"]')[0].checked){var I=e.children("."+v).children("."+s).last();I.find('input[same="layuiTreeCheck"]')[0].checked=!0}t.renderForm("checkbox")}else if("update"==f){var F=d.children("."+y).html();d.children("."+y).html(""),d.append(''),d.children(".layui-tree-editInput").val(F).focus();var j=function(e){var i=e.val().trim();i=i?i:r.text.defaultNodeName,e.remove(),d.children("."+y).html(i),g.data.title=i,r.operate&&r.operate(g)};d.children(".layui-tree-editInput").blur(function(){j(i(this))}),d.children(".layui-tree-editInput").on("keydown",function(e){13===e.keyCode&&(e.preventDefault(),j(i(this)))})}else n.confirm('确认删除该节点 "'+(a.title||"")+'" 吗?',function(a){if(r.operate&&r.operate(g),g.status="remove",n.close(a),!e.prev("."+s)[0]&&!e.next("."+s)[0]&&!e.parent("."+v)[0])return e.remove(),void t.elem.append(t.elemNone);if(e.siblings("."+s).children("."+p)[0]){if(r.showCheckbox){var l=function(e){if(e.parents("."+s)[0]){var a=e.siblings("."+s).children("."+p),n=e.parent("."+v).prev(),r=n.find('input[same="layuiTreeCheck"]')[0],c=1,d=0;0==r.checked&&(a.each(function(e,a){var n=i(a).find('input[same="layuiTreeCheck"]')[0];0!=n.checked||n.disabled||(c=0),n.disabled||(d=1)}),1==c&&1==d&&(r.checked=!0,t.renderForm("checkbox"),l(n.parent("."+s))))}};l(e)}if(r.showLine){var d=e.siblings("."+s),h=1,f=e.parent("."+v);layui.each(d,function(e,a){i(a).children("."+v)[0]||(h=0)}),1==h?(b[0]||(f.removeClass(x),d.children("."+v).addClass(m),d.children("."+v).children("."+s).removeClass(k)),e.next()[0]?f.children("."+s).last().children("."+v).children("."+s).last().addClass(k):e.prev().children("."+v).children("."+s).last().addClass(k),e.next()[0]||e.parents("."+s)[1]||e.parents("."+s).eq(0).next()[0]||e.prev("."+s).addClass(k)):!e.next()[0]&&e.hasClass(k)&&e.prev().addClass(k)}}else{var y=e.parent("."+v).prev();if(r.showLine){y.find("."+o).removeClass("layui-tree-icon"),y.find("."+o).children(".layui-icon").removeClass(u).addClass("layui-icon-file");var w=y.parents("."+v).eq(0);w.addClass(x),w.children("."+s).each(function(){i(this).children("."+v).children("."+s).last().addClass(k)})}else y.find(".layui-tree-iconArrow").addClass(c);e.parents("."+s).eq(0).removeClass(C),e.parent("."+v).remove()}e.remove()})})},b.prototype.events=function(){var e=this,a=e.config;e.elem.find(".layui-tree-checkedFirst");e.setChecked(e.checkids),e.elem.find(".layui-tree-search").on("keyup",function(){var n=i(this),t=n.val(),r=n.nextAll(),l=[];r.find("."+y).each(function(){var e=i(this).parents("."+p);if(i(this).html().indexOf(t)!=-1){l.push(i(this).parent());var a=function(e){e.addClass("layui-tree-searchShow"),e.parent("."+v)[0]&&a(e.parent("."+v).parent("."+s))};a(e.parent("."+s))}}),r.find("."+p).each(function(){var e=i(this).parent("."+s);e.hasClass("layui-tree-searchShow")||e.addClass(c)}),0==r.find(".layui-tree-searchShow").length&&e.elem.append(e.elemNone),a.onsearch&&a.onsearch({elem:l})}),e.elem.find(".layui-tree-search").on("keydown",function(){i(this).nextAll().find("."+p).each(function(){var e=i(this).parent("."+s);e.removeClass("layui-tree-searchShow "+c)}),i(".layui-tree-emptyText")[0]&&i(".layui-tree-emptyText").remove()})},b.prototype.getChecked=function(){var e=this,a=e.config,n=[],t=[];e.elem.find(".layui-form-checked").each(function(){n.push(i(this).prev()[0].value)});var r=function(e,a){layui.each(e,function(e,t){layui.each(n,function(e,n){if(t.id==n){var l=i.extend({},t);return delete l.children,a.push(l),t.children&&(l.children=[],r(t.children,l.children)),!0}})})};return r(i.extend({},a.data),t),t},b.prototype.setChecked=function(e){var a=this;a.config;a.elem.find("."+s).each(function(a,n){var t=i(this).data("id"),r=i(n).children("."+p).find('input[same="layuiTreeCheck"]'),l=r.next();if("number"==typeof e){if(t==e)return r[0].checked||l.click(),!1}else"object"==typeof e&&layui.each(e,function(e,i){if(i==t&&!r[0].checked)return l.click(),!0})})},l.that={},l.config={},r.reload=function(e,i){var a=l.that[e];return a.reload(i),l.call(a)},r.getChecked=function(e){var i=l.that[e];return i.getChecked()},r.setChecked=function(e,i){var a=l.that[e];return a.setChecked(i)},r.render=function(e){var i=new b(e);return l.call(i)},e(t,r)}); --------------------------------------------------------------------------------