ssm基于ssm的人才招聘网站源码和论文020
开发工具:idea
数据库mysql5.7+
数据库链接工具:navcat,小海豚等
技术:ssm
选题依据(研究的背景、目的和意义等)
在Internet飞速发展的今天,互联网成为人们快速获取、发布和传递信息的重要渠道,它在人们政治、经济、生活等各个方面发挥着重要的作用。Internet上发布信息主要是通过网站来实现的,获取信息也是要在Internet“海洋”中按照一定的检索方式将所需要的信息从网站上下载下来。因此网站建设在Internet应用上的地位显而易见,它已成为信息社会的重要组成部分,从而倍受人们的重视。为了方便求职者进行求职以及方便企业进行发布职位信息,特构建人才招聘网站。
人才招聘网站为求职者提供了方便、快捷的应聘途径。对招聘单位来说,人才招聘网站也为他们提供了查询、检索求职者信息库的条件,使招聘工作中的人员初选工作变得轻松易行,此系统的开发就是实现招聘时企业和人才的交互选择。网上求职招聘是一新兴行业,随着互联网的发展,越来越多的人愿意通过网络活动,尤其是在疫情期间,足不出户的人们通过网络交友、通过网络进行商品交易,通过网络从事一些社会活动……人们已经离不开互联网,互联网信息传递快、覆盖面广,所以众多求职者和各大招聘行业也抓住了这个机会,通过互联网发布招聘信息既方便又快捷,求职者也能在众多选项中找到适合自己的职位。线上求职招聘方式已经成为了求职招聘的一大重要手段,其规模和成功率已经与传统招聘会不相上下,有的甚至超过了传统招聘会。通过它,求职者和招聘者可以突破时间和空间的限制而实现求职和招聘过程。线上求职招聘的崛起对传统人才招聘体系产生了强烈的冲击,网络招聘范围广,信息量大,可挑选余地大,招聘效果好,费用低,获得了越来越多的公司的认可,同时它信息反应适时、用户检索方便、地域限制少等特点。因此进行这方面的研究有着重要的现实意义。
研究方案(主要研究内容、目标、研究方法等)
1、研究内容
本基于SSM的人才招聘网站主要满足3种类型用户的需求,这3种类型用户分别为求职者、企业和管理员,他们分别实现的功能如下。
(1)求职者进入网站后可查看职位信息、企业信息以及职位新闻等,注册登录后可实现申请职位、收藏职位、管理职位收藏夹、查看职位申请记录、管理个人简历等。
(2)管理员可登录系统后对系统进行全面管理,管理员登陆后主要功能模块包括用户管理(求职者管理)和企业管理。
(3)企业注册登录后主要功能模块包括企业信箱以及发布管理职位。
2、研究目标
(1)完成以Java编写的人才招聘网站的设计与实现,并实现本系统的主要功能,且程序能够正常运行。
(2)系统界面设计简单清晰、操作简单、容易上手。
(3)数据库的数据要求准确、合理且结构清晰,表与表之间有合理的外键。
(4)软件健壮性强,界面设计友好、美观大方,操作方便、无重大错误。
(5)设计文档结构合理,条理清晰,图文并茂。
3、研究方法
(1)文献法:查阅相关论文、学刊等资料,收集各方面文献。结合研究的课题进行具体分析;
(2)访谈法:与指导老师同学交流,获得更多信息与相关的知识。
(3)理论学习与实践相结合的方法:通过对所使用开发软件的学习与理解,分析和比较各种框架和设计模式的优点与不足,最终确定自己的见解。
(4)归纳总结法:通过人才招聘网站设计的前期研究和调查,将现有理论知识进行探究,尤其针对功能性需求分析,借鉴前人理论知识作为本研究基础,通过找出研究中缺失的部分,加入自己的创新点,并对其进行归纳和总结。
1、主要内容
本基于SSM的人才招聘网站采用Java语言和MySQL数据库进行开发设计,系统主要满足3种类型用户的需求,这3种类型用户分别为求职者、企业和管理员,他们分别实现的功能如下。
(1)求职者进入网站后可查看职位信息、企业信息以及职位新闻等,注册登录后可实现申请职位、收藏职位、管理职位收藏夹、查看职位申请记录、管理个人简历等。
(2)管理员可登录系统后对系统进行全面管理,管理员登陆后主要功能模块包括用户管理(求职者管理)和企业管理。
(3)企业注册登录后主要功能模块包括企业信箱以及发布管理职位。
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.YingpinyaoqingEntity;
import com.entity.view.YingpinyaoqingView;
import com.service.YingpinyaoqingService;
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 2021-02-06 18:51:25
*/
@RestController
@RequestMapping("/yingpinyaoqing")
public class YingpinyaoqingController {
@Autowired
private YingpinyaoqingService yingpinyaoqingService;
/**
* 后端列表
*/
@RequestMapping("/page")
public R page(@RequestParam Map<String, Object> params,YingpinyaoqingEntity yingpinyaoqing, HttpServletRequest request){
String tableName = request.getSession().getAttribute("tableName").toString();
if(tableName.equals("yonghu")) {
yingpinyaoqing.setYonghuming((String)request.getSession().getAttribute("username"));
}
if(tableName.equals("qiye")) {
yingpinyaoqing.setQiyezhanghao((String)request.getSession().getAttribute("username"));
}
EntityWrapper<YingpinyaoqingEntity> ew = new EntityWrapper<YingpinyaoqingEntity>();
PageUtils page = yingpinyaoqingService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, yingpinyaoqing), params), params));
request.setAttribute("data", page);
return R.ok().put("data", page);
}
/**
* 前端列表
*/
@RequestMapping("/list")
public R list(@RequestParam Map<String, Object> params,YingpinyaoqingEntity yingpinyaoqing, HttpServletRequest request){
EntityWrapper<YingpinyaoqingEntity> ew = new EntityWrapper<YingpinyaoqingEntity>();
PageUtils page = yingpinyaoqingService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, yingpinyaoqing), params), params));
request.setAttribute("data", page);
return R.ok().put("data", page);
}
/**
* 列表
*/
@RequestMapping("/lists")
public R list( YingpinyaoqingEntity yingpinyaoqing){
EntityWrapper<YingpinyaoqingEntity> ew = new EntityWrapper<YingpinyaoqingEntity>();
ew.allEq(MPUtil.allEQMapPre( yingpinyaoqing, "yingpinyaoqing"));
return R.ok().put("data", yingpinyaoqingService.selectListView(ew));
}
/**
* 查询
*/
@RequestMapping("/query")
public R query(YingpinyaoqingEntity yingpinyaoqing){
EntityWrapper< YingpinyaoqingEntity> ew = new EntityWrapper< YingpinyaoqingEntity>();
ew.allEq(MPUtil.allEQMapPre( yingpinyaoqing, "yingpinyaoqing"));
YingpinyaoqingView yingpinyaoqingView = yingpinyaoqingService.selectView(ew);
return R.ok("查询应聘邀请成功").put("data", yingpinyaoqingView);
}
/**
* 后端详情
*/
@RequestMapping("/info/{id}")
public R info(@PathVariable("id") Long id){
YingpinyaoqingEntity yingpinyaoqing = yingpinyaoqingService.selectById(id);
return R.ok().put("data", yingpinyaoqing);
}
/**
* 前端详情
*/
@RequestMapping("/detail/{id}")
public R detail(@PathVariable("id") Long id){
YingpinyaoqingEntity yingpinyaoqing = yingpinyaoqingService.selectById(id);
return R.ok().put("data", yingpinyaoqing);
}
/**
* 后端保存
*/
@RequestMapping("/save")
public R save(@RequestBody YingpinyaoqingEntity yingpinyaoqing, HttpServletRequest request){
yingpinyaoqing.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
//ValidatorUtils.validateEntity(yingpinyaoqing);
yingpinyaoqingService.insert(yingpinyaoqing);
return R.ok();
}
/**
* 前端保存
*/
@RequestMapping("/add")
public R add(@RequestBody YingpinyaoqingEntity yingpinyaoqing, HttpServletRequest request){
yingpinyaoqing.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
//ValidatorUtils.validateEntity(yingpinyaoqing);
yingpinyaoqingService.insert(yingpinyaoqing);
return R.ok();
}
/**
* 修改
*/
@RequestMapping("/update")
public R update(@RequestBody YingpinyaoqingEntity yingpinyaoqing, HttpServletRequest request){
//ValidatorUtils.validateEntity(yingpinyaoqing);
yingpinyaoqingService.updateById(yingpinyaoqing);//全部更新
return R.ok();
}
/**
* 删除
*/
@RequestMapping("/delete")
public R delete(@RequestBody Long[] ids){
yingpinyaoqingService.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<YingpinyaoqingEntity> wrapper = new EntityWrapper<YingpinyaoqingEntity>();
if(map.get("remindstart")!=null) {
wrapper.ge(columnName, map.get("remindstart"));
}
if(map.get("remindend")!=null) {
wrapper.le(columnName, map.get("remindend"));
}
String tableName = request.getSession().getAttribute("tableName").toString();
if(tableName.equals("yonghu")) {
wrapper.eq("yonghuming", (String)request.getSession().getAttribute("username"));
}
if(tableName.equals("qiye")) {
wrapper.eq("qiyezhanghao", (String)request.getSession().getAttribute("username"));
}
int count = yingpinyaoqingService.selectCount(wrapper);
return R.ok().put("count", count);
}
}