基于web的实验教学管理系统java ssm教学视频平台源码和论文

news2025/1/12 10:53:10

 

研究背景

近几年来,随着地方高等院校办学规模的不断扩大,为了适用社会发展需要,地方高校将应用
型人才培养作为学校的人才培养目标。为了适应学校应用型人才培养目标,各专业尤其是理工科专
业人才培养方案中加强了实践教学环节,因此,实践教学管理成为高等院校教学管理的重要内容之
一。
目前高校教学管理都采用了基于网络的信息化管理系统,但是由于实践教学在课程教学时间安
排、课程教学内容、周数等方面不同于传统的课程教学,通用的教学管理系统不能很好地适应实践
教学管理。根据我系实践教学的需求,基于 java web 设计与实现了一个实践教学管理系统,满足实
践教学管理的需求要求,更好地实现实践课程教学管理。

 

 

 演示视频:

【java毕业设计】基于web的实验教学管理系统java ssm教学视频平台源码和论文

研究目标

调研我系的实际情况,根据软件工程的思想,设计并开发了一个适合我系实践教学管理的系统,
该系统包括学生和教师信息的管理、实践教学管理、学生成绩管理等功能,基本上满足了实践教学
的需求。

 

pom.xml:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
	<modelVersion>4.0.0</modelVersion>
	<groupId>com.jlwl</groupId>
	<artifactId>jspmx120k</artifactId>
	<packaging>war</packaging>
	<version>1.0-SNAPSHOT</version>

	<properties>
		<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
		<spring.version>5.0.0.RELEASE</spring.version>
		<junit.version>4.12</junit.version>
		<druid.version>1.1.0</druid.version>
		<fastjson.version>1.2.8</fastjson.version>
		<mybaitsplus.version>2.3</mybaitsplus.version>
		<mysql.version>5.1.38</mysql.version>
		<log4j.version>1.2.17</log4j.version>
		<slf4j.version>1.7.19</slf4j.version>
		<aspectjweaver.version>1.8.8</aspectjweaver.version>
		<fileupload.version>1.3.1</fileupload.version>
		<jstl.version>1.2</jstl.version>
	</properties>

	<dependencies>
		<!-- JUnit -->
		<dependency>
			<groupId>junit</groupId>
			<artifactId>junit</artifactId>
			<version>${junit.version}</version>
			<scope>test</scope>
		</dependency>

		<!-- Spring -->
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-core</artifactId>
			<version>${spring.version}</version>
			<type>jar</type>
			<scope>compile</scope>
		</dependency>
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-context</artifactId>
			<version>${spring.version}</version>
			<type>jar</type>
			<scope>compile</scope>
		</dependency>
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-context-support</artifactId>
			<version>${spring.version}</version>
			<type>jar</type>
			<scope>compile</scope>
		</dependency>
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-tx</artifactId>
			<version>${spring.version}</version>
			<type>jar</type>
			<scope>compile</scope>
		</dependency>
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-aop</artifactId>
			<version>${spring.version}</version>
			<type>jar</type>
			<scope>compile</scope>
		</dependency>
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-beans</artifactId>
			<version>${spring.version}</version>
			<type>jar</type>
			<scope>compile</scope>
		</dependency>
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-jdbc</artifactId>
			<version>${spring.version}</version>
			<type>jar</type>
			<scope>compile</scope>
		</dependency>

		<!-- Spring MVC -->
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-web</artifactId>
			<version>${spring.version}</version>
			<type>jar</type>
			<scope>compile</scope>
		</dependency>
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-webmvc</artifactId>
			<version>${spring.version}</version>
			<type>jar</type>
			<scope>compile</scope>
		</dependency>

		<!-- AOP -->
		<dependency>
			<groupId>org.aspectj</groupId>
			<artifactId>aspectjweaver</artifactId>
			<version>${aspectjweaver.version}</version>
		</dependency>

		<!-- FileUpload -->
		<dependency>
			<groupId>commons-fileupload</groupId>
			<artifactId>commons-fileupload</artifactId>
			<version>${fileupload.version}</version>
		</dependency>

		<dependency>
			<groupId>javax.servlet</groupId>
			<artifactId>jstl</artifactId>
			<version>${jstl.version}</version>
		</dependency>

		<!-- Mybatis-Plus -->
		<dependency>
			<groupId>com.baomidou</groupId>
			<artifactId>mybatis-plus</artifactId>
			<version>${mybaitsplus.version}</version>
		</dependency>

		<!-- Mysql -->
		<dependency>
			<groupId>mysql</groupId>
			<artifactId>mysql-connector-java</artifactId>
			<version>${mysql.version}</version>
		</dependency>
		<!-- Druid -->
		<dependency>
			<groupId>com.alibaba</groupId>
			<artifactId>druid</artifactId>
			<version>${druid.version}</version>
		</dependency>

		<!-- FastJson -->
		<dependency>
			<groupId>com.alibaba</groupId>
			<artifactId>fastjson</artifactId>
			<version>${fastjson.version}</version>
		</dependency>

		<!-- Log -->
		<dependency>
			<groupId>log4j</groupId>
			<artifactId>log4j</artifactId>
			<version>${log4j.version}</version>
		</dependency>
		<dependency>
			<groupId>org.slf4j</groupId>
			<artifactId>slf4j-api</artifactId>
			<version>${slf4j.version}</version>
		</dependency>
		<dependency>
			<groupId>org.slf4j</groupId>
			<artifactId>slf4j-log4j12</artifactId>
			<version>${slf4j.version}</version>
		</dependency>

		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-test</artifactId>
			<version>${spring.version}</version>
		</dependency>
		
		<dependency>
		    <groupId>org.apache.commons</groupId>
		    <artifactId>commons-lang3</artifactId>
		    <version>3.0</version>
		</dependency>
		
		<dependency>
		    <groupId>javax.validation</groupId>
		    <artifactId>validation-api</artifactId>
		    <version>2.0.1.Final</version>
		</dependency>
		
		<dependency>
		    <groupId>commons-io</groupId>
		    <artifactId>commons-io</artifactId>
		    <version>2.5</version>
		</dependency>
		
		<dependency>
		    <groupId>cn.hutool</groupId>
		    <artifactId>hutool-all</artifactId>
		    <version>4.0.12</version>
		</dependency>
		<!-- https://mvnrepository.com/artifact/org.apache.tomcat.embed/tomcat-embed-core -->
		<dependency>
		    <groupId>org.apache.tomcat.embed</groupId>
		    <artifactId>tomcat-embed-core</artifactId>
		    <version>9.0.29</version>
		</dependency>
		
		<!-- https://mvnrepository.com/artifact/commons-beanutils/commons-beanutils -->
		<dependency>
		    <groupId>commons-beanutils</groupId>
		    <artifactId>commons-beanutils</artifactId>
		    <version>1.8.0</version>
		</dependency>
		
		<!-- https://mvnrepository.com/artifact/com.fasterxml.jackson.core/jackson-annotations -->
		<dependency>
		    <groupId>com.fasterxml.jackson.core</groupId>
		    <artifactId>jackson-annotations</artifactId>
		    <version>2.10.1</version>
		</dependency>
		
		<dependency>
	        <groupId>com.fasterxml.jackson.core</groupId>
	        <artifactId>jackson-databind</artifactId>
	        <version>2.10.1</version>
	    </dependency>
	 
	    <dependency>
	        <groupId>org.codehaus.jackson</groupId>
	        <artifactId>jackson-mapper-asl</artifactId>
	        <version>1.9.13</version>
	    </dependency>
		
		<!-- https://mvnrepository.com/artifact/javax.servlet.jsp/jsp-api -->
		<dependency>
		    <groupId>javax.servlet.jsp</groupId>
		    <artifactId>jsp-api</artifactId>
		    <version>2.1</version>
		    <scope>provided</scope>
		</dependency>
		
		<!-- 百度人工智能 -->
		<dependency>
    		<groupId>com.baidu.aip</groupId>
    		<artifactId>java-sdk</artifactId>
    		<version>4.4.1</version>
		</dependency>
		
		<!-- https://mvnrepository.com/artifact/org.apache.tomcat.embed/tomcat-embed-jasper -->
		<dependency>
		    <groupId>org.apache.tomcat.embed</groupId>
		    <artifactId>tomcat-embed-jasper</artifactId>
		    <version>9.0.27</version>
		    <scope>provided</scope>
		</dependency>


		<!-- pdf start -->
		<dependency>
			<groupId>com.itextpdf</groupId>
			<artifactId>itextpdf</artifactId>
			<version>5.3.2</version>
		</dependency>
		<dependency>
			<groupId>com.itextpdf</groupId>
			<artifactId>itext-asian</artifactId>
			<version>5.2.0</version>
		</dependency>
		<!-- pdf end -->

	</dependencies>

	<build>
	<!-- 项目访问名称 -->
		<finalName>jspmx120k</finalName>
		<plugins>
			<plugin>
				<groupId>org.apache.maven.plugins</groupId>
				<artifactId>maven-compiler-plugin</artifactId>
				<configuration>
					<source>1.7</source>
					<target>1.7</target>
				</configuration>
			</plugin>
		</plugins>
	</build>
</project>

 

 

 

 

package com.controller;

import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Calendar;
import java.util.Map;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Date;
import java.util.List;
import javax.servlet.http.HttpServletRequest;

import com.utils.ValidatorUtils;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.baomidou.mybatisplus.mapper.Wrapper;
import com.annotation.IgnoreAuth;

import com.entity.XueshengEntity;
import com.entity.view.XueshengView;

import com.service.XueshengService;
import com.service.TokenService;
import com.utils.PageUtils;
import com.utils.R;
import com.utils.MD5Util;
import com.utils.MPUtil;
import com.utils.CommonUtil;


/**
 * 学生
 * 后端接口
 * @author 
 * @email 
 * @date 2022-02-12 18:33:18
 */
@RestController
@RequestMapping("/xuesheng")
public class XueshengController {
    @Autowired
    private XueshengService xueshengService;
    
	@Autowired
	private TokenService tokenService;
	
	/**
	 * 登录
	 */
	@IgnoreAuth
	@RequestMapping(value = "/login")
	public R login(String username, String password, String captcha, HttpServletRequest request) {
		XueshengEntity user = xueshengService.selectOne(new EntityWrapper<XueshengEntity>().eq("xueshengzhanghao", username));
		if(user==null || !user.getMima().equals(password)) {
			return R.error("账号或密码不正确");
		}
		String token = tokenService.generateToken(user.getId(), username,"xuesheng",  "学生" );
		request.getSession().setAttribute("xuesheng",user);
		request.getSession().removeAttribute("user");
		request.getSession().removeAttribute("jiaoshi");
		return R.ok().put("token", token);
	}
	
	/**
     * 注册
     */
	@IgnoreAuth
    @RequestMapping("/register")
    public R register(@RequestBody XueshengEntity xuesheng){
    	//ValidatorUtils.validateEntity(xuesheng);
    	XueshengEntity user = xueshengService.selectOne(new EntityWrapper<XueshengEntity>().eq("xueshengzhanghao", xuesheng.getXueshengzhanghao()));
		if(user!=null) {
			return R.error("注册用户已存在");
		}
		Long uId = new Date().getTime();
		xuesheng.setId(uId);
        xueshengService.insert(xuesheng);
        return R.ok();
    }
	
	/**
	 * 退出
	 */
	@RequestMapping("/logout")
	public R logout(HttpServletRequest request) {
		request.getSession().invalidate();
		return R.ok("退出成功");
	}
	
	/**
     * 获取用户的session用户信息
     */
    @RequestMapping("/session")
    public R getCurrUser(HttpServletRequest request){
    	Long id = (Long)request.getSession().getAttribute("userId");
        XueshengEntity user = xueshengService.selectById(id);
        return R.ok().put("data", user);
    }
    
    /**
     * 密码重置
     */
    @IgnoreAuth
	@RequestMapping(value = "/resetPass")
    public R resetPass(String username, HttpServletRequest request){
    	XueshengEntity user = xueshengService.selectOne(new EntityWrapper<XueshengEntity>().eq("xueshengzhanghao", username));
    	if(user==null) {
    		return R.error("账号不存在");
    	}
        user.setMima("123456");
        xueshengService.updateById(user);
        return R.ok("密码已重置为:123456");
    }


    /**
     * 后端列表
     */
    @RequestMapping("/page")
    public R page(@RequestParam Map<String, Object> params,XueshengEntity xuesheng, HttpServletRequest request){

        EntityWrapper<XueshengEntity> ew = new EntityWrapper<XueshengEntity>();
    	PageUtils page = xueshengService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, xuesheng), params), params));
		request.setAttribute("data", page);
        return R.ok().put("data", page);
    }
    
    /**
     * 前端列表
     */
    @RequestMapping("/list")
    public R list(@RequestParam Map<String, Object> params,XueshengEntity xuesheng, HttpServletRequest request){
        EntityWrapper<XueshengEntity> ew = new EntityWrapper<XueshengEntity>();
    	PageUtils page = xueshengService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, xuesheng), params), params));
		request.setAttribute("data", page);
        return R.ok().put("data", page);
    }

	/**
     * 列表
     */
    @RequestMapping("/lists")
    public R list( XueshengEntity xuesheng){
       	EntityWrapper<XueshengEntity> ew = new EntityWrapper<XueshengEntity>();
      	ew.allEq(MPUtil.allEQMapPre( xuesheng, "xuesheng")); 
        return R.ok().put("data", xueshengService.selectListView(ew));
    }

	 /**
     * 查询
     */
    @RequestMapping("/query")
    public R query(XueshengEntity xuesheng){
        EntityWrapper< XueshengEntity> ew = new EntityWrapper< XueshengEntity>();
 		ew.allEq(MPUtil.allEQMapPre( xuesheng, "xuesheng")); 
		XueshengView xueshengView =  xueshengService.selectView(ew);
		return R.ok("查询学生成功").put("data", xueshengView);
    }
	
    /**
     * 后端详情
     */
    @RequestMapping("/info/{id}")
    public R info(@PathVariable("id") Long id){
        XueshengEntity xuesheng = xueshengService.selectById(id);
        return R.ok().put("data", xuesheng);
    }

    /**
     * 前端详情
     */
    @RequestMapping("/detail/{id}")
    public R detail(@PathVariable("id") Long id){
        XueshengEntity xuesheng = xueshengService.selectById(id);
        return R.ok().put("data", xuesheng);
    }
    



    /**
     * 后端保存
     */
    @RequestMapping("/save")
    public R save(@RequestBody XueshengEntity xuesheng, HttpServletRequest request){
    	xuesheng.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
    	//ValidatorUtils.validateEntity(xuesheng);
    	XueshengEntity user = xueshengService.selectOne(new EntityWrapper<XueshengEntity>().eq("xueshengzhanghao", xuesheng.getXueshengzhanghao()));
		if(user!=null) {
			return R.error("用户已存在");
		}

		xuesheng.setId(new Date().getTime());
        xueshengService.insert(xuesheng);
        return R.ok();
    }
    
    /**
     * 前端保存
     */
    @RequestMapping("/add")
    public R add(@RequestBody XueshengEntity xuesheng, HttpServletRequest request){
    	xuesheng.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
    	//ValidatorUtils.validateEntity(xuesheng);
    	XueshengEntity user = xueshengService.selectOne(new EntityWrapper<XueshengEntity>().eq("xueshengzhanghao", xuesheng.getXueshengzhanghao()));
		if(user!=null) {
			return R.error("用户已存在");
		}

		xuesheng.setId(new Date().getTime());
        xueshengService.insert(xuesheng);
        return R.ok();
    }

    /**
     * 修改
     */
    @RequestMapping("/update")
    public R update(@RequestBody XueshengEntity xuesheng, HttpServletRequest request){
        //ValidatorUtils.validateEntity(xuesheng);
        xueshengService.updateById(xuesheng);//全部更新
        return R.ok();
    }
    

    /**
     * 删除
     */
    @RequestMapping("/delete")
    public R delete(@RequestBody Long[] ids){
        xueshengService.deleteBatchIds(Arrays.asList(ids));
        return R.ok();
    }
    
    /**
     * 提醒接口
     */
	@RequestMapping("/remind/{columnName}/{type}")
	public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request, 
						 @PathVariable("type") String type,@RequestParam Map<String, Object> map) {
		map.put("column", columnName);
		map.put("type", type);
		
		if(type.equals("2")) {
			SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
			Calendar c = Calendar.getInstance();
			Date remindStartDate = null;
			Date remindEndDate = null;
			if(map.get("remindstart")!=null) {
				Integer remindStart = Integer.parseInt(map.get("remindstart").toString());
				c.setTime(new Date()); 
				c.add(Calendar.DAY_OF_MONTH,remindStart);
				remindStartDate = c.getTime();
				map.put("remindstart", sdf.format(remindStartDate));
			}
			if(map.get("remindend")!=null) {
				Integer remindEnd = Integer.parseInt(map.get("remindend").toString());
				c.setTime(new Date());
				c.add(Calendar.DAY_OF_MONTH,remindEnd);
				remindEndDate = c.getTime();
				map.put("remindend", sdf.format(remindEndDate));
			}
		}
		
		Wrapper<XueshengEntity> wrapper = new EntityWrapper<XueshengEntity>();
		if(map.get("remindstart")!=null) {
			wrapper.ge(columnName, map.get("remindstart"));
		}
		if(map.get("remindend")!=null) {
			wrapper.le(columnName, map.get("remindend"));
		}


		int count = xueshengService.selectCount(wrapper);
		return R.ok().put("count", count);
	}
	
	


}

 

 

package com.controller;

import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.entity.JiaoshiEntity;
import com.entity.NewsEntity;
import com.entity.ShiyanbaogaoEntity;
import com.entity.XueshengEntity;
import com.itextpdf.text.Document;
import com.itextpdf.text.PageSize;
import com.itextpdf.text.Rectangle;
import com.itextpdf.text.pdf.PdfPTable;
import com.itextpdf.text.pdf.PdfWriter;
import com.service.JiaoshiService;
import com.service.ShiyanbaogaoService;
import com.service.UserService;
import com.utils.PDFBuilder;
import com.utils.PDFReport;
import com.utils.PdfUtil;
import com.utils.R;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;

import javax.servlet.http.HttpSession;
import java.io.File;
import java.io.FileOutputStream;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.List;
import java.util.UUID;

/**
 * @author
 * @date 2022-02-11 11:56
 */

@Controller
@RequestMapping("/shiyanbaogao")
public class ShiyanbaogaoController {
    @Autowired
    private JiaoshiService jiaoshiService;
    @Autowired
    private ShiyanbaogaoService shiyanbaogaoService;
    @Autowired
    private UserService userService;
    Document document = new Document();// 建立一个Document对象
    @RequestMapping("toTijiaoPage")
    public String toTijiaoPage(Model model,HttpSession session){


        XueshengEntity xueshengEntity = (XueshengEntity) session.getAttribute("xuesheng");
        if(xueshengEntity!=null){
            EntityWrapper<JiaoshiEntity> ew = new EntityWrapper<JiaoshiEntity>();
            List<JiaoshiEntity> jiaoshiEntityList = jiaoshiService.selectList(ew);
            model.addAttribute("jiaoshiEntityList",jiaoshiEntityList);
            return "baogao/index";
        }

        JiaoshiEntity jiaoshiEntity = (JiaoshiEntity) session.getAttribute("jiaoshi");
        if(jiaoshiEntity!=null){

            return  "redirect:../shiyanbaogao/tea_list";
        }


        return "index";

    }

    @RequestMapping("add")
    public String add(ShiyanbaogaoEntity shiyanbaogaoEntity, HttpSession session){

        XueshengEntity xueshengEntity = (XueshengEntity) session.getAttribute("xuesheng");
        if(xueshengEntity==null){
            //return R.error("请先登录");
        }
        shiyanbaogaoEntity.setCreatetime(new Date());
        //shiyanbaogaoEntity.setJiaoshigonghao();
       shiyanbaogaoEntity.setNianji(xueshengEntity.getNianji());
        shiyanbaogaoEntity.setXueshengzhanghao(xueshengEntity.getXueshengzhanghao());
       shiyanbaogaoEntity.setXueshengxingming(xueshengEntity.getXueshengxingming());
        shiyanbaogaoEntity.setXueshengId(xueshengEntity.getId().intValue());

        JiaoshiEntity jiaoshiEntity = jiaoshiService.selectById(shiyanbaogaoEntity.getJiaoshiId());
        if(jiaoshiEntity!=null){
            shiyanbaogaoEntity.setJiaoshigonghao(jiaoshiEntity.getJiaoshixingming());
        }else{
            shiyanbaogaoEntity.setJiaoshigonghao("程序猿");
        }

        shiyanbaogaoService.insert(shiyanbaogaoEntity);

      return  "redirect:../shiyanbaogao/list";
   }


   @RequestMapping("tea_list")
   public String tea_list(HttpSession session,Model model){
       JiaoshiEntity jiaoshiEntity = (JiaoshiEntity) session.getAttribute("jiaoshi");
       EntityWrapper<ShiyanbaogaoEntity> ew = new EntityWrapper<ShiyanbaogaoEntity>();
       ew.eq("jiaoshi_id",jiaoshiEntity.getId());
       List<ShiyanbaogaoEntity> shiyanbaogaoEntityList = shiyanbaogaoService.selectList(ew);
       model.addAttribute("shiyanbaogaoEntityList",shiyanbaogaoEntityList);


       String[] data1 =new String[10];
       String[] data2 =new String[10];


       Integer[] score1 =new Integer[10];
       Integer[] score2 =new Integer[10];
       List<ShiyanbaogaoEntity> list1 = shiyanbaogaoService.selectNum1();
       List<ShiyanbaogaoEntity> list2 = shiyanbaogaoService.selectpinjun();
       int i=0;
       for (ShiyanbaogaoEntity shiyanbaogaoEntity:list1) {
           data1[i] = shiyanbaogaoEntity.getXueshengxingming();
           score1[i] = shiyanbaogaoEntity.getScore();
           i++;
       }

        int j=0;
       for (ShiyanbaogaoEntity shiyanbaogaoEntity:list2) {
               data2[j] = shiyanbaogaoEntity.getNianji();
           score2[j] = shiyanbaogaoEntity.getScore();
               j++;
       }

       model.addAttribute("data1",data1);
       model.addAttribute("data2",data2);
       model.addAttribute("score1",score1);
       model.addAttribute("score2",score2);

       return "baogao/tea_list";
   }


    @RequestMapping("list")
    public String list(HttpSession session,Model model){
        EntityWrapper<ShiyanbaogaoEntity> ew = new EntityWrapper<ShiyanbaogaoEntity>();
        XueshengEntity xueshengEntity = (XueshengEntity) session.getAttribute("xuesheng");
        ew.eq("xuesheng_id",xueshengEntity.getId());
        List<ShiyanbaogaoEntity> shiyanbaogaoEntityList = shiyanbaogaoService.selectList(ew);
        model.addAttribute("shiyanbaogaoEntityList",shiyanbaogaoEntityList);
        return "baogao/list";
    }


    @RequestMapping("detail")
   public String detail(Integer id,Model model){
        ShiyanbaogaoEntity shiyanbaogaoEntity = shiyanbaogaoService.selectById(id);
        model.addAttribute("shiyanbaogaoEntity",shiyanbaogaoEntity);
        return "baogao/pingfen";
   }

    @RequestMapping("delete")
    public String delete(Integer id,HttpSession session){
        shiyanbaogaoService.deleteById(id);
        XueshengEntity xueshengEntity = (XueshengEntity) session.getAttribute("xuesheng");
        if(xueshengEntity!=null){
            return  "redirect:../shiyanbaogao/list";
        }

        JiaoshiEntity jiaoshiEntity = (JiaoshiEntity) session.getAttribute("jiaoshi");
        if(jiaoshiEntity!=null){
            return  "redirect:../shiyanbaogao/tea_list";
        }

        return "index";
    }

    /**
     * 评价实验报告 打分
     * @param shiyanbaogaoEntity
     * @param session
     * @return
     */
    @RequestMapping("pingjia")
    public String pingjia(ShiyanbaogaoEntity shiyanbaogaoEntity, HttpSession session){

        ShiyanbaogaoEntity baogao = shiyanbaogaoService.selectById(shiyanbaogaoEntity.getId());

        baogao.setPingyu(shiyanbaogaoEntity.getPingyu());
        baogao.setScore(shiyanbaogaoEntity.getScore());
        baogao.setPtime(new Date());
        shiyanbaogaoService.updateById(baogao);
        return  "redirect:../shiyanbaogao/tea_list";
    }



     @RequestMapping("xiazai")
    public  String xiazai(Integer id,HttpSession session) throws Exception {

         ShiyanbaogaoEntity baogao =shiyanbaogaoService.selectById(id);


         //设置单元格为5列
         PdfPTable table = PdfUtil.createTable(4);

         table.addCell(PdfUtil.createHeadCell(baogao.getXueshengxingming()+"实验成绩报告单"));

         table.addCell(PdfUtil.createTitleCell_1("学生姓名"));
         table.addCell(PdfUtil.createCell_1(baogao.getXueshengxingming()));
         table.addCell(PdfUtil.createTitleCell_1("指导老师"));
         table.addCell(PdfUtil.createCell_1(baogao.getJiaoshigonghao()));
         //table.addCell(PdfUtil.createCell_2("Logo"));

         table.addCell(PdfUtil.createTitleCell_1("报告内容"));
         table.addCell(PdfUtil.createCell_4(baogao.getContent()));
         table.addCell(PdfUtil.createTitleCell_1("教师评语"));
         table.addCell(PdfUtil.createCell_4(baogao.getPingyu()));

         SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");//设置日期格式
         table.addCell(PdfUtil.createTitleCell_1("教师评分"));
         table.addCell(PdfUtil.createCell_1(baogao.getScore().toString()));
         table.addCell(PdfUtil.createTitleCell_1("生成时间"));
         table.addCell(PdfUtil.createCell_1(df.format(new Date())));

         File file1=new File("D:\\file");
         if(!file1.exists()) {//如果文件夹不存在
             file1.mkdir();//创建文件夹
         }

        String UUID = java.util.UUID.randomUUID().toString();
        String path = "D:/file/"+UUID+".pdf";
         try {
             File file = new File(path);
             file.createNewFile();
             Rectangle pageSize = new Rectangle(PageSize.A4);
             document.setPageSize(pageSize);
             PdfWriter writer = PdfWriter.getInstance(document, new FileOutputStream(file));
             PDFBuilder builder = new PDFBuilder();
             writer.setPageEvent(builder);
             document.open();
             //PdfPTable table = generatePDF();
             document.add(table);
             document.close();
         } catch (Exception e) {
             e.printStackTrace();
         }
         String test="d:/file/"+baogao.getXueshengxingming()+"实验报告"+UUID+".pdf";
         PdfUtil.addImage(path,test ,baogao.getPingyu(),null);

         XueshengEntity xueshengEntity = (XueshengEntity) session.getAttribute("xuesheng");
         if(xueshengEntity!=null){
             return  "redirect:../shiyanbaogao/list";
         }

         JiaoshiEntity jiaoshiEntity = (JiaoshiEntity) session.getAttribute("jiaoshi");
         if(jiaoshiEntity!=null){
             return  "redirect:../shiyanbaogao/tea_list";
         }

         return "index";
     }


     @RequestMapping("data1")
     @ResponseBody
     public List<ShiyanbaogaoEntity> list(){

         List<ShiyanbaogaoEntity> list2 = shiyanbaogaoService.selectpinjun();
        return list2;
   }

    @RequestMapping("data2")
    @ResponseBody
    public List<ShiyanbaogaoEntity> data2(){
        List<ShiyanbaogaoEntity> list1 = shiyanbaogaoService.selectNum1();

        return list1;
    }

}

 

  随着科技发展,现代的计算机信息技术不断进步,在学校系统管理方面逐步开始普遍借助计算机处理数据来完成对数据的操作,对于实验教学实验教学系统所设计的管理及数据保存而言极为常见,例如主页、个人中心、学生管理、教师管理、班级管理、实验教学信息管理、系统管理等,这给管理者的工作带来了巨大的挑战,用传统方式处理归类大量的信息,都是通过笔记的方式进行详细信息的统计,计算机普及之后,逐渐开始使用电脑软件将信息输入到电脑内进行统计,但想要统计数据信息仍然比较繁琐和困难,而通过计算机对数据进行处理排版相对人工而言更为简单省力,因此实验教学实验教学系统顺应需求产生;该系统可以为用户提供了上传信息的便利,同时方便了管理员查看、维护系统,还可以通过客户需求对系统进行相应的调整和维护等;同时对于用户而言,可以随时查看网站内的各种信息,管理员可以非常轻松地获取到相应的数据信息并进行分类处理等,节省了用户和管理员在各个方面需要的时间。

本论文实验教学实验教学系统主要牵扯到的程序基础理论等。如果加以改造使用,普及范围会更为广泛,可以提高工作人员的工作效率。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/76189.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

1559_AURIX_TC275_RCU系统中的Boot支持、Pad配置以及NMI trap处理

全部学习汇总&#xff1a; GreyZhang/g_TC275: happy hacking for TC275! (github.com) 这一次看的10页文档虽然文字内容不多&#xff0c;但是涉及到的面还是很多的。而且&#xff0c;看完之后的确是有一种答疑解惑的畅快感。 1. ESRx作为GPIO用的时候&#xff0c;也拥有GPIO设…

高等数学(第七版)同济大学 习题11-1 个人解答

高等数学&#xff08;第七版&#xff09;同济大学 习题11-1 函数作图软件&#xff1a;Mathematica 1.设在xOy面内有一分布着质量的曲线弧L&#xff0c;在点(x,y)处它的线密度为μ(x,y)&#xff0c;用对弧长的曲线积分分别表达&#xff1a;\begin{aligned}&1. \ 设在xOy面内…

蓝桥杯嵌入式MCP4017

文章目录前言一、查看MCP4017芯片手册二、MCP4017在开发板上的电路图三、工程配置四、MCP4017读写函数编写总结前言 MCP4017是一个可编程电阻&#xff0c;通过写入数值可以调节电阻值的大小。 一、查看MCP4017芯片手册 在这里我们只需要关注MCP4017即可。下面的几个重要点我…

广播、组播 socket编程

目录 1、单播 / 广播 / 组播 的概念 (1) 单播 (2) 广播 (3) 多播&#xff08;组播&#xff09; 2、广播 socket编程&#xff08;只能是UDP通信&#xff09; 3、多播 socket编程&#xff08;只能是UDP通信&#xff09; 1、单播 / 广播 / 组播 的概念 (1) 单播 之前在进行…

m基于FPGA的MSK调制解调系统verilog开发,并带FPGA误码检测模块和matlab仿真程序

目录 1.算法描述 2.仿真效果预览 3.Verilog核心程序 4.完整FPGA 1.算法描述 整个模型的基本框图为 软件无线电是现代通信技术的重要研究领域和发展方向,目前发展迅速.快速发展的软件无线电技术与落后的硬件计算资源之间的矛盾越来越突出.为了缓解这个矛盾,一方面可以加快集…

职场日常:一文剖析性能测试流程,时间为啥那么长?

如果你做过性能测试&#xff0c;你就会知道&#xff0c;性能测试的时间要比功能测试时间长很多&#xff0c;但是&#xff0c;你没有做过&#xff0c;你可能就会问了&#xff0c;为什么性能测试时间要长那么多呢&#xff1f;今天就用一文&#xff0c;带大家了解性能测试工作流程…

自学python?一般人我还是劝你算了吧

前言 本人纯屌丝一枚&#xff0c;在学python之前对电脑的认知也就只限于上个网&#xff0c;玩个办公软件。这里不能跑题&#xff0c;我为啥说自学python&#xff0c;一般人我还是劝你算了吧。因为我就是那个一般人。 基础真的很简单&#xff0c;是个人稍微认点真都能懂&#…

Python一学就会系列:01 开发环境搭建 及 hello world

文章目录前言一、python是什么&#xff1f;官网简介二、开发环境安装1.下载2.安装3. 验证是否安装成功编写一个python新建一个后缀名为py的文件运行python文件总结前言 一、python是什么&#xff1f; 官网 https://www.python.org/ 简介 官网介绍&#xff1a; Python是一种编…

美团面试官总结的“Spring boot面试文档”,全是大厂高频面试题,太全了!

前言 Spring boot不单单在BAT这些一线大厂使用率极其的高&#xff0c;在中小企业中使用率也是非常高的&#xff0c;企业的需求增大&#xff0c;当然对待面试者的要求也会随之提高&#xff0c;竞争也会随之增大。 相信现在的你之所以可以看到我的这篇文章&#xff0c;那肯定是…

[附源码]计算机毕业设计的高校课程知识库Springboot程序

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

Python数据分析项目案例

第一部分&#xff1a;数据类型处理 数据加载 字段含义&#xff1a; user_id:用户IDorder_dt:购买日期order_product:购买产品的数量order_amount:购买金额观察数据 查看数据的数据类型数据中是否存储在缺失值将order_dt转换成时间类型查看数据的统计描述在源数据中添加一列表示…

图像风格迁移基础入门及实践案例总结

目录 &#xff11;图像的不同风格 &#xff12;何为图像风格迁移 &#xff12;.&#xff11;基础概念及方法 &#xff12;.&#xff12;示例 &#xff13;图像风格迁移的典型研究成果 &#xff13;.1deep-photo-styletransfer &#xff13;.2CycleGAN &#xff13;.3U-…

【问题记录】Mac M1 Docker配置redis一主二从三哨兵(烧饼好吃)

文章目录Docker配置 redis一主二从三哨兵文件目录redis compose 文件在 redis 文件路径下执行 docker composesentinel 文件结构sentinel compose 配置文件sentinel config 配置文件切换到 sentinel执行 compose测试及问题记录解决方案Docker配置 redis 一主二从三哨兵 文件目…

8家最大的WooCommerce在线商店

想象一下&#xff0c;世界上三分之一的电子商务网站都由单一技术提供支持&#xff0c;而且令人惊讶的是它是免费的。我说的是最大的电子商务解决方案提供商之一&#xff0c;WooCommerce。在这里&#xff0c;我们列出了8 家最大的WooCommerce在线商店&#xff0c;以激发您建立自…

基于jsp+mysql+ssm供应链管理信息系统-计算机毕业设计

项目介绍 本文以销售供应链管理系统的开发为背景&#xff0c;对企业销售管理系统的分析&#xff0c;设计&#xff0c;开发和实施过程进行了详细的描述。本系统基于ssm框架访问作为后台数据库管理连接&#xff0c;通过jdbc与数据库建立连接&#xff0c;以jsp为前端开发工具提供…

数据库之MHA高可用集群部署及故障切换

目录 1 MHA概念 1.1 MHA 的组成 1.2 MHA 的特点 2 搭建MySQLMHA 2.2 修改三台MySQL服务器的主配置文件/etc/my.cnf&#xff0c;并创建命令软链接 2.3 配置MySQL一主两从 2.4 安装 MHA 软件 2.5 在所有服务器上配置无密码认证 2.6 在 manager 节点上配置 MHA 2.7 第一次配…

分类评价指标

不均衡数据 很多时候&#xff0c;不同类别的分类代价并不相等&#xff0c;这就是非均衡分类问题。如果在两个类别中&#xff0c;一个类别的出现次数比另一个多很多&#xff0c;那么错误类型将发挥重要作用。例如。我们一共有100个病人&#xff0c;其中99人是健康的&#xff08…

『.Net』在C#/.Net中将Json压缩成一行的几种方式

&#x1f4e3;读完这篇文章里你能收获到 在.Net Core中使用多种方式将Json压缩成一行主要介绍两种实现方案&#xff0c;Newtonsoft.Json和内置的System.Text.Json 文章目录一、Newtonsoft.Json二、System.Text.Json一、Newtonsoft.Json 将 Formatting 参数设为 Formatting.No…

世界杯杂谈之有趣的数据纪录

目录 &#xff08;一&#xff09;前言 &#xff08;二&#xff09;正文 1. 关于出场 &#xff08;1&#xff09;出场次数 &#xff08;2&#xff09;出场时间最长球员 &#xff08;3&#xff09;连续出场决赛场次最多 &#xff08;4&#xff09;世界杯出场时间最短的人 …

在Mac上优雅的使用ssh和sftp (像win上的xshell和xftp一样)

怎样在Mac上SSH和FTP?完美替代XShell是哪个软件?item2吗?Royal TSX! 没有比它更好_哔哩哔哩_bilibili 下载Royal TSX Royal TSX https://www.royalapps.com/ts/mac/features 安装插件 创建document 在document里面添加ssh和sftp 点击左下角加号,依次选这两个,因为一样,所…