• SSM框架基于h5的校园兼职招聘系统的设计与实现源码+论文三稿+ppt+查重报告(包远程安装,已降重)


    项目名称
    SSM框架基于h5的校园兼职招聘系统的设计与实现源码

    视频效果
    SSM框架基于h5的校园兼职招聘系统的设计与实现源码_哔哩哔哩_bilibili

     项目地址
    SSM框架基于h5的校园兼职招聘系统的设计与实现源码_哔哩哔哩_bilibili

    系统说明

    结合需求分析阶段的数据流图及数据字典,得出了系统的功能模块图。该系统通过对用户类型的区分,分为个人用户管理和企业用户管理两大模块。

    图5-3功能模块图

    5.2.2 个人信息管理模块
    信息管理模块是整个系统中最为基础,但也是最为重要的的一环。因为在之后的模块中,所有的操作都围绕着数据、信息进行。个人信息管理模块的功能就是确保个人用户在使用系统时,个人的信息是完整的、准确的。该模块又划分为以下几个子模块:

    注册模块:个人用户在第一次使用该系统时,需要按照相应的约束填写自己的信息,从而进行注册。

    登录模块:判断用户输入的登录信息正确与否,从而决定是否让用户进行后面的操作。除了注册功能外,该系统其他的功能都是建立在成功登录系统的前提下的。所以用户想要进行后续的操作,必须先按照之前注册的信息进行登录。

    信息修改模块:该模块可以让用户对自己的个人信息进行更新、维护。

    5.2.3 简历管理模块
    简历管理模块包括个人用户对自己简历管理的所有操作。具体体现在以下几个方面:

    简历发布:用户在成功发布简历后,自己的信息才能被相关企业所看到。每个用户只能发布一份简历。

    简历撤销:用户如果由于某些原因,暂时不想参加招聘,则可以选择撤销掉自己的简历,个人信息就不会出现在人才库中,不会被别人所看到。用户如果还没有发布过简历,则不可以进行该操作。

    简历下载:该功能可以让个人用户的将自己的简历信息从网页上下载到电脑上,以word格式进行永久保存或打印操作。

    5.2.4 求职申请模块
    求职申请模块是该系统的核心模块。个人用户只有通过使用该模块的一些功能,才能向企业发布求职申请,与企业之间建立联系;企业也才能收到求职者的信息进行后续的操作。个人用户在成功登录系统后,一般会按照下面的步骤进行操作:

    浏览企业信息:在个人用户的主界面上,会显示出所有已被企业发布过的招聘信息的主要内容,如果需要深入了解企业,则可以点击后面附带的按钮查看详细信息。

    检索企业信息:该功能可以让个人用户根据不同的检索条件,对企业进行筛选。比如:职位类别、薪资范围、发布时间。用户可以选择其中的一种进行筛选,也可以选择多种进行联合检索。

    发出求职申请:个人用户在浏览完各种招聘信息后,可以向一个或多个心仪的企业发出求职申请。但对同一家企业,只能申请一次。

    等候通知:用户在每次申请过后,便会生成一条相应的求职记录,它会显示求职者当前申请的状态,让求职者了解到简历是否通过。

    5.2.5 企业信息管理模块
    企业信息管理模块与个人信息管理模块功能类似,它管理的信息与企业相关,与个人无关。例如:公司名称、公司地点、职位需求等等。在该模块中,企业用户也可通过注册、登录、修改的功能,完善企业信息,进行后续操作。

    5.2.6 招聘管理模块
    企业用户通过该模块可以实现以下几个功能:

    发布招聘信息:招聘信息只有发布,才能被求职者所看到,他们才能向相应的企业发送申请。一个企业只能发布一则招聘信息。

    撤销招聘信息:企业如果不再需要招聘,则可以撤销掉招聘信息。其他人都不会浏览到该招聘信息。招聘信息已发布状态,才能被撤销。

    筛选人才信息:企业用户成功登陆系统后,会看到所有被发布的求职信息。企业也可根据需要,对求职者的专业、薪资要求、简历发布时间、毕业学校条件进行检索,显示出满足条件的求职者。

    发送通知:当有求职者向企业发送申请后,这条求职记录会被企业看到,企业可根据求职者的简历决定是否同意他的请求,从而向他发出通知。

    环境需要
    1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。
    2.IDE环境:IDEA,Eclipse,Myeclipse都可以。推荐IDEA;
    3.tomcat环境:Tomcat 7.x,8.x,9.x版本均可
    4.硬件环境:windows 7/8/10 1G内存以上;或者 Mac OS; 
    5.数据库:MySql 5.7版本;
    6.是否Maven项目:否;

    技术栈

    1. 后端:Spring+SpringMVC+Mybatis
    2. 前端:JSP+CSS+JavaScript+jQuery

    使用说明

    1. 使用Navicat或者其它工具,在mysql中创建对应名称的数据库,并导入项目的sql文件;
    2. 使用IDEA/Eclipse/MyEclipse导入项目,Eclipse/MyEclipse导入时,若为maven项目请选择maven;
      若为maven项目,导入成功后请执行maven clean;maven install命令,然后运行;
    3. 将项目中springmvc-servlet.xml配置文件中的数据库配置改为自己的配置;
    4. 运行项目,在浏览器中输入http://localhost:8080/ 登录

    运行截图

     用户管理控制层:


    package com.houserss.controller;

    import javax.servlet.http.HttpSession;

    import org.apache.commons.lang3.StringUtils;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.stereotype.Controller;
    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.bind.annotation.RequestMethod;
    import org.springframework.web.bind.annotation.RequestParam;
    import org.springframework.web.bind.annotation.ResponseBody;

    import com.houserss.common.Const;
    import com.houserss.common.Const.Role;
    import com.houserss.common.ServerResponse;
    import com.houserss.pojo.User;
    import com.houserss.service.IUserService;
    import com.houserss.service.impl.UserServiceImpl;
    import com.houserss.util.MD5Util;
    import com.houserss.util.TimeUtils;
    import com.houserss.vo.DeleteHouseVo;
    import com.houserss.vo.PageInfoVo;

    /**

    • Created by admin
      */

    @Controller
    @RequestMapping("/user/")
    public class UserController {

    @Autowired
    private IUserService iUserService;
    
    /**
     * 用户登录
     * @param username
     * @param password
     * @param session
     * @return
     */
    @RequestMapping(value = "login.do",method = RequestMethod.POST)
    @ResponseBody
    public ServerResponse<User> login(User user,String uvcode, HttpSession session){
        String code = (String)session.getAttribute("validationCode");
        if(StringUtils.isNotBlank(code)) {
            if(!code.equalsIgnoreCase(uvcode)) {
                return ServerResponse.createByErrorMessage("验证码不正确");
            }
        }
        ServerResponse<User> response = iUserService.login(user.getUsername(),user.getPassword());
        if(response.isSuccess()){
            session.setAttribute(Const.CURRENT_USER,response.getData());
        }
        return response;
    }
    
    
    
    

    }

    管理员管理控制层:

    package com.sxl.controller.admin;

    import java.util.List;
    import java.util.Map;

    import javax.servlet.http.HttpServletRequest;

    import org.springframework.http.ResponseEntity;
    import org.springframework.stereotype.Controller;
    import org.springframework.ui.Model;
    import org.springframework.web.bind.annotation.RequestMapping;

    import com.sxl.controller.MyController;

    @Controller("adminController")
    @RequestMapping(value = "/admin")
    public class AdminController extends MyController {

    @RequestMapping(value = "/index")
    public String frame(Model model, HttpServletRequest request)throws Exception {
        return "/admin/index";
    }
    
    @RequestMapping(value = "/main")
    public String main(Model model, HttpServletRequest request)throws Exception {
        return "/admin/main";
    }
    
    @RequestMapping(value = "/tj1")
    public String tj1(Model model, HttpServletRequest request)throws Exception {
        String sql="select DATE_FORMAT(insertDate,'%Y-%m-%d') dates,sum(allPrice) price from t_order order by DATE_FORMAT(insertDate,'%Y-%m-%d')  desc";
        List<Map> list = db.queryForList(sql);
        model.addAttribute("list", list);
        System.out.println(list);
        return "/admin/tj/tj1";
    }
    
    
    @RequestMapping(value = "/password")
    public String password(Model model, HttpServletRequest request)throws Exception {
        return "/admin/password";
    }
    
    
    @RequestMapping(value = "/changePassword")
    public ResponseEntity<String> loginSave(Model model,HttpServletRequest request,String oldPassword,String newPassword) throws Exception {
        Map admin = getAdmin(request);
        if(oldPassword.equals(admin.get("password").toString())){
            String sql="update t_admin set password=? where id=?";
            db.update(sql, new Object[]{newPassword,admin.get("id")});
            return renderData(true,"1",null);
        }else{
            return renderData(false,"1",null);
        }
    }

    }

    修改密码业务逻辑:

    package com.sxl.controller.admin;

    import java.util.Map;

    import javax.servlet.http.HttpServletRequest;

    import org.springframework.http.ResponseEntity;
    import org.springframework.stereotype.Controller;
    import org.springframework.ui.Model;
    import org.springframework.web.bind.annotation.RequestMapping;

    import com.sxl.controller.MyController;

    @Controller("userController")
    @RequestMapping(value = "/user")
    public class UserController extends MyController {

    @RequestMapping(value = "/index")
    public String frame(Model model, HttpServletRequest request)throws Exception {
        return "/user/index";
    }
    
    @RequestMapping(value = "/main")
    public String main(Model model, HttpServletRequest request)throws Exception {
        return "/user/main";
    }
    
    
    @RequestMapping(value = "/password")
    public String password(Model model, HttpServletRequest request)throws Exception {
        return "/user/password";
    }
    
    
    @RequestMapping(value = "/changePassword")
    public ResponseEntity<String> loginSave(Model model,HttpServletRequest request,String oldPassword,String newPassword) throws Exception {
        Map user = getUser(request);
        if(oldPassword.equals(user.get("password").toString())){
            String sql="update t_user set password=? where id=?";
            db.update(sql, new Object[]{newPassword,user.get("id")});
            return renderData(true,"1",null);
        }else{
            return renderData(false,"1",null);
        }
    }
    @RequestMapping(value = "/mine")
    public String mine(Model model, HttpServletRequest request)throws Exception {

    Map user =getUser(request);Map map = db.queryForMap("select * from t_user where id=?",new Object[]{user.get("id")});model.addAttribute("map", map); return "/user/mine";

    }
    
    
    
    @RequestMapping(value = "/mineSave")
    public ResponseEntity<String> mineSave(Model model,HttpServletRequest request,Long id
        ,String username,String password,String name,String gh,String mobile) throws Exception{
        int result = 0;
            String sql="update t_user set name=?,gh=?,mobile=? where id=?";
            result = db.update(sql, new Object[]{name,gh,mobile,id});
        if(result==1){
            return renderData(true,"操作成功",null);
        }else{
            return renderData(false,"操作失败",null);
        }
    }
    }
    

    通用管理模块:
    package com.sxl.controller;

    import java.nio.charset.Charset;
    import java.util.Locale;
    import java.util.ResourceBundle;

    import javax.servlet.http.HttpServletRequest;

    import org.apache.commons.lang.StringUtils;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.http.HttpHeaders;
    import org.springframework.http.HttpStatus;
    import org.springframework.http.MediaType;
    import org.springframework.http.ResponseEntity;

    import com.sxl.util.JacksonJsonUtil;
    import com.sxl.util.StringUtil;
    import com.sxl.util.SystemProperties;

    public class BaseController {

    public static final Long EXPIRES_IN = 1000 * 3600 * 24 * 1L;// 1天
    
    @Autowired
    private SystemProperties systemProperties;
    
    /**
     * 获得配置文件内容
     */
    public String getConfig(String key) {
        return systemProperties.getProperties(key);
    }
    
    /**
     * 返回服务器地址 like http://192.168.1.1:8441/UUBean/
     */
    public String getHostUrl(HttpServletRequest request) {
        String hostName = request.getServerName();
        Integer hostPort = request.getServerPort();
        String path = request.getContextPath();
    
        if (hostPort == 80) {
            return "http://" + hostName + path + "/";
        } else {
            return "http://" + hostName + ":" + hostPort + path + "/";
        }
    }
    
    /***
     * 获取当前的website路径 String
     */
    public static String getWebSite(HttpServletRequest request) {
        String returnUrl = request.getScheme() + "://"
                + request.getServerName();
    
        if (request.getServerPort() != 80) {
            returnUrl += ":" + request.getServerPort();
        }
    
        returnUrl += request.getContextPath();
    
        return returnUrl;
    }
    
    
    
    /**
     * 初始化HTTP头.
     * 
     * @return HttpHeaders
     */
    public HttpHeaders initHttpHeaders() {
        HttpHeaders headers = new HttpHeaders();
        MediaType mediaType = new MediaType("text", "html",
                Charset.forName("utf-8"));
        headers.setContentType(mediaType);
        return headers;
    }
    
    /**
     * 返回 信息数据
     * 
     * @param status
     * @param msg
     * @return
     */
    public ResponseEntity<String> renderMsg(Boolean status, String msg) {
        if (StringUtils.isEmpty(msg)) {
            msg = "";
        }
        String str = "{\"status\":\"" + status + "\",\"msg\":\"" + msg + "\"}";
        ResponseEntity<String> responseEntity = new ResponseEntity<String>(str,
                initHttpHeaders(), HttpStatus.OK);
        return responseEntity;
    }
    
    /**
     * 返回obj数据
     * 
     * @param status
     * @param msg
     * @param obj
     * @return
     */
    public ResponseEntity<String> renderData(Boolean status, String msg,
            Object obj) {
        if (StringUtils.isEmpty(msg)) {
            msg = "";
        }
        StringBuffer sb = new StringBuffer();
        sb.append("{");
        sb.append("\"status\":\"" + status + "\",\"msg\":\"" + msg + "\",");
        sb.append("\"data\":" + JacksonJsonUtil.toJson(obj) + "");
        sb.append("}");
    
        ResponseEntity<String> responseEntity = new ResponseEntity<String>(
                sb.toString(), initHttpHeaders(), HttpStatus.OK);
        return responseEntity;
    }
    
    
    /***
     * 获取IP(如果是多级代理,则得到的是一串IP值)
     */
    public static String getIpAddr(HttpServletRequest request) {
        String ip = request.getHeader("x-forwarded-for");
        if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
            ip = request.getHeader("Proxy-Client-IP");
        }
    
        if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
            ip = request.getHeader("WL-Proxy-Client-IP");
        }
    
        if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
            ip = request.getRemoteAddr();
        }
    
        if (ip != null && ip.length() > 0) {
            String[] ips = ip.split(",");
            for (int i = 0; i < ips.length; i++) {
                if (!"unknown".equalsIgnoreCase(ips[i])) {
                    ip = ips[i];
                    break;
                }
            }
        }
    
        return ip;
    }
    
    /**
     * 国际化获得语言内容
     * 
     * @param key
     *            语言key
     * @param args
     * @param argsSplit
     * @param defaultMessage
     * @param locale
     * @return
     */
    public static String getLanguage(String key, String args, String argsSplit,
            String defaultMessage, String locale) {
        String language = "zh";
        String contry = "cn";
        String returnValue = defaultMessage;
    
        if (!StringUtil.isEmpty(locale)) {
            try {
                String[] localeArray = locale.split("_");
                language = localeArray[0];
                contry = localeArray[1];
            } catch (Exception e) {
            }
        }
    
        try {
            ResourceBundle resource = ResourceBundle.getBundle("lang.resource",
                    new Locale(language, contry));
            returnValue = resource.getString(key);
            if (!StringUtil.isEmpty(args)) {
                String[] argsArray = args.split(argsSplit);
                for (int i = 0; i < argsArray.length; i++) {
                    returnValue = returnValue.replace("{" + i + "}",
                            argsArray[i]);
                }
            }
        } catch (Exception e) {
        }
    
        return returnValue;
    }

    }


    如果本文对你有帮助,别忘记给我个3连 ,点赞,转发,评论,

    咱们下期见!答案获取方式:已赞 已评 已关~

    学习更多JAVA知识与技巧,关注与私信博主(03)

     

  • 相关阅读:
    StackExchange.Redis跑起来,为什么这么溜?
    剑指 Offer (更新中)
    软考高级架构师下篇-17安全架构设计理论与实践
    华清远见上海中心22071班
    Mysql之用户管理
    django rest framework快速使用
    vue基础(1)
    【教3妹学算法】按照频率将数组升序排序
    rv1126-rv1109-镜像生成位置
    [附源码]计算机毕业设计面向高校活动聚AppSpringboot程序
  • 原文地址:https://blog.csdn.net/weixin_70730532/article/details/125427426