首先,论文一开始便是清楚的论述了系统的研究内容。其次,剖析系统需求分析,弄明白“做什么”,分析包括业务分析和业务流程的分析以及用例分析,更进一步明确系统的需求。然后在明白了系统的需求基础上需要进一步地设计系统,主要包罗软件架构模式、整体功能模块、数据库设计。本项目软件架构选择B/S模式,总体功能模块运用自顶向下的分层思想。再然后就是实现系统并进行代码编写实现功能。论文的最后章节总结一下自己完成本论文和开发本项目的心得和总结。通过房屋租赁管理系统将会使房屋租赁各个方面的工作效率带来实质性的提升。
关键字:房屋租赁系统 B/S模式 软件架
基于ssm+jsp房屋租赁系统源码和论文805
Abstract
First of all, the thesis clearly discusses the systematic research content at the very beginning. Secondly, the analysis of system requirements analysis, understand "what to do", including business analysis and business process analysis and use case analysis, further clear system requirements. Then, on the basis of understanding the requirements of the system, we need to further design the system, mainly including software architecture pattern, overall functional modules and database design. The software architecture of the project is B/S mode, and the overall functional modules are layered from top to bottom. Then is the realization of the system and code writing to achieve the function. The last chapter of the paper summarizes the experience and summary of the completion of this paper and the development of this project. Through the housing rental management system will make all aspects of the housing rental work efficiency to bring substantial improvement.
Key words: housing rental system B/S mode software architecture
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.ZukeEntity;
import com.entity.view.ZukeView;
import com.service.ZukeService;
import com.service.TokenService;
import com.utils.PageUtils;
import com.utils.R;
import com.utils.MD5Util;
import com.utils.MPUtil;
import com.utils.CommonUtil;
import java.io.IOException;
/**
* 租客
* 后端接口
* @author
* @email
* @date 2022-03-20 17:20:42
*/
@RestController
@RequestMapping("/zuke")
public class ZukeController {
@Autowired
private ZukeService zukeService;
@Autowired
private TokenService tokenService;
/**
* 登录
*/
@IgnoreAuth
@RequestMapping(value = "/login")
public R login(String username, String password, String captcha, HttpServletRequest request) {
ZukeEntity user = zukeService.selectOne(new EntityWrapper<ZukeEntity>().eq("zhanghao", username));
if(user==null || !user.getMima().equals(password)) {
return R.error("账号或密码不正确");
}
String token = tokenService.generateToken(user.getId(), username,"zuke", "租客" );
return R.ok().put("token", token);
}
/**
* 注册
*/
@IgnoreAuth
@RequestMapping("/register")
public R register(@RequestBody ZukeEntity zuke){
//ValidatorUtils.validateEntity(zuke);
ZukeEntity user = zukeService.selectOne(new EntityWrapper<ZukeEntity>().eq("zhanghao", zuke.getZhanghao()));
if(user!=null) {
return R.error("注册用户已存在");
}
Long uId = new Date().getTime();
zuke.setId(uId);
zukeService.insert(zuke);
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");
ZukeEntity user = zukeService.selectById(id);
return R.ok().put("data", user);
}
/**
* 密码重置
*/
@IgnoreAuth
@RequestMapping(value = "/resetPass")
public R resetPass(String username, HttpServletRequest request){
ZukeEntity user = zukeService.selectOne(new EntityWrapper<ZukeEntity>().eq("zhanghao", username));
if(user==null) {
return R.error("账号不存在");
}
user.setMima("123456");
zukeService.updateById(user);
return R.ok("密码已重置为:123456");
}
/**
* 后端列表
*/
@RequestMapping("/page")
public R page(@RequestParam Map<String, Object> params,ZukeEntity zuke,
HttpServletRequest request){
EntityWrapper<ZukeEntity> ew = new EntityWrapper<ZukeEntity>();
PageUtils page = zukeService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, zuke), params), params));
request.setAttribute("data", page);
return R.ok().put("data", page);
}
/**
* 前端列表
*/
@IgnoreAuth
@RequestMapping("/list")
public R list(@RequestParam Map<String, Object> params,ZukeEntity zuke,
HttpServletRequest request){
EntityWrapper<ZukeEntity> ew = new EntityWrapper<ZukeEntity>();
PageUtils page = zukeService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, zuke), params), params));
request.setAttribute("data", page);
return R.ok().put("data", page);
}
/**
* 列表
*/
@RequestMapping("/lists")
public R list( ZukeEntity zuke){
EntityWrapper<ZukeEntity> ew = new EntityWrapper<ZukeEntity>();
ew.allEq(MPUtil.allEQMapPre( zuke, "zuke"));
return R.ok().put("data", zukeService.selectListView(ew));
}
/**
* 查询
*/
@RequestMapping("/query")
public R query(ZukeEntity zuke){
EntityWrapper< ZukeEntity> ew = new EntityWrapper< ZukeEntity>();
ew.allEq(MPUtil.allEQMapPre( zuke, "zuke"));
ZukeView zukeView = zukeService.selectView(ew);
return R.ok("查询租客成功").put("data", zukeView);
}
/**
* 后端详情
*/
@RequestMapping("/info/{id}")
public R info(@PathVariable("id") Long id){
ZukeEntity zuke = zukeService.selectById(id);
return R.ok().put("data", zuke);
}
/**
* 前端详情
*/
@IgnoreAuth
@RequestMapping("/detail/{id}")
public R detail(@PathVariable("id") Long id){
ZukeEntity zuke = zukeService.selectById(id);
return R.ok().put("data", zuke);
}
/**
* 后端保存
*/
@RequestMapping("/save")
public R save(@RequestBody ZukeEntity zuke, HttpServletRequest request){
zuke.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
//ValidatorUtils.validateEntity(zuke);
ZukeEntity user = zukeService.selectOne(new EntityWrapper<ZukeEntity>().eq("zhanghao", zuke.getZhanghao()));
if(user!=null) {
return R.error("用户已存在");
}
zuke.setId(new Date().getTime());
zukeService.insert(zuke);
return R.ok();
}
/**
* 前端保存
*/
@RequestMapping("/add")
public R add(@RequestBody ZukeEntity zuke, HttpServletRequest request){
zuke.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
//ValidatorUtils.validateEntity(zuke);
ZukeEntity user = zukeService.selectOne(new EntityWrapper<ZukeEntity>().eq("zhanghao", zuke.getZhanghao()));
if(user!=null) {
return R.error("用户已存在");
}
zuke.setId(new Date().getTime());
zukeService.insert(zuke);
return R.ok();
}
/**
* 修改
*/
@RequestMapping("/update")
public R update(@RequestBody ZukeEntity zuke, HttpServletRequest request){
//ValidatorUtils.validateEntity(zuke);
zukeService.updateById(zuke);//全部更新
return R.ok();
}
/**
* 删除
*/
@RequestMapping("/delete")
public R delete(@RequestBody Long[] ids){
zukeService.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<ZukeEntity> wrapper = new EntityWrapper<ZukeEntity>();
if(map.get("remindstart")!=null) {
wrapper.ge(columnName, map.get("remindstart"));
}
if(map.get("remindend")!=null) {
wrapper.le(columnName, map.get("remindend"));
}
int count = zukeService.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.YonghuzufangEntity;
import com.entity.view.YonghuzufangView;
import com.service.YonghuzufangService;
import com.service.TokenService;
import com.utils.PageUtils;
import com.utils.R;
import com.utils.MD5Util;
import com.utils.MPUtil;
import com.utils.CommonUtil;
import java.io.IOException;
/**
* 用户租房
* 后端接口
* @author
* @email
* @date 2022-03-20 17:20:42
*/
@RestController
@RequestMapping("/yonghuzufang")
public class YonghuzufangController {
@Autowired
private YonghuzufangService yonghuzufangService;
/**
* 后端列表
*/
@RequestMapping("/page")
public R page(@RequestParam Map<String, Object> params,YonghuzufangEntity yonghuzufang,
HttpServletRequest request){
String tableName = request.getSession().getAttribute("tableName").toString();
if(tableName.equals("zuke")) {
yonghuzufang.setZhanghao((String)request.getSession().getAttribute("username"));
}
EntityWrapper<YonghuzufangEntity> ew = new EntityWrapper<YonghuzufangEntity>();
PageUtils page = yonghuzufangService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, yonghuzufang), params), params));
request.setAttribute("data", page);
return R.ok().put("data", page);
}
/**
* 前端列表
*/
@IgnoreAuth
@RequestMapping("/list")
public R list(@RequestParam Map<String, Object> params,YonghuzufangEntity yonghuzufang,
HttpServletRequest request){
EntityWrapper<YonghuzufangEntity> ew = new EntityWrapper<YonghuzufangEntity>();
PageUtils page = yonghuzufangService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, yonghuzufang), params), params));
request.setAttribute("data", page);
return R.ok().put("data", page);
}
/**
* 列表
*/
@RequestMapping("/lists")
public R list( YonghuzufangEntity yonghuzufang){
EntityWrapper<YonghuzufangEntity> ew = new EntityWrapper<YonghuzufangEntity>();
ew.allEq(MPUtil.allEQMapPre( yonghuzufang, "yonghuzufang"));
return R.ok().put("data", yonghuzufangService.selectListView(ew));
}
/**
* 查询
*/
@RequestMapping("/query")
public R query(YonghuzufangEntity yonghuzufang){
EntityWrapper< YonghuzufangEntity> ew = new EntityWrapper< YonghuzufangEntity>();
ew.allEq(MPUtil.allEQMapPre( yonghuzufang, "yonghuzufang"));
YonghuzufangView yonghuzufangView = yonghuzufangService.selectView(ew);
return R.ok("查询用户租房成功").put("data", yonghuzufangView);
}
/**
* 后端详情
*/
@RequestMapping("/info/{id}")
public R info(@PathVariable("id") Long id){
YonghuzufangEntity yonghuzufang = yonghuzufangService.selectById(id);
return R.ok().put("data", yonghuzufang);
}
/**
* 前端详情
*/
@IgnoreAuth
@RequestMapping("/detail/{id}")
public R detail(@PathVariable("id") Long id){
YonghuzufangEntity yonghuzufang = yonghuzufangService.selectById(id);
return R.ok().put("data", yonghuzufang);
}
/**
* 后端保存
*/
@RequestMapping("/save")
public R save(@RequestBody YonghuzufangEntity yonghuzufang, HttpServletRequest request){
yonghuzufang.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
//ValidatorUtils.validateEntity(yonghuzufang);
yonghuzufangService.insert(yonghuzufang);
return R.ok();
}
/**
* 前端保存
*/
@IgnoreAuth
@RequestMapping("/add")
public R add(@RequestBody YonghuzufangEntity yonghuzufang, HttpServletRequest request){
yonghuzufang.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
//ValidatorUtils.validateEntity(yonghuzufang);
yonghuzufangService.insert(yonghuzufang);
return R.ok();
}
/**
* 修改
*/
@RequestMapping("/update")
public R update(@RequestBody YonghuzufangEntity yonghuzufang, HttpServletRequest request){
//ValidatorUtils.validateEntity(yonghuzufang);
yonghuzufangService.updateById(yonghuzufang);//全部更新
return R.ok();
}
/**
* 删除
*/
@RequestMapping("/delete")
public R delete(@RequestBody Long[] ids){
yonghuzufangService.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<YonghuzufangEntity> wrapper = new EntityWrapper<YonghuzufangEntity>();
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("zuke")) {
wrapper.eq("zhanghao", (String)request.getSession().getAttribute("username"));
}
int count = yonghuzufangService.selectCount(wrapper);
return R.ok().put("count", count);
}
}