文末获取源码
开发语言:Java
开发工具:IDEA /Eclipse
数据库:MYSQL5.7/8.0
应用服务:Tomcat7/Tomcat8
是否Maven项目:是
后端框架:SpringBoot
前端框架:vue+element等
JDK版本:jdk1.8
项目架构:B/S架构
随着农机电招行业的不断发展,农机电招在现实生活中的使用和普及,农机电招行业成为近年内出现的一个新行业,并且能够成为大群众广为认可和接受的行为和选择。设计农机电招平台的目的就是借助计算机让复杂的销售操作变简单,变高效。
农机电招平台采用了B/S结构,JAVA作为开发语言,数据库采用了B/S结构,Mysql数据库进行开发。该系统包括前台操作和后台管理两个部分,一方面,为用户提供首页,农机,系统公告,个人中心,后台管理等功能;另一方面,为管理员提供首页,个人中心,农机机主管理,使用者管理,农机类型管理,农机管理,农机预约管理,系统管理等功能。
需求分析是指详细的分析要解决的问题,弄清楚要解决的问题的要求,最终达到一个什么样的结果。需求分析的最终任务就是对即将要开发的系统的功能、性能等方面进行定义。
农机电招平台是一个管理信息系统,为了宣传的需要,为了给用户提供方便快捷的服务,从而设计了农机电招平台。管理员可以通过这个系统把农机电招信息发布出去,可以方便用户快速地了解最新动态,用户也可以从中获得多样化的优质服务,促进了和用户之间的沟通。
农机电招平台的主要包括了管理员,农机机主和使用者三个角色。
1.用户进入系统可以实现首页,农机,系统公告,个人中心,后台管理等;
2.管理员的主要功能包括首页,个人中心,农机机主管理,使用者管理,农机类型管理,农机管理,农机预约管理,系统管理等;
农机电招平台系统的主要功能展示了首页,农机,系统公告,个人中心,后台管理等,用户可根据权限进行相应操作。如图
农机机主注册,通过填写机主账号,机主姓名,密码,确认密码,年龄,手机号,身份证,等信息完成注册操作,如图
农机,在农机页面可以查看品牌,型号,农机类型,日租价,机主账号,机主姓名,手机号等内容,并进行预约操作;如图
个人中心,在个人中心页面中可以对用户名,姓名,密码,性别,年龄,联系电话,身份证,驾照等级等内容进行更新信息操作,如图
用户进入系统前在登录页面根据要求填写用户名和密码,选择角色等信息,点击登录进行登录操作,如图
管理员登录系统后,可以对首页,个人中心,农机机主管理,使用者管理,农机类型管理,农机管理,农机预约管理,系统管理等功能进行相应的操作管理,如图
在农机机主管理页面可以对索引,机主账号,机主姓名,性别,年龄,手机号,身份证等内容进行详情,修改和删除等操作,如图
在使用者管理页面可以对车索引,用户名,姓名,性别,年龄,联系电话,身份证,驾照等级等内容进行详情,修改和删除等操作,如图
在农机类型管理页面可以对索引,农机类型等内容进行详情和修改等操作;如图
在农机管理页面可以对索引,农机名称,封面图片,品牌,型号,农机类型,日租价,机主账号,机主姓名,手机号等内容进行详情,修改和删除等操作,如图
农机机主登录系统后,可以对首页,个人中心,农机管理,农机预约管理等功能进行相应的操作管理,如图
在农机管理页面可以对索引,农机名称,封面图片,品牌,型号,农机类型,日租价,机主账号,机主姓名,手机号等内容进行详情,修改和删除等操作,如图
在农机预约管理页面可以对索引,农机名称,封面图片,品牌,型号,机主账号,手机号,农机类型,日租价,租赁天数,总价,预约时间,用户名,姓名,联系电话,身份证,驾照等级,工作地点,备注,是否支付,审核回复,审核状态,审核等内容进行详情和删除等操作,如图
使用者登录系统后,可以对首页,个人中心,农机预约管理等功能进行相应的操作管理,如图
/**
* 农机机主
* 后端接口
* @author
* @email
* @date 2022-04-18 15:38:13
*/
@RestController
@RequestMapping("/nongjijizhu")
public class NongjijizhuController {
@Autowired
private NongjijizhuService nongjijizhuService;
@Autowired
private TokenService tokenService;
/**
* 登录
*/
@IgnoreAuth
@RequestMapping(value = "/login")
public R login(String username, String password, String captcha, HttpServletRequest request) {
NongjijizhuEntity user = nongjijizhuService.selectOne(new EntityWrapper().eq("jizhuzhanghao", username));
if(user==null || !user.getMima().equals(password)) {
return R.error("账号或密码不正确");
}
String token = tokenService.generateToken(user.getId(), username,"nongjijizhu", "农机机主" );
return R.ok().put("token", token);
}
/**
* 注册
*/
@IgnoreAuth
@RequestMapping("/register")
public R register(@RequestBody NongjijizhuEntity nongjijizhu){
//ValidatorUtils.validateEntity(nongjijizhu);
NongjijizhuEntity user = nongjijizhuService.selectOne(new EntityWrapper().eq("jizhuzhanghao", nongjijizhu.getJizhuzhanghao()));
if(user!=null) {
return R.error("注册用户已存在");
}
Long uId = new Date().getTime();
nongjijizhu.setId(uId);
nongjijizhuService.insert(nongjijizhu);
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");
NongjijizhuEntity user = nongjijizhuService.selectById(id);
return R.ok().put("data", user);
}
/**
* 密码重置
*/
@IgnoreAuth
@RequestMapping(value = "/resetPass")
public R resetPass(String username, HttpServletRequest request){
NongjijizhuEntity user = nongjijizhuService.selectOne(new EntityWrapper().eq("jizhuzhanghao", username));
if(user==null) {
return R.error("账号不存在");
}
user.setMima("123456");
nongjijizhuService.updateById(user);
return R.ok("密码已重置为:123456");
}
/**
* 后端列表
*/
@RequestMapping("/page")
public R page(@RequestParam Map params,NongjijizhuEntity nongjijizhu,
HttpServletRequest request){
EntityWrapper ew = new EntityWrapper();
PageUtils page = nongjijizhuService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, nongjijizhu), params), params));
return R.ok().put("data", page);
}
/**
* 前端列表
*/
@IgnoreAuth
@RequestMapping("/list")
public R list(@RequestParam Map params,NongjijizhuEntity nongjijizhu,
HttpServletRequest request){
EntityWrapper ew = new EntityWrapper();
PageUtils page = nongjijizhuService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, nongjijizhu), params), params));
return R.ok().put("data", page);
}
/**
* 列表
*/
@RequestMapping("/lists")
public R list( NongjijizhuEntity nongjijizhu){
EntityWrapper ew = new EntityWrapper();
ew.allEq(MPUtil.allEQMapPre( nongjijizhu, "nongjijizhu"));
return R.ok().put("data", nongjijizhuService.selectListView(ew));
}
/**
* 查询
*/
@RequestMapping("/query")
public R query(NongjijizhuEntity nongjijizhu){
EntityWrapper< NongjijizhuEntity> ew = new EntityWrapper< NongjijizhuEntity>();
ew.allEq(MPUtil.allEQMapPre( nongjijizhu, "nongjijizhu"));
NongjijizhuView nongjijizhuView = nongjijizhuService.selectView(ew);
return R.ok("查询农机机主成功").put("data", nongjijizhuView);
}
/**
* 后端详情
*/
@RequestMapping("/info/{id}")
public R info(@PathVariable("id") Long id){
NongjijizhuEntity nongjijizhu = nongjijizhuService.selectById(id);
return R.ok().put("data", nongjijizhu);
}
/**
* 前端详情
*/
@IgnoreAuth
@RequestMapping("/detail/{id}")
public R detail(@PathVariable("id") Long id){
NongjijizhuEntity nongjijizhu = nongjijizhuService.selectById(id);
return R.ok().put("data", nongjijizhu);
}
/**
* 后端保存
*/
@RequestMapping("/save")
public R save(@RequestBody NongjijizhuEntity nongjijizhu, HttpServletRequest request){
nongjijizhu.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
//ValidatorUtils.validateEntity(nongjijizhu);
NongjijizhuEntity user = nongjijizhuService.selectOne(new EntityWrapper().eq("jizhuzhanghao", nongjijizhu.getJizhuzhanghao()));
if(user!=null) {
return R.error("用户已存在");
}
nongjijizhu.setId(new Date().getTime());
nongjijizhuService.insert(nongjijizhu);
return R.ok();
}
/**
* 前端保存
*/
@RequestMapping("/add")
public R add(@RequestBody NongjijizhuEntity nongjijizhu, HttpServletRequest request){
nongjijizhu.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
//ValidatorUtils.validateEntity(nongjijizhu);
NongjijizhuEntity user = nongjijizhuService.selectOne(new EntityWrapper().eq("jizhuzhanghao", nongjijizhu.getJizhuzhanghao()));
if(user!=null) {
return R.error("用户已存在");
}
nongjijizhu.setId(new Date().getTime());
nongjijizhuService.insert(nongjijizhu);
return R.ok();
}
/**
* 修改
*/
@RequestMapping("/update")
public R update(@RequestBody NongjijizhuEntity nongjijizhu, HttpServletRequest request){
//ValidatorUtils.validateEntity(nongjijizhu);
nongjijizhuService.updateById(nongjijizhu);//全部更新
return R.ok();
}
/**
* 删除
*/
@RequestMapping("/delete")
public R delete(@RequestBody Long[] ids){
nongjijizhuService.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 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 wrapper = new EntityWrapper();
if(map.get("remindstart")!=null) {
wrapper.ge(columnName, map.get("remindstart"));
}
if(map.get("remindend")!=null) {
wrapper.le(columnName, map.get("remindend"));
}
int count = nongjijizhuService.selectCount(wrapper);
return R.ok().put("count", count);
}
}