基于微信小程序的房屋租赁管理系统的设计与实现
摘要
随着信息技术在管理上越来越深入而广泛的应用,管理信息系统的实施在技术上已逐步成熟。本文介绍了基于微信小程序的房屋租赁管理系统的开发全过程。通过分析基于微信小程序的房屋租赁管理系统管理的不足,创建了一个计算机管理基于微信小程序的房屋租赁管理系统的方案。文章介绍了基于微信小程序的房屋租赁管理系统的系统分析部分,包括可行性分析等,系统设计部分主要介绍了系统功能设计和数据库设计。
本基于微信小程序的房屋租赁管理系统后端有管理员和中介。管理员功能有,个人中心,用户管理,中介管理,房屋信息管理,房屋类型管理,租房订单管理,租房信息管理,租房账单管理,房源管理,系统管理等。中介功能有,个人中心,房屋信息管理,租房订单管理,租房信息管理等。用户功能有,查看房屋信息,修改个人信息,租房订单,租房信息,租房账单。因而具有一定的实用性。
本站后台采用Java的SSM框架进行后台管理开发,可以在浏览器上登录进行后台数据方面的管理,MySQL作为本地数据库,微信小程序用到了微信开发者工具,充分保证系统的稳定性。系统具有界面清晰、操作简单,功能齐全的特点,使得基于微信小程序的房屋租赁管理系统管理工作系统化、规范化。
基于微信小程序的房屋租赁管理系统+ssm后台管理源码和论文weixin135
关键词:基于微信小程序的房屋租赁管理系统;SSM框架;MYSQL数据库
Abstract
With the deepening and extensive application of information technology in management, the implementation of management information systems has gradually matured in technology. This article introduces the whole process of the development of the housing rental management system based on WeChat applet. By analyzing the deficiencies in the management of the housing rental management system based on the WeChat applet, a computer management solution for the housing rental management system based on the WeChat applet was created. The article introduces the system analysis part of the housing rental management system based on WeChat applet, including feasibility analysis, etc. The system design part mainly introduces the system function design and database design.
The back end of the housing rental management system based on WeChat applet has administrators and intermediaries. Administrator functions include personal center, user management, intermediary management, housing information management, housing type management, rental order management, rental information management, rental bill management, housing management, system management, etc. Intermediary functions include personal center, housing information management, rental order management, rental information management, etc. User functions include viewing housing information, modifying personal information, rental orders, rental information, and rental bills. So it has a certain practicability.
The background of this site uses the Java SSM framework for background management and development. You can log in on the browser for background data management. MySQL is used as a local database. WeChat applets use WeChat developer tools to fully ensure the stability of the system. The system has the characteristics of clear interface, simple operation and complete functions, which makes the management of the housing rental management system based on WeChat applet systematized and standardized.
Keywords: Housing rental management system based on WeChat applet; SSM framework; MYSQL database文章来源:https://www.toymoban.com/news/detail-816485.html
文章来源地址https://www.toymoban.com/news/detail-816485.html
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.format.annotation.DateTimeFormat;
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.ZhongjieEntity;
import com.entity.view.ZhongjieView;
import com.service.ZhongjieService;
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-04-19 17:47:04
*/
@RestController
@RequestMapping("/zhongjie")
public class ZhongjieController {
@Autowired
private ZhongjieService zhongjieService;
@Autowired
private TokenService tokenService;
/**
* 登录
*/
@IgnoreAuth
@RequestMapping(value = "/login")
public R login(String username, String password, String captcha, HttpServletRequest request) {
ZhongjieEntity user = zhongjieService.selectOne(new EntityWrapper<ZhongjieEntity>().eq("zhongjiezhanghao", username));
if(user==null || !user.getMima().equals(password)) {
return R.error("账号或密码不正确");
}
String token = tokenService.generateToken(user.getId(), username,"zhongjie", "中介" );
return R.ok().put("token", token);
}
/**
* 注册
*/
@IgnoreAuth
@RequestMapping("/register")
public R register(@RequestBody ZhongjieEntity zhongjie){
//ValidatorUtils.validateEntity(zhongjie);
ZhongjieEntity user = zhongjieService.selectOne(new EntityWrapper<ZhongjieEntity>().eq("zhongjiezhanghao", zhongjie.getZhongjiezhanghao()));
if(user!=null) {
return R.error("注册用户已存在");
}
Long uId = new Date().getTime();
zhongjie.setId(uId);
zhongjieService.insert(zhongjie);
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");
ZhongjieEntity user = zhongjieService.selectById(id);
return R.ok().put("data", user);
}
/**
* 密码重置
*/
@IgnoreAuth
@RequestMapping(value = "/resetPass")
public R resetPass(String username, HttpServletRequest request){
ZhongjieEntity user = zhongjieService.selectOne(new EntityWrapper<ZhongjieEntity>().eq("zhongjiezhanghao", username));
if(user==null) {
return R.error("账号不存在");
}
user.setMima("123456");
zhongjieService.updateById(user);
return R.ok("密码已重置为:123456");
}
/**
* 后端列表
*/
@RequestMapping("/page")
public R page(@RequestParam Map<String, Object> params,ZhongjieEntity zhongjie,
HttpServletRequest request){
EntityWrapper<ZhongjieEntity> ew = new EntityWrapper<ZhongjieEntity>();
PageUtils page = zhongjieService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, zhongjie), params), params));
return R.ok().put("data", page);
}
/**
* 前端列表
*/
@RequestMapping("/list")
public R list(@RequestParam Map<String, Object> params,ZhongjieEntity zhongjie, HttpServletRequest request){
EntityWrapper<ZhongjieEntity> ew = new EntityWrapper<ZhongjieEntity>();
PageUtils page = zhongjieService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, zhongjie), params), params));
return R.ok().put("data", page);
}
/**
* 列表
*/
@RequestMapping("/lists")
public R list( ZhongjieEntity zhongjie){
EntityWrapper<ZhongjieEntity> ew = new EntityWrapper<ZhongjieEntity>();
ew.allEq(MPUtil.allEQMapPre( zhongjie, "zhongjie"));
return R.ok().put("data", zhongjieService.selectListView(ew));
}
/**
* 查询
*/
@RequestMapping("/query")
public R query(ZhongjieEntity zhongjie){
EntityWrapper< ZhongjieEntity> ew = new EntityWrapper< ZhongjieEntity>();
ew.allEq(MPUtil.allEQMapPre( zhongjie, "zhongjie"));
ZhongjieView zhongjieView = zhongjieService.selectView(ew);
return R.ok("查询中介成功").put("data", zhongjieView);
}
/**
* 后端详情
*/
@RequestMapping("/info/{id}")
public R info(@PathVariable("id") Long id){
ZhongjieEntity zhongjie = zhongjieService.selectById(id);
return R.ok().put("data", zhongjie);
}
/**
* 前端详情
*/
@RequestMapping("/detail/{id}")
public R detail(@PathVariable("id") Long id){
ZhongjieEntity zhongjie = zhongjieService.selectById(id);
return R.ok().put("data", zhongjie);
}
/**
* 后端保存
*/
@RequestMapping("/save")
public R save(@RequestBody ZhongjieEntity zhongjie, HttpServletRequest request){
zhongjie.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
//ValidatorUtils.validateEntity(zhongjie);
ZhongjieEntity user = zhongjieService.selectOne(new EntityWrapper<ZhongjieEntity>().eq("zhongjiezhanghao", zhongjie.getZhongjiezhanghao()));
if(user!=null) {
return R.error("用户已存在");
}
zhongjie.setId(new Date().getTime());
zhongjieService.insert(zhongjie);
return R.ok();
}
/**
* 前端保存
*/
@RequestMapping("/add")
public R add(@RequestBody ZhongjieEntity zhongjie, HttpServletRequest request){
zhongjie.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
//ValidatorUtils.validateEntity(zhongjie);
ZhongjieEntity user = zhongjieService.selectOne(new EntityWrapper<ZhongjieEntity>().eq("zhongjiezhanghao", zhongjie.getZhongjiezhanghao()));
if(user!=null) {
return R.error("用户已存在");
}
zhongjie.setId(new Date().getTime());
zhongjieService.insert(zhongjie);
return R.ok();
}
/**
* 修改
*/
@RequestMapping("/update")
public R update(@RequestBody ZhongjieEntity zhongjie, HttpServletRequest request){
//ValidatorUtils.validateEntity(zhongjie);
zhongjieService.updateById(zhongjie);//全部更新
return R.ok();
}
/**
* 删除
*/
@RequestMapping("/delete")
public R delete(@RequestBody Long[] ids){
zhongjieService.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<ZhongjieEntity> wrapper = new EntityWrapper<ZhongjieEntity>();
if(map.get("remindstart")!=null) {
wrapper.ge(columnName, map.get("remindstart"));
}
if(map.get("remindend")!=null) {
wrapper.le(columnName, map.get("remindend"));
}
int count = zhongjieService.selectCount(wrapper);
return R.ok().put("count", count);
}
}
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.format.annotation.DateTimeFormat;
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.ZufangzhangdanEntity;
import com.entity.view.ZufangzhangdanView;
import com.service.ZufangzhangdanService;
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-04-19 17:47:04
*/
@RestController
@RequestMapping("/zufangzhangdan")
public class ZufangzhangdanController {
@Autowired
private ZufangzhangdanService zufangzhangdanService;
/**
* 后端列表
*/
@RequestMapping("/page")
public R page(@RequestParam Map<String, Object> params,ZufangzhangdanEntity zufangzhangdan,
HttpServletRequest request){
String tableName = request.getSession().getAttribute("tableName").toString();
if(tableName.equals("yonghu")) {
zufangzhangdan.setZhanghao((String)request.getSession().getAttribute("username"));
}
EntityWrapper<ZufangzhangdanEntity> ew = new EntityWrapper<ZufangzhangdanEntity>();
PageUtils page = zufangzhangdanService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, zufangzhangdan), params), params));
return R.ok().put("data", page);
}
/**
* 前端列表
*/
@RequestMapping("/list")
public R list(@RequestParam Map<String, Object> params,ZufangzhangdanEntity zufangzhangdan, HttpServletRequest request){
String tableName = request.getSession().getAttribute("tableName").toString();
if(tableName.equals("yonghu")) {
zufangzhangdan.setZhanghao((String)request.getSession().getAttribute("username"));
}
EntityWrapper<ZufangzhangdanEntity> ew = new EntityWrapper<ZufangzhangdanEntity>();
PageUtils page = zufangzhangdanService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, zufangzhangdan), params), params));
return R.ok().put("data", page);
}
/**
* 列表
*/
@RequestMapping("/lists")
public R list( ZufangzhangdanEntity zufangzhangdan){
EntityWrapper<ZufangzhangdanEntity> ew = new EntityWrapper<ZufangzhangdanEntity>();
ew.allEq(MPUtil.allEQMapPre( zufangzhangdan, "zufangzhangdan"));
return R.ok().put("data", zufangzhangdanService.selectListView(ew));
}
/**
* 查询
*/
@RequestMapping("/query")
public R query(ZufangzhangdanEntity zufangzhangdan){
EntityWrapper< ZufangzhangdanEntity> ew = new EntityWrapper< ZufangzhangdanEntity>();
ew.allEq(MPUtil.allEQMapPre( zufangzhangdan, "zufangzhangdan"));
ZufangzhangdanView zufangzhangdanView = zufangzhangdanService.selectView(ew);
return R.ok("查询租房账单成功").put("data", zufangzhangdanView);
}
/**
* 后端详情
*/
@RequestMapping("/info/{id}")
public R info(@PathVariable("id") Long id){
ZufangzhangdanEntity zufangzhangdan = zufangzhangdanService.selectById(id);
return R.ok().put("data", zufangzhangdan);
}
/**
* 前端详情
*/
@RequestMapping("/detail/{id}")
public R detail(@PathVariable("id") Long id){
ZufangzhangdanEntity zufangzhangdan = zufangzhangdanService.selectById(id);
return R.ok().put("data", zufangzhangdan);
}
/**
* 后端保存
*/
@RequestMapping("/save")
public R save(@RequestBody ZufangzhangdanEntity zufangzhangdan, HttpServletRequest request){
zufangzhangdan.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
//ValidatorUtils.validateEntity(zufangzhangdan);
zufangzhangdanService.insert(zufangzhangdan);
return R.ok();
}
/**
* 前端保存
*/
@RequestMapping("/add")
public R add(@RequestBody ZufangzhangdanEntity zufangzhangdan, HttpServletRequest request){
zufangzhangdan.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
//ValidatorUtils.validateEntity(zufangzhangdan);
zufangzhangdan.setUserid((Long)request.getSession().getAttribute("userId"));
zufangzhangdanService.insert(zufangzhangdan);
return R.ok();
}
/**
* 修改
*/
@RequestMapping("/update")
public R update(@RequestBody ZufangzhangdanEntity zufangzhangdan, HttpServletRequest request){
//ValidatorUtils.validateEntity(zufangzhangdan);
zufangzhangdanService.updateById(zufangzhangdan);//全部更新
return R.ok();
}
/**
* 删除
*/
@RequestMapping("/delete")
public R delete(@RequestBody Long[] ids){
zufangzhangdanService.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<ZufangzhangdanEntity> wrapper = new EntityWrapper<ZufangzhangdanEntity>();
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("zhanghao", (String)request.getSession().getAttribute("username"));
}
int count = zufangzhangdanService.selectCount(wrapper);
return R.ok().put("count", count);
}
}
到了这里,关于基于微信小程序的房屋租赁管理系统+ssm后台管理源码和论文的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!