2 猎头服务管理系统分析
2.1 可行性分析
2.1.1 技术可行性分析
通过了解对猎头服务管理系统的真实需求后,将猎头服务管理系统所需要的角色划分整理成了下图2-1,图2-2和图2-3。
从开发工具来看,由于猎头服务管理系统是基于JAVA的,因此有很多开发工具都可以进行开发,这些功能强大的开发工具可以给我来设计猎头服务管理系统带来非常大的方便。
从猎头服务管理系统的本身技术来说,对于我来开发一个猎头服务管理系统这个毕设是不费事的。猎头服务管理系统的开发可以简单的分为前台端、后台端开发以及数据库开发。其中的大部分技术难点在我上学时已经使用过了,同时网络上很多技术点可以让我来借鉴。Web后台管理使用JAVA[9]的springboot架构开发,数据库使用mysql,页面上使用javascript[10]脚本,因此为我在开发猎头服务管理系统这个毕设上省去了很多多余代码,这给我的毕设项目编写带来了极大的便利。综上所述,从技术层面来看开发猎头服务管理系统是可行的。
从用户体验来看,市面上很多被广泛使用的系统案例可以让我来参考,因此我可以综合它们的页面交互设计的优点,基于我的毕设项目特点来进行改版,最后达到令用户满意的页面交互体验。综上所述,从技术层面来看开发猎头服务管理系统是可行的。
2.1.2 经济可行性分析
从猎头服务管理系统的开发成本来看,猎头服务管理系统的设计和开发都是我自己完成的,没有其他成本上的开销。
从猎头服务管理系统的维护成本来看,猎头服务管理系统的开发遵循一套完整的代码编写规范,并且猎头服务管理系统的结构设计非常灵活,遵循高内聚低耦合的原则,因此易于维护和迭代开发。
在猎头服务管理系统上线之后,上线前期我会根据真实需求来调查,对使用我开发的猎头服务管理系统来制定一套符合的使用费。系统运行稳定后我会将推广范围到其他的校园当中,其他校园可以使用我的猎头服务管理系统,只需要缴纳一点点的定金,我会给他们引入广告投资和自营业务。
综合以上的分析,猎头服务管理系统所带来的经济效益将会带来极大的收益。并且随着我的推广,来使用我开发的猎头服务管理系统的市场将越来越大,猎头服务管理系统带来的利润也就越来越多。因此,从经济层面来看开发猎头服务管理系统的是可行的。
2.2 系统需求分析
2.2.1 功能性需求分析
猎头服务管理系统从角色上划分为了注册用户、招聘企业、管理员三种角色。
管理员用户角色:
(1)登录:管理员的账号是在数据表表中直接设置生成的,不需要进行注册;
(2)公告管理:当点击“公告管理”这一菜单的时候,会出公告栏一个子菜单,可以对这一个模块进行增删改查操作;
(3)系统用户管理:当点击“系统用户管理”这一菜单的时候,会出现管理员+注册用户+招聘企业人三个子菜单,可以对这三个模块进行增删改查操作;
(4)资源管理:当点击“资源管理”这一菜单的时候,会出现招聘资讯+资讯分类这两个子菜单,可以对招聘资讯进行增删改查操作;
(5)模块管理:当点击“模块”这一菜单的时候,会出现职位分类+地区管理+招聘职位+简历投递+面试邀约+求职咨询这六个子菜单,能够对招聘职位与职位分类进行增删改查操作,对简历投递与面试邀约进行管理,以及实现对地区管理与求职咨询进行管理等;
注册用户角色:
(1)注册登录模块:当用户想要进入本猎头服务管理系统中对资讯进行查看评论以及了解招聘信息等操作的时候,就必须要登录到系统当中,要是新的用户没有猎头服务管理系统的账号的话,点击“注册”按钮,就会进入到新用户注册这个界面上,用户输入对应的账号(必须填写)+密码(必须填写)+确认密码(必须填写,而且要与密码一直)+昵称+邮箱+手机号+选择用户身份等等,然后点击“注册”,系统在用户这一数据库中会查询账号是不是存在,两次密码是不是一样,都填写正确就会注册成功,然后再进行登录,如果是之前已经注册过的用户很长时间没有使用,忘记密码,也可以点击“忘记密码”进行找回;
(2)招聘资讯:在首页导航栏上我们会看到“招聘资讯”这一菜单,我们点击进入进去以后,会看到所有资讯列表,在这个界面,我们可以点击进入进行查看、评论、点赞等;
(3)公告消息:在首页导航栏上我们会看到“公告消息”这一菜单,我们点击进入进去以后,会看到所有管理员在后台发布的公告信息;
(4)我的收藏:在“我的”下可以查看管理“我的收藏”信息,可以查看收藏,也可以对不喜欢的信息进行删除收藏;
(5)我的账户:当用户点击右上角“我的”这个按钮,会出现子菜单,点击“我的账户”可以对个人的资料以及登录系统的密码进行设置;
(6)个人中心:当用户点击右上角“我的”这个按钮,就会进入到对应的后台进行信息的管理了;
(7)招聘职位:在首页导航栏上点击“招聘职位”弹跳出的是招聘职位列表,可以点击随意一款职位进行了解其具体信息。包括企业名称、职位名称、地区、招聘人数等;
招聘企业角色:
(1)招聘职位管理;招聘企业对招聘职位信息进行添加、删除、查询管理等;
(2)简历投递管理:企业对简历投递信息进行删除、查询管理等;
(3)面试邀约管理:企业对面试邀约信息进行添加、删除、查询管理等;
(4)求职咨询管理:企业对求职咨询信息进行删除、查询管理等;
2.2.2 非功能性分析
猎头服务管理系统的非功能性需求比如猎头服务管理系统的安全性怎么样,可靠性怎么样,性能怎么样,可拓展性怎么样等。具体可以表示在如下2-1表格中:
表2-1猎头服务管理系统非功能需求表
安全性
主要指猎头服务管理系统数据库的安装,数据库的使用和密码的设定必须合乎规范。
可靠性
可靠性是指猎头服务管理系统能够安装用户的指示进行操作,经过测试,可靠性90%以上。
性能
性能是影响猎头服务管理系统占据市场的必要条件,所以性能最好要佳才好。
可扩展性
比如数据库预留多个属性,比如接口的使用等确保了系统的非功能性需求。
易用性
用户只要跟着猎头服务管理系统的页面展示内容进行操作,就可以了。
可维护性
猎头服务管理系统开发的可维护性是非常重要的,经过测试,可维护性没有问题
2.3 系统用例分析
根据上一节功能分析,可以得出系统的用例,注册用户角色用例如图2.1所示。
图2.1 猎头服务管理系统中注册用户角色用例图
管理员角色用例如图2.2所示。
图2.2 猎头服务管理系统管理员角色用例图
企业角色用例如图2.3所示。
图2.3 猎头服务管理系统中企业角色用例图
3 猎头服务管理系统总体设计
3.1 系统模块设计
根据第二章中猎头服务管理系统的功能分析可知,猎头服务管理系统中整体功能模块图如图3.1所示,
图3.1 猎头服务管理系统功能模块图
3.2 数据库设计
3.3.1 数据库概念结构设计
下面是整个猎头服务管理系统中主要的数据库表总E-R实体关系图。
图3.2 猎头服务管理系统总E-R关系图
3.2.2 数据库逻辑结构设计
通过上一小节中猎头服务管理系统中总E-R关系图上得出一共需要创建很多个数据表。在此我主要罗列几个主要的数据库表结构设计。
resume_delivery表:
名称
类型
长度
不是null
主键
注释
resume_delivery_id
int
11
是
是
简历投递ID
enterprise_no
int
11
否
否
企业编号
enterprise_name
varchar
64
否
否
企业名称
position_name
varchar
64
否
否
职位名称
position_category
varchar
64
否
否
职位类别
user_no
int
11
否
否
用户编号
full_name
varchar
64
否
否
姓名
gender
varchar
64
否
否
性别
education
varchar
64
否
否
学历
university_one_is_graduated_from
varchar
64
否
否
毕业院校
resume
varchar
255
否
否
简历
self_introduction
text
0
否
否
自我介绍
黑马java297期基础加就业recommend
int
11
是
否
智能推荐
create_time
datetime
0
是
否
创建时间
update_time
timestamp
0
是
否
更新时间
registered_user表:
名称
类型
长度
不是null
主键
注释
registered_user_id
int
11
是
是
注册用户ID
full_name
varchar
64
否
否
姓名
gender
varchar
64
否
否
性别
education
varchar
64
否
否
学历
university_one_is_graduated_from
varchar
64
否
否
毕业院校
examine_state
varchar
16
是
否
审核状态
recommend
int
11
是
否
智能推荐
user_id
int
11
是
否
用户ID
create_time
datetime
0
是
否
创建时间
update_time
timestamp
0
是
否
更新时间
recruitment_position表:
名称
类型
长度
不是null
主键
注释
recruitment_position_id
int
11
是
是
招聘职位ID
enterprise_no
int
11
否
否
企业编号
enterprise_name
varchar
64
否
否
企业名称
position_name
varchar
64
否
否
职位名称
position_category
varchar
64
否
否
职位类别
region
varchar
64
否
否
地区
number_of_recruiters
int
11
否
否
招聘人数
work_address
varchar
64
否
否
工作地址
job_content
text
0
否
否
工作内容
educational_requirements
text
0
否
否
学历要求
salary
text
0
否
否
薪资待遇
publicity_map
varchar
255
否
否
宣传图
details
longtext
0
否
否
详情
hits
int
11
是
否
点击数
praise_len
int
11
是
否
点赞数
recommend
int
11
是
否
智能推荐
create_time
datetime
0
是
否
创建时间
update_time
timestamp
0
是
否
更新时间
job_search_consultation表:
名称
类型
长度
不是null
主键
注释
job_search_consultation_id
int
11
是
是
求职咨询ID
enterprise_no
int
11
否
否
企业编号
enterprise_name
varchar
64
否
否
企业名称
position_name
varchar
64
否
否
职位名称
user
int
11
否
否
用户
advisory_questions
text
0
否
否
咨询问题
enterprise_reply
text
0
否
否
企业回复
recommend
int
11
是
否
智能推荐
create_time
datetime
0
是
否
创建时间
update_time
timestamp
0
是
否
更新时间
invitation_for_interview表:
名称
类型
长度
不是null
主键
注释
invitation_for_interview_id
int
11
是
是
面试邀请ID
enterprise_no
int
11
否
否
企业编号
enterprise_name
varchar
64
否
否
企业名称
user_no
int
11
否
否
用户编号
full_name
varchar
64
否
否
姓名
position_name
varchar
64
否
否
职位名称
interview_time
datetime
0
否
否
面试时间
place_of_interview
varchar
64
否
否
面试地点
carrying_information
text
0
否
否
携带资料
examine_state
varchar
16
是
否
审核状态
examine_reply
varchar
16
否
否
审核回复
recommend
int
11
是
否
智能推荐
create_time
datetime
0
是
否
创建时间
update_time
timestamp
0
是
否
更新时间
recruitment_enterprise表:
名称
类型
长度
不是null
主键
注释
recruitment_enterprise_id
int
11
是
是
招聘企业ID
enterprise_no
varchar
64
是
否
企业编号
enterprise_name
varchar
64
否
否
企业名称
person_in_charge
varchar
64
否
否
负责人
business_license
varchar
255
否
否
营业执照
examine_state
varchar
16
是
否
审核状态
recommend
int
11
是
否
智能推荐
user_id
int
11
是
否
用户ID
create_time
datetime
0
是
否
创建时间
update_time
timestamp
0
是
否
更新时间
4 猎头服务管理系统设计与实现
猎头服务管理系统的详细设计与实现主要是根据前面的猎头服务管理系统的需求分析和猎头服务管理系统的总体设计来设计页面并实现业务逻辑。主要从猎头服务管理系统界面实现、业务逻辑实现这两部分进行介绍。
4.1 系统首页页面
当进入猎头服务管理系统的时候,首先映入眼帘的是系统的导航栏,下面是轮播图以及系统内容,其主界面展示如下图4.1所示。
图4.1 用户界面图
4.2 注册页面
不是猎头服务管理系统中正式用户的是可以在线进行注册的,如果你没有本猎头服务管理系统的账号的话,添加“注册”,当填写上自己的账号+密码+确认密码+昵称+邮箱+手机号等后再点击“注册”按钮后将会先验证输入的有没有空数据,再次验证密码和确认密码是否是一样的,最后验证输入的账户名和数据库表中已经注册的账户名是否重复,只有都验证没问题后即可用户注册成功。注册界面实现了用户用户的注册,其注册界面展示如下图4。2所示。
图4.2 注册界面图
用户注册逻辑代码如下:
/
* 注册
* @param user
* @return
*/
@PostMapping("register")
public Map<String, Object> signUp(@RequestBody User user) {
// 查询用户
Map<String, String> query = new HashMap<>();
query.put("username",user.getUsername());
List list = service.select(query, new HashMap<>()).getResultList();
if (list.size()>0){
return error(30000, "用户已存在");
}
user.setUserId(null);
user.setPassword(service.encryption(user.getPassword()));
service.save(user);
return success(1);
}
/
* 用户ID:[0,]用户获取其他与用户相关的数据
*/
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "user_id")
private Integer userId;
/
* 账户状态:[0,10](1可用|2异常|3已冻结|4已注销)
*/
@Basic
@Column(name = "state")
private Integer state;
/
* 所在用户组:[0,32767]决定用户身份和权限
*/
@Basic
@Column(name = "user_group")
private String userGroup;
/
* 上次登录时间:
*/
@Basic
@Column(name = "login_time")
private Timestamp loginTime;
/
* 手机号码:[0,11]用户的手机号码,用于找回密码时或登录时
*/
@Basic
@Column(name = "phone")
private String phone;
/
* 手机认证:[0,1](0未认证|1审核中|2已认证)
*/
@Basic
@Column(name = "phone_state")
private Integer phoneState;
/
* 用户名:[0,16]用户登录时所用的账户名称
*/
@Basic
@Column(name = "username")
private String username;
/
* 昵称:[0,16]
*/
@Basic
@Column(name = "nickname")
private String nickname;
/
* 密码:[0,32]用户登录所需的密码,由6-16位数字或英文组成
*/
@Basic
@Column(name = "password")
private String password;
/
* 邮箱:[0,64]用户的邮箱,用于找回密码时或登录时
*/
@Basic
@Column(name = "email")
private String email;
/
* 邮箱认证:[0,1](0未认证|1审核中|2已认证)
*/
@Basic
@Column(name = "email_state")
private Integer emailState;
/
* 头像地址:[0,255]
*/
@Basic
@Column(name = "avatar")
private String avatar;
/
* 创建时间:
*/
@Basic
@Column(name = "create_time")
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private Timestamp createTime;
@Basic
@Transient
private String code;
}
4.3 登录页面
猎头服务管理系统中的前台上注册后的用户是可以通过自己的账户名和密码进行登录的,当用户输入完整的自己的账户名和密码信息并点击“登录”按钮后,将会首先验证输入的有没有空数据,再次验证输入的账户名+密码和数据库中当前保存的用户信息是否一致,只有在一致后将会登录成功并自动跳转到猎头服务管理系统的首页中;否则将会提示相应错误信息,用户登录界面如下图4.3所示。
图4.3 登录界面图
用户登录的逻辑代码如下所示。
/
* 登录
* @param data
* @param httpServletRequest
* @return
*/
@PostMapping("login")
public Map<String, Object> login(@RequestBody Map<String, String> data, HttpServletRequest httpServletRequest) {
log.info("[执行登录接口]");
String username = data.get("username");
String email = data.get("email");
String phone = data.get("phone");
String password = data.get("password");
List resultList = null;
Map<String, String> map = new HashMap<>();
if(username != null && "".equals(username) == false){
map.put("username", username);
resultList = service.select(map, new HashMap<>()).getResultList();
}
else if(email != null && "".equals(email) == false){
map.put("email", email);
resultList = service.select(map, new HashMap<>()).getResultList();
}
else if(phone != null && "".equals(phone) == false){
map.put("phone", phone);
resultList = service.select(map, new HashMap<>()).getResultList();
}else{
return error(30000, "账号或密码不能为空");
}
if (resultList == null || password == null) {
return error(30000, "账号或密码不能为空");
}
//判断是否有这个用户
if (resultList.size()<=0){
return error(30000,"用户不存在");
}
User byUsername = (User) resultList.get(0);
Map<String, String> groupMap = new HashMap<>();
groupMap.put("name",byUsername.getUserGroup());
List groupList = userGroupService.select(groupMap, new HashMap<>()).getResultList();
if (groupList.size()<1){
return error(30000,"用户组不存在");
}
UserGroup userGroup = (UserGroup) groupList.get(0);
//查询用户审核状态
if (!StringUtils.isEmpty(userGroup.getSourceTable())){
String sql = "select examine_state from "+ userGroup.getSourceTable() +" WHERE user_id = " + byUsername.getUserId();
String res = String.valueOf(service.runCountSql(sql).getSingleResult());
if (res==null){
return error(30000,"用户不存在");
}
if (!res.equals("已通过")){
return error(30000,"该用户审核未通过");
}
}
//查询用户状态
if (byUsername.getState()!=1){
return error(30000,"用户非可用状态,不能登录");
}
String md5password = service.encryption(password);
if (byUsername.getPassword().equals(md5password)) {
// 存储Token到数据库
AccessToken accessToken = new AccessToken();
accessToken.setToken(UUID.randomUUID().toString().replaceAll("-", ""));
accessToken.setUser_id(byUsername.getUserId());
tokenService.save(accessToken);
// 返回用户信息
JSONObject user = JSONObject.parseObject(JSONObject.toJSONString(byUsername));
user.put("token", accessToken.getToken());
JSONObject ret = new JSONObject();
ret.put("obj",user);
return success(ret);
} else {
return error(30000, "账号或密码不正确");
}
}
4.4 招聘资讯页面
当用户点击“招聘资讯”以后就会进入到以下界面,用户可以输入关键词搜索资讯内容,查看点赞数以及点击数,然后点击到资讯的详细的界面,在这个详细界面可以点赞+收藏+评论。其出界面展示如下图4.4所示。
图4.4 招聘资讯界面图
4.5招聘职位页面
当用户点击“招聘职位”以后就会给我们展示招聘职位的列表,选择一个招聘职位进入到图4.5界面中,用户可以对招聘进行简历投递,点击求职咨询按钮,进入到4.6界面中,输入企业编号、企业名称、职位名称、咨询问题、用户等,点击“提交”按钮,就会显示咨询成功。
图4.5招聘职位界面图
图4.6 求职咨询界面图
招聘职位的逻辑代码如下:
@PostMapping("/add")
@Transactional
public Map<String, Object> add(HttpServletRequest request) throws IOException {
service.insert(service.readBody(request.getReader()));
return success(1);
}
@Transactional
public Map<String, Object> addMap(Map<String,Object> map){
service.insert(map);
return success(1);
}
public Map<String,Object> readBody(BufferedReader reader){
BufferedReader br = null;
StringBuilder sb = new StringBuilder("");
try{
br = reader;
String str;
while ((str = br.readLine()) != null){
sb.append(str);
}
br.close();
String json = sb.toString();
return JSONObject.parseObject(json, Map.class);
}catch (IOException e){
e.printStackTrace();
}finally{
if (null != br){
try{
br.close();
}catch (IOException e){
e.printStackTrace();
}
}
}
return null;
}
public void insert(Map<String,Object> body){
StringBuffer sql = new StringBuffer("INSERT INTO ");
sql.append("`").append(table).append("`").append(" (");
for (Map.Entry<String,Object> entry:body.entrySet()){
sql.append("`"+humpToLine(entry.getKey())+"`").append(",");
}
sql.deleteCharAt(sql.length()-1);
sql.append(") VALUES (");
for (Map.Entry<String,Object> entry:body.entrySet()){
Object value = entry.getValue();
if (value instanceof String){
sql.append("'").append(entry.getValue()).append("'").append(",");
}else {
sql.append(entry.getValue()).append(",");
}
}
sql.deleteCharAt(sql.length() - 1);
sql.append(")");
log.info("[{}] - 插入操作:{}",table,sql);
Query query = runCountSql(sql.toString());
query.executeUpdate();
}
4.6 我的账户页面
当用户点击右上角“我的”这个按钮,会出现子菜单,点击“我的账户”可以对个人的资料以及登录系统的密码进行设置,我的账户界面如下图4.7所示。
图4.7 非药品界面图
4.7 简历投递管理页面
企业点击“简历投递”,选择“面试邀约”按钮后就会进入到面试邀约查询这个界面,输入企业编号、名称、职位名称、用户编号、面试时间等,点击“提交”就查询成功了;其界面展示如下图4.8所示。
图4.8 简历投递界面图
简历投递界面逻辑代码如下:
@RequestMapping(value = {"/avg_group", "/avg"})
public Map<String, Object> avg(HttpServletRequest request) {
Query count = service.avg(service.readQuery(request), service.readConfig(request));
return success(count.getResultList());
}
4.8 求职咨询管理页面
企业点击“求职咨询”,选择“详情”按钮后就会进入到求职咨询信息查询这个界面,输入企业编号、名称、职位名称以及企业回复等,点击“提交”就查询成功了;其界面展示如下图4.9所示。
图4.9 求职咨询界面图
求职咨询管理界面逻辑代码如下:
@RequestMapping(value = {"/count_group", "/count"})
public Map<String, Object> count(HttpServletRequest request) {
Query count = service.count(service.readQuery(request), service.readConfig(request));
return success(count.getResultList());
}
4.9 系统用户管理页面
此功能为管理员的功能,管理员点击“系统用户”菜单后,会展示出管理员+注册用户+招聘企业三个子菜单,任何可以对其进行增删改查操作;其界面展示如下图4.10所示。
图4.10 系统用户管理界面图
4.10 资源管理页面
此功能为管理员的功能,管理员点击“资源管理”菜单后,会展示出招聘资讯+资讯分类两个子菜单,任何可以对其进行增删改查操作;其界面展示如下图4.11所示。
图4.11 资源管理界面图
资源管理界面逻辑代码如下:
@PostMapping("/set")
@Transactional
public Map<String, Object> set(HttpServletRequest request) throws IOException {
service.update(service.readQuery(request), service.readConfig(request), service.readBody(request.getReader()));
return success(1);
}
public Map<String,String> readConfig(HttpServletRequest request){
Map<String,String> map = new HashMap<>();
map.put(FindConfig.PAGE,request.getParameter(FindConfig.PAGE));
map.put(FindConfig.SIZE,request.getParameter(FindConfig.SIZE));
map.put(FindConfig.LIKE,request.getParameter(FindConfig.LIKE));
map.put(FindConfig.ORDER_BY,request.getParameter(FindConfig.ORDER_BY));
map.put(FindConfig.FIELD,request.getParameter(FindConfig.FIELD));
map.put(FindConfig.GROUP_BY,request.getParameter(FindConfig.GROUP_BY));
map.put(FindConfig.MAX_,request.getParameter(FindConfig.MAX_));
map.put(FindConfig.MIN_,request.getParameter(FindConfig.MIN_));
return map;
}
public Map<String,String> readQuery(HttpServletRequest request){
String queryString = request.getQueryString();
if (queryString != null && !"".equals(queryString)) {
String[] querys = queryString.split("&");
Map<String, String> map = new HashMap<>();
for (String query : querys) {
String[] q = query.split("=");
map.put(q[0], q[1]);
}
map.remove(FindConfig.PAGE);
map.remove(FindConfig.SIZE);
map.remove(FindConfig.LIKE);
map.remove(FindConfig.ORDER_BY);
map.remove(FindConfig.FIELD);
map.remove(FindConfig.GROUP_BY);
map.remove(FindConfig.MAX_);
map.remove(FindConfig.MIN_);
return map;
}else {
return new HashMap<>();
}
}
@Transactional
public void update(Map<String,String> query,Map<String,String> config,Map<String,Object> body){
StringBuffer sql = new StringBuffer("UPDATE ").append("`").append(table).append("`").append(" SET ");
for (Map.Entry<String,Object> entry:body.entrySet()){
Object value = entry.getValue();
if (value instanceof String){
sql.append("`"+humpToLine(entry.getKey())+"`").append("=").append("'").append(value).append("'").append(",");
}else {
sql.append("`"+humpToLine(entry.getKey())+"`").append("=").append(value).append(",");
}
}
sql.deleteCharAt(sql.length()-1);
sql.append(toWhereSql(query,"0".equals(config.get(FindConfig.LIKE))));
log.info("[{}] - 更新操作:{}",table,sql);
Query query1 = runCountSql(sql.toString());
query1.executeUpdate();
}
public String toWhereSql(Map<String,String> query, Boolean like) {
if (query.size() > 0) {
try {
StringBuilder sql = new StringBuilder(" WHERE ");
for (Map.Entry<String, String> entry : query.entrySet()) {
if (entry.getKey().contains(FindConfig.MIN_)) {
String min = humpToLine(entry.getKey()).replace("_min", "");
sql.append("`"+min+"`").append(" >= '").append(URLDecoder.decode(entry.getValue(), "UTF-8")).append("' and ");
continue;
}
if (entry.getKey().contains(FindConfig.MAX_)) {
String max = humpToLine(entry.getKey()).replace("_max", "");
sql.append("`"+max+"`").append(" <= '").append(URLDecoder.decode(entry.getValue(), "UTF-8")).append("' and ");
continue;
}
if (like == true) {
sql.append("`"+humpToLine(entry.getKey())+"`").append(" LIKE '%").append(URLDecoder.decode(entry.getValue(), "UTF-8")).append("%'").append(" and ");
} else {
sql.append("`"+humpToLine(entry.getKey())+"`").append(" = '").append(URLDecoder.decode(entry.getValue(), "UTF-8")).append("'").append(" and ");
}
}
sql.delete(sql.length() - 4, sql.length());
sql.append(" ");
return sql.toString();
} catch (UnsupportedEncodingException e) {
log.info("拼接sql 失败:{}", e.getMessage());
}
}
return "";
}
4.11 职位分类管理页面
此功能为管理员的功能,管理员点击“职位分类”菜单后,会展示出添加职位分类栏,可以对职位分类信息进行增删改查操作;其界面展示如下图4.12所示。
图4.12 职位分类管理界面图
职位分类管理界面关键代码如下:
@RequestMapping("/get_list")
public Map<String, Object> getList(HttpServletRequest request) {
Map<String, Object> map = service.selectToPage(service.readQuery(request), service.readConfig(request));
return success(map);
4.12 地区管理页面
此功能为管理员的功能,管理员点击“地区管理”菜单后能够对地区管理进行增删改查操作;其界面展示如下图4.13所示。
图4.13 地区管理界面图
版权声明:
本文来源网络,所有图片文章版权属于原作者,如有侵权,联系删除。
本文网址:https://www.bianchenghao6.com/h6javajc/18386.html