基于javaweb+mysql的ssm农产品水果店销售管理系统(java+jsp+ssm+javabean+mysql+tomcat)
运行环境
Java≥8、MySQL≥5.7、Tomcat≥8
开发工具
eclipse/idea/myeclipse/sts等均可配置运行
适用
课程设计,大作业,毕业设计,项目练习,学习演示等
功能说明
农产品店、水果店等管理产品与销售、进货等信息
技术框架
JavaBean MVC JSP SSM(Spring SpringMVC MyBatis) MySQL EasyUI JavaScript
基于javaweb+mysql的SSM农产品水果店销售管理系统(java+jsp+ssm+javabean+mysql+tomcat)
/**
* 模糊搜索分页获取销售退货单信息
* @return
*/
@RequestMapping(value="/list",method=RequestMethod.POST)
@ResponseBody
public Map<String, Object> getList(
@RequestParam(name="payType",required=false) Integer payType,
@RequestParam(name="status",required=false) Integer status,
@RequestParam(name="minMoney",required=false) Float minMoney,
@RequestParam(name="maxMoney",required=false) Float maxMoney,
@RequestParam(name="operator",defaultValue="") String operator,Page page
){
Map<String, Object> ret = new HashMap<String, Object>();
Map<String, Object> queryMap = new HashMap<String, Object>();
queryMap.put("operator", operator);
if(payType != null){
queryMap.put("payType", payType);
}
if(status != null){
queryMap.put("status", status);
}
if(minMoney != null){
queryMap.put("minMoney", minMoney);
}
if(maxMoney != null){
queryMap.put("maxMoney", maxMoney);
}
queryMap.put("offset", page.getOffset());
queryMap.put("pageSize", page.getRows());
ret.put("total", sellRebackService.getTotal(queryMap));
ret.put("rows", sellRebackService.findList(queryMap));
return ret;
}
/**
* 添加销售退货单信息
* @param sell
* @return
*/
@RequestMapping(value="add",method=RequestMethod.POST)
@ResponseBody
public Map<String, String> add(String productList,SellReback sell,HttpServletRequest request){
Map<String, String> ret = new HashMap<String, String>();
* @return
*/
private boolean isExist(String username,Long id){
User user = userService.findByUsername(username);
if(user == null)return false;
if(user.getId().longValue() == id.longValue())return false;
return true;
}
}
/**
* 进货退货单管理控制器
*
*/
@RequestMapping("/admin/order_in_reback")
@Controller
public class OrderInRebackController {
@Autowired
private ProductService productService;
@Autowired
private OrderInRebackService orderInRebackService;
@Autowired
/**
* 商品管理控制器
*
*/
@RequestMapping("/admin/product")
@Controller
public class ProductController {
@Autowired
private SupplierService supplierService;
@Autowired
private ProductService productService;
/**
* 商品管理列表页面
* @param model
* @return
*/
@RequestMapping(value="/list",method=RequestMethod.GET)
public ModelAndView list(ModelAndView model){
Map<String, Object> queryMap = new HashMap<String, Object>();
queryMap.put("offset", 0);
queryMap.put("pageSize", 9999);
model.addObject("supplierList", supplierService.findList(queryMap));
model.setViewName("product/list");
return model;
}
/**
* 模糊搜索分页获取商品信息
* @return
*/
@RequestMapping(value="/list",method=RequestMethod.POST)
@ResponseBody
public Map<String, Object> getList(
@RequestParam(name="supplierId",required=false) Long supplierId,
@RequestParam(name="name",defaultValue="") String name,Page page
){
Map<String, Object> ret = new HashMap<String, Object>();
Map<String, Object> queryMap = new HashMap<String, Object>();
queryMap.put("name", name);
if(supplierId != null){
@RequestParam(name="supplierId",required=false) Long supplierId,
@RequestParam(name="name",defaultValue="") String name,Page page
){
Map<String, Object> ret = new HashMap<String, Object>();
Map<String, Object> queryMap = new HashMap<String, Object>();
queryMap.put("name", name);
if(supplierId != null){
queryMap.put("supplierId", supplierId);
}
queryMap.put("offset", page.getOffset());
queryMap.put("pageSize", page.getRows());
ret.put("total", productService.getTotal(queryMap));
ret.put("rows", productService.findList(queryMap));
return ret;
}
/**
* 添加商品信息
* @param product
* @return
*/
@RequestMapping(value="add",method=RequestMethod.POST)
@ResponseBody
public Map<String, String> add(Product product){
Map<String, String> ret = new HashMap<String, String>();
if(product == null){
ret.put("type", "error");
ret.put("msg", "请填写正确的农产品信息!");
return ret;
}
if(StringUtils.isEmpty(product.getName())){
ret.put("type", "error");
ret.put("msg", "请填写农产品名称!");
return ret;
}
if(product.getSupplierId() == null){
ret.put("type", "error");
ret.put("msg", "请选择农产品供应商!");
return ret;
}
if(product.getPrice() == null){
ret.put("type", "error");
ret.put("msg", "请填写农产品单价!");
return ret;
}
if(productService.add(product) <= 0){
ret.put("type", "error");
ret.put("msg", "添加失败,请联系管理员!");
return ret;
}
ret.put("type", "success");
ret.put("msg", "添加成功!");
return ret;
*/
@RequestMapping("/admin/user")
@Controller
public class UserController {
@Autowired
private UserService userService;
@Autowired
private RoleService roleService;
/**
* 用户列表页面
* @param model
* @return
*/
@RequestMapping(value="/list",method=RequestMethod.GET)
public ModelAndView list(ModelAndView model){
Map<String, Object> queryMap = new HashMap<String, Object>();
model.addObject("roleList", roleService.findList(queryMap));
model.setViewName("user/list");
return model;
}
/**
* 获取用户列表
* @param page
* @param username
* @param roleId
* @param sex
* @return
*/
@RequestMapping(value="/list",method=RequestMethod.POST)
@ResponseBody
public Map<String, Object> getList(Page page,
@RequestParam(name="username",required=false,defaultValue="") String username,
@RequestParam(name="roleId",required=false) Long roleId,
@RequestParam(name="sex",required=false) Integer sex
){
Map<String, Object> ret = new HashMap<String, Object>();
Map<String, Object> queryMap = new HashMap<String, Object>();
queryMap.put("username", username);
queryMap.put("roleId", roleId);
queryMap.put("sex", sex);
queryMap.put("offset", page.getOffset());
queryMap.put("pageSize", page.getRows());
ret.put("rows", userService.findList(queryMap));
ret.put("total", userService.getTotal(queryMap));
/**
* 进货单管理控制器
*
*/
@RequestMapping("/admin/order_in")
@Controller
public class OrderInController {
@Autowired
private ProductService productService;
@Autowired
private OrderInService orderInService;
@Autowired
private StockService stockService;
/**
* 进货单管理列表页面
* @param model
* @return
*/
@RequestMapping(value="/list",method=RequestMethod.GET)
public ModelAndView list(ModelAndView model){
model.setViewName("order_in/list");
return model;
}
/**
* 模糊搜索分页获取进货单信息
* @return
*/
try {
if(stockService.delete(id) <= 0){
ret.put("type", "error");
ret.put("msg", "删除失败,请联系管理员!");
return ret;
}
} catch (Exception e) {
// TODO: handle exception
ret.put("type", "error");
ret.put("msg", "该商品库存下存在关联的入库或销售信息,请先将商品库存关联信息删除!");
return ret;
}
ret.put("type", "success");
ret.put("msg", "删除成功!");
return ret;
}
}
/**
* 日志管理控制器
*
*/
@RequestMapping("/admin/log")
@Controller
}
if(StringUtils.isEmpty(user.getUsername())){
ret.put("type", "error");
ret.put("msg", "请填写用户名!");
return ret;
}
if(StringUtils.isEmpty(user.getPassword())){
ret.put("type", "error");
ret.put("msg", "请填写密码!");
return ret;
}
Object loginCpacha = request.getSession().getAttribute("loginCpacha");
if(loginCpacha == null){
ret.put("type", "error");
ret.put("msg", "会话超时,请刷新页面!");
return ret;
}
if(!cpacha.toUpperCase().equals(loginCpacha.toString().toUpperCase())){
ret.put("type", "error");
ret.put("msg", "验证码错误!");
logService.add("用户名为"+user.getUsername()+"的用户登录时输入验证码错误!");
return ret;
}
User findByUsername = userService.findByUsername(user.getUsername());
if(findByUsername == null){
ret.put("type", "error");
ret.put("msg", "该用户名不存在!");
logService.add("登录时,用户名为"+user.getUsername()+"的用户不存在!");
return ret;
}
if(!user.getPassword().equals(findByUsername.getPassword())){
ret.put("type", "error");
ret.put("msg", "密码错误!");
logService.add("用户名为"+user.getUsername()+"的用户登录时输入密码错误!");
return ret;
}
//说明用户名密码及验证码都正确
//此时需要查询用户的角色权限
Role role = roleService.find(findByUsername.getRoleId());
List<Authority> authorityList = authorityService.findListByRoleId(role.getId());//根据角色获取权限列表
String menuIds = "";
for(Authority authority:authorityList){
menuIds += authority.getMenuId() + ",";
}
if(!StringUtils.isEmpty(menuIds)){
menuIds = menuIds.substring(0,menuIds.length()-1);
}
existStock.setProductNum(existStock.getProductNum() + stock.getProductNum());
stockService.edit(existStock);
}
}
}
/**
* 销售退货单管理控制器
*
*/
@RequestMapping("/admin/sell_reback")
@Controller
public class SellRebackController {
@Autowired
private SellRebackService sellRebackService;
@Autowired
private StockService stockService;
/**
}
/**
* 销售统计控制器
*
*/
@RequestMapping("/admin/stats")
@Controller
public class StatsController {
@Autowired
private SellService sellService;
@Autowired
private SellRebackService sellRebackService;
/**
* 统计页面
* @param model
* @return
*/
@RequestMapping(value="stats",method=RequestMethod.GET)
public ModelAndView stats(ModelAndView model){
model.setViewName("stats/stats");
return model;
}
/**
* 获取统计数据
* @param type
* @return
@Autowired
private AuthorityService authorityService;
@Autowired
private MenuService menuService;
/**
* 角色列表页面
* @param model
* @return
*/
@RequestMapping(value="/list",method=RequestMethod.GET)
public ModelAndView list(ModelAndView model){
model.setViewName("/role/list");
return model;
}
/**
* 获取角色列表
* @param page
* @param name
* @return
*/
@RequestMapping(value="/list",method=RequestMethod.POST)
@ResponseBody
public Map<String, Object> getList(Page page,
@RequestParam(name="name",required=false,defaultValue="") String name
){
Map<String, Object> ret = new HashMap<String, Object>();
Map<String, Object> queryMap = new HashMap<String, Object>();
queryMap.put("name", name);
queryMap.put("offset", page.getOffset());
queryMap.put("pageSize", page.getRows());
ret.put("rows", roleService.findList(queryMap));
ret.put("total", roleService.getTotal(queryMap));
return ret;
}
/**
* 角色添加
* @param role
* @return
*/
@RequestMapping(value="/add",method=RequestMethod.POST)
@ResponseBody
public Map<String, String> add(Role role){
Map<String, String> ret = new HashMap<String, String>();
if(role == null){
ret.put("type", "error");
ret.put("msg", "请填写正确的角色信息!");
return ret;
ret.put("type", "success");
ret.put("msg", "添加成功!");
return ret;
}
/**
* 编辑供应商信息
* @param supplier
* @return
*/
@RequestMapping(value="edit",method=RequestMethod.POST)
@ResponseBody
public Map<String, String> edit(Supplier supplier){
Map<String, String> ret = new HashMap<String, String>();
if(supplier == null){
ret.put("type", "error");
ret.put("msg", "请填写正确的供应商信息!");
return ret;
}
if(StringUtils.isEmpty(supplier.getName())){
ret.put("type", "error");
ret.put("msg", "请填写供应商名称!");
return ret;
}
if(StringUtils.isEmpty(supplier.getTel())){
ret.put("type", "error");
ret.put("msg", "请填写供应商电话!");
return ret;
}
if(StringUtils.isEmpty(supplier.getContactName())){
ret.put("type", "error");
ret.put("msg", "请填写供应商联系人!");
return ret;
}
if(StringUtils.isEmpty(supplier.getContactPhone())){
ret.put("type", "error");
ret.put("msg", "请填写供应商联系人手机号!");
return ret;
}
if(StringUtils.isEmpty(supplier.getAddress())){
ret.put("type", "error");
ret.put("msg", "请填写供应商地址!");
return ret;
}
if(supplierService.edit(supplier) <= 0){
ret.put("type", "error");
ret.put("msg", "编辑失败,请联系管理员!");
return ret;
}
ret.put("type", "success");
ret.put("msg", "添加成功!");
return ret;
/**
* 系统操作类控制器
*
*/
@Controller
@RequestMapping("/system")
public class SystemController {
@Autowired
private UserService userService;
@Autowired
private RoleService roleService;
@Autowired
* 销售单管理控制器
*
*/
@RequestMapping("/admin/sell")
@Controller
public class SellController {
@Autowired
private SellService sellService;
@Autowired
private StockService stockService;
/**
* 销售单管理列表页面
* @param model
* @return
*/
@RequestMapping(value="/list",method=RequestMethod.GET)
public ModelAndView list(ModelAndView model){
model.setViewName("sell/list");
return model;
}
/**
* 模糊搜索分页获取销售单信息
* @return
*/
@RequestMapping(value="/list",method=RequestMethod.POST)
@ResponseBody
public Map<String, Object> getList(
@RequestParam(name="payType",required=false) Integer payType,
@RequestParam(name="status",required=false) Integer status,
@RequestParam(name="minMoney",required=false) Float minMoney,
@RequestParam(name="maxMoney",required=false) Float maxMoney,
@RequestParam(name="operator",defaultValue="") String operator,Page page
){
Map<String, Object> ret = new HashMap<String, Object>();
Map<String, Object> queryMap = new HashMap<String, Object>();
queryMap.put("operator", operator);
if(payType != null){
queryMap.put("payType", payType);
}
if(status != null){
queryMap.put("status", status);
}
if(minMoney != null){
public Map<String, String> edit(Menu menu){
Map<String, String> ret = new HashMap<String, String>();
if(menu == null){
ret.put("type", "error");
ret.put("msg", "请选择正确的菜单信息!");
return ret;
}
if(StringUtils.isEmpty(menu.getName())){
ret.put("type", "error");
ret.put("msg", "请填写菜单名称!");
return ret;
}
if(StringUtils.isEmpty(menu.getIcon())){
ret.put("type", "error");
ret.put("msg", "请填写菜单图标类!");
return ret;
}
if(menu.getParentId() == null){
menu.setParentId(0l);
}
if(menuService.edit(menu) <= 0){
ret.put("type", "error");
ret.put("msg", "修改失败,请联系管理员!");
return ret;
}
ret.put("type", "success");
ret.put("msg", "修改成功!");
return ret;
}
/**
* 删除菜单信息
* @param id
* @return
*/
@RequestMapping(value="/delete",method=RequestMethod.POST)
@ResponseBody
public Map<String, String> delete(
@RequestParam(name="id",required=true) Long id
){
Map<String, String> ret = new HashMap<String, String>();
if(id == null){
}
}
/**
* 菜单管理控制器
*
*/
@RequestMapping("/admin/menu")
@Controller
public class MenuController {
@Autowired
private MenuService menuService;
/**
/**
* 商品管理控制器
*
*/
@RequestMapping("/admin/product")
@Controller
public class ProductController {
@Autowired
private SupplierService supplierService;
@Autowired
private ProductService productService;
/**
* 商品管理列表页面
* @param model
* @return
*/
@RequestMapping(value="/list",method=RequestMethod.GET)
public ModelAndView list(ModelAndView model){
Map<String, Object> queryMap = new HashMap<String, Object>();
queryMap.put("offset", 0);
queryMap.put("pageSize", 9999);
model.addObject("supplierList", supplierService.findList(queryMap));
model.setViewName("product/list");
return model;
}
/**
* 模糊搜索分页获取商品信息
* @return
*/
@RequestMapping(value="/list",method=RequestMethod.POST)
@ResponseBody