基于SpringBoot+vue的校园招聘系统

简介: 基于SpringBoot+vue的校园招聘系统

一、前言

校园招聘系统是一种具有交互性的人才信息系统,相当于一个线上招聘会,具有时间、空间的便携性。许多学校为了更好的统筹企业与毕业生,都因地适宜地开发了属于自己的校园招聘系统,这也是一个比较流行的网络应用系统。

介绍了一个校园招聘系统的设计和实现过程。该系统将面向对象的设计思想运用到数据库中,采用前端框架vue、后端框架SpringBoot2.7.1 + SpringMVC + Mybatis-Plus3.5.0和MySQL数据库相结合,设计成开发动态网页形式的在线招聘系统。企业和学生的招聘信息均在线上录入,招聘过程中所需的数据也在数据库中进行储存与调用,因此数据的更新是无纸质化的。提督第一次自主研发一个项目,欢迎各位大佬指正,有兴趣的小伙伴也可以交流一下。

关键词:vue、Springboot2.7.1 + SpringMVC + Mybatis-plus 3.5.0、MySQL8.0

二、系统的介绍

2018122814580746.png前台工作主要是完成学生端对工作岗位的浏览,投递和收藏,其中浏览又细分为校内岗位和校外岗位等等。

1、前台

2018122814580746.png

2018122814580746.png

2018122814580746.png

2018122814580746.png

2018122814580746.png2018122814580746.png2018122814580746.png2018122814580746.png2018122814580746.png2018122814580746.png

2、后台

后台主要功能是对招聘信息的发布和管理,以及对职位申请的审批,查看用户的个人主页等

2018122814580746.png2018122814580746.png2018122814580746.png2018122814580746.png2018122814580746.png

3、部分代码展示

import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.jc.campusemploydemo.bean.Result;
import com.jc.campusemploydemo.domain.Positions;
import com.jc.campusemploydemo.mapper.PositionsMapper;
import com.jc.campusemploydemo.service.PositionsService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@Service
public class PositionsServiceImpl implements PositionsService {
    @Autowired
    private PositionsMapper record;
    /**
     * 分页查询校外的职位
     * @param page
     * @param size
     * @return
     */
    @Override
    public Page<Positions> showAllOnSocial(Integer page, Integer size) {
        QueryWrapper<Positions> wrapper = new QueryWrapper<>();
        wrapper.eq("p_flag",1);
        wrapper.orderByAsc("id");
        Page selectPage = record.selectPage(new Page(page, size), wrapper);
        return selectPage;
    }
    /**
     * 分页查询校内的职位
     * @param page
     * @param size
     * @return
     */
    @Override
    public Page<Positions> showAllOnCampus(Integer page, Integer size) {
        QueryWrapper<Positions> wrapper = new QueryWrapper<>();
        wrapper.eq("p_flag",1);
        wrapper.orderByAsc("id");
        Page selectPage = record.selectPage(new Page(page, size), wrapper);
        return selectPage;
    }
    @Override
    public Result addPos(Positions positions) {
        int flag = record.insert(positions);
        if (flag <0){
            return new Result(false,"添加失败");
        }
        return new Result(true,"添加成功");
    }
    @Override
    public boolean delete(Integer id) {
        return record.deleteById(id)>0;
    }
    @Override
    public Result updatePos(Positions positions) {
        int i = record.updateById(positions);
        if (i>0){
            return new Result(true,"更新成功");
        }
        return new Result(false,"更新失败");
    }
    /**
     * 查询全部职业信息
     * @param page
     * @param size
     * @return
     */
    @Override
    public Page<Positions> showAll(Integer page, Integer size) {
        QueryWrapper<Positions> wrapper = new QueryWrapper<>();
        wrapper.orderByAsc("id");
        Page selectPage = record.selectPage(new Page(page,size), wrapper);
        return selectPage;
    }
    /**
     * 根据条件查询
     * @param pClassify
     * @param page
     * @param size
     * @return
     */
    @Override
    public Page<Positions> selectLikeByKeyWord( String pClassify,String p_name,Integer page,Integer size) {
        QueryWrapper<Positions> queryWrapper = new QueryWrapper<>();
        if (p_name!= null){
            queryWrapper.like("p_name",p_name);
        }
        if (pClassify!= null){
            queryWrapper.like("p_classify",pClassify);
        }
        queryWrapper.orderByDesc("id");
        Page page1 = record.selectPage(new Page(page,size),queryWrapper);
        return page1;
    }
    /**
     * 根据id查找职位
     * @param id
     * @return
     */
    @Override
    public Result selectById(Integer id) {
        Positions positions = record.selectById(id);
        if(positions != null){
            return new Result(true,"查找成功",positions);
        }
        return new Result(false,"查找失败");
    }
}

4、上传文件相关代码(后续会搭建linux的文件平台)

上传文件功能原理:其实原理很简单,就是使用springboot的MultipartFile类作为参数,判断文件是否为空,为空则返回失败提示;否则,先获取当前文件的文件名字,再获取存储路径,如果路径不存在,则创建这个路径,然后创建实际存储文件的路径,根据实际路径存储文件,将相对路径存储到数据库里面。

 @PostMapping("/uploadResume")
    @ApiOperation(value="上传附件",notes = "code= 0 : 失败  code= 1: 成功,前端根据接口code值来判断跳转页面")
    public Object uploadResumeFile(@RequestParam("file") MultipartFile upFile) {
        JSONObject jsonObject = new JSONObject();
//        上传失败
        if (upFile.isEmpty()) {
            jsonObject.put(Const.CODE, 0);
            jsonObject.put(Const.MSG, "文件上传失败");
            return jsonObject;
        }
        //        文件名 = 当前时间到毫秒+原来的文件文件名
        String fileName = System.currentTimeMillis() + upFile.getOriginalFilename();
//        文件路径
        String filePath = "D:\\DataStorage\\IdeaData\\campusemploydemo\\campusemploydemo\\src\\main\\resources\\static\\resume\\";
        //        如果文件路径不存在,新增该路径
        File file1 = new File(filePath);
        if (!file1.exists()) {
            file1.mkdir();
        }
        //        实际的文件地址(前端上传之后的地址)
        File dest = new File(filePath + System.getProperty("file.separator") + fileName);
        //        存储到数据库里的相对文件地址
        String storePath = "/img/userPic" + fileName;
        try {
            upFile.transferTo(dest);            // 用来把 MultipartFile 转换换成 File
            User user = (User) session.getAttribute("name");
            Information information = informationService.selectById(user.getUid());
            information.setFiles(storePath);
            Result flag = informationService.updateInfo(information, user.getUid());
            if (flag.isFlag()) {
                jsonObject.put(Const.CODE, 1);
                jsonObject.put(Const.MSG, "上传成功");
                jsonObject.put("pic", storePath);
                return jsonObject;
            }
        } catch (IOException e) {
            jsonObject.put(Const.CODE, 0);
            jsonObject.put(Const.MSG, "上传失败" + ": " + e.getMessage());
            return jsonObject;
        } finally {
            return jsonObject;
        }
    }

相关源码下载链接:https://download.csdn.net/download/m0_58847451/86930153

有感兴趣的小伙伴可以联系哦

相关文章
|
7月前
|
监控 安全 JavaScript
2025基于springboot的校车预定全流程管理系统
针对传统校车管理效率低、信息不透明等问题,本研究设计并实现了一套校车预定全流程管理系统。系统采用Spring Boot、Java、Vue和MySQL等技术,实现校车信息管理、在线预定、实时监控等功能,提升学校管理效率,保障学生出行安全,推动教育信息化发展。
|
7月前
|
JavaScript 安全 Java
基于springboot的大学生兼职系统
本课题针对大学生兼职信息不对称、权益难保障等问题,研究基于Spring Boot、Vue、MySQL等技术的兼职系统,旨在构建安全、高效、功能完善的平台,提升大学生就业竞争力与兼职质量。
|
7月前
|
JavaScript Java 关系型数据库
基于springboot的美食城服务管理系统
本系统基于Spring Boot、Java、Vue和MySQL技术,构建集消费者服务、商家管理与后台监管于一体的美食城综合管理平台,提升运营效率与用户体验。
|
8月前
|
JavaScript
Vue中如何实现兄弟组件之间的通信
在Vue中,兄弟组件可通过父组件中转、事件总线、Vuex/Pinia或provide/inject实现通信。小型项目推荐父组件中转或事件总线,大型项目建议使用Pinia等状态管理工具,确保数据流清晰可控,避免内存泄漏。
718 2
|
7月前
|
缓存 JavaScript
vue中的keep-alive问题(2)
vue中的keep-alive问题(2)
603 137
|
11月前
|
人工智能 JavaScript 算法
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
1151 0
|
11月前
|
JavaScript UED
用组件懒加载优化Vue应用性能
用组件懒加载优化Vue应用性能
|
12月前
|
JavaScript 数据可视化 前端开发
基于 Vue 与 D3 的可拖拽拓扑图技术方案及应用案例解析
本文介绍了基于Vue和D3实现可拖拽拓扑图的技术方案与应用实例。通过Vue构建用户界面和交互逻辑,结合D3强大的数据可视化能力,实现了力导向布局、节点拖拽、交互事件等功能。文章详细讲解了数据模型设计、拖拽功能实现、组件封装及高级扩展(如节点类型定制、连接样式优化等),并提供了性能优化方案以应对大数据量场景。最终,展示了基础网络拓扑、实时更新拓扑等应用实例,为开发者提供了一套完整的实现思路和实践经验。
1651 78
|
10月前
|
人工智能 JSON JavaScript
VTJ.PRO 首发 MasterGo 设计智能识别引擎,秒级生成 Vue 代码
VTJ.PRO发布「AI MasterGo设计稿识别引擎」,成为全球首个支持解析MasterGo原生JSON文件并自动生成Vue组件的AI工具。通过双引擎架构,实现设计到代码全流程自动化,效率提升300%,助力企业降本增效,引领“设计即生产”新时代。
724 1

热门文章

最新文章