文章目录
- 前言
- 一、项目设计
- 1. 模块设计
- 系统子模块功能介绍
- 2. 实现效果
- 二、部分源码
- 项目源码
前言
今天学长向大家分享一个 java web项目:
基于java web的百货中心供应链管理系统
一、项目设计
1. 模块设计
系统子模块功能介绍
1)登录模块:用户通过输入用户名和密码来登录系统,如果输入错误会返回登录界面,成功登录后用户的登录信息会存储在浏览器中,系统会根据这些信息判断该用户的操作权限。
2)人事管理模块:已经登录的符合权限的用户可以在此模块中查看公司员工信息,也可以根据需要添加、修改、删除员工信息。
3)合作公司管理模块:已经登录的符合权限的用户可以在此模块中查看合作公司信息,也可以根据需要添加、修改、删除合作公司信息。
4)采购订单管理模块:已经登录的符合权限的用户可以在此模块中查看采购订单信息,也可以根据需要添加、修改、删除采购订单信息。
5)库存管理模块:已经登录的符合权限的用户可以在此模块中查看商品库存信息,也可以根据需要添加、修改、商品库存信息。
6)销售管理模块:已经登录的符合权限的用户可以在此模块中查看商品销售信息,也可以根据需要添加商品销售信息。
7)经营统计模块:已经登录的用户可以在此模块中查看最佳销售、最佳采购、最佳商品的信息。
2. 实现效果
二、部分源码
部分代码示例:
在经过了需求分析、概要设计和详细设计后,便开始了百货中心供应链管理系统的实现阶段,首先我利用Tiles结合JavaScript对页面进行布局,之后再利用Maven完成整个项目框架的搭建,利用Hibernate反向工程生成Java实体类,再使用Struts和Spring完成之前设计的业务逻辑。部分关键代码及最终程序的运行效果如下:
1)登录模块关键代码
public String logon() {
UserEntity userEntity = userService.getUserEntity(username, password);
if (userEntity != null) {
ActionContext.getContext().getSession().put("user", userEntity);
return SUCCESS;
} else {
this.addActionError("用户名或者密码不正确");
return INPUT;
}
}
2)增、删、改、查功能调用关键代码
public String list() {
if (userEntityPaginationBean == null) {
userEntityPaginationBean = new PaginationBean<UserEntity>();
}
userEntityPaginationBean = userService.pagedList(userEntityPaginationBean);
return SUCCESS;
}
public String show() {
userEntity = userService.getUserEntity(userEntity);
return SUCCESS;
}
public String add() {
return SUCCESS;
}
public String update() {
userEntity = userService.getUserEntity(userEntity);
return SUCCESS;
}
public String delete() {
try{
userService.delete(userEntity);
list();
this.addActionMessage("用户删除成功!");
}
catch(Exception e){
list();
this.addActionMessage("删除失败,不能删除已登录用户!");
}
return SUCCESS;
}
public String save() {
userService.saveOrUpdateEntity(userEntity);
list();
this.addActionMessage("用户操作成功!");
return SUCCESS;
}
3)经营统计模块关键代码
public List<Object[]> top10BestSale() {
HibernateTemplate tmpl = getHibernateTemplate();
return tmpl.execute(new HibernateCallback<List<Object[]>>() {
public List<Object[]> doInHibernate(Session session) throws HibernateException, SQLException {
SQLQuery query = session.createSQLQuery("select t1.real_name, sum(t2.amount) total_amount from tb_chain_user t1 " +
"left join tb_chain_sale t2 on t1.USER_ID = t2.user_id " +
"group by t1.real_name " +
"order by total_amount desc " +
"limit 0, 10");
List results = query.list();
return (List<Object[]>)results;
}
});
}
public List<Object[]> top10BestPurchases() {
HibernateTemplate tmpl = getHibernateTemplate();
return tmpl.execute(new HibernateCallback<List<Object[]>>() {
@SuppressWarnings("unchecked")
@Override
public List<Object[]> doInHibernate(Session session) throws HibernateException, SQLException {
SQLQuery query = session.createSQLQuery("select t1.real_name, sum(t2.amount) total_amount from tb_chain_user t1 " +
"left join tb_chain_purchase t2 on t1.USER_ID = t2.user_id " +
"group by t1.real_name " +
"order by total_amount desc " +
"limit 0, 10");
List results = query.list();
return (List<Object[]>)results;
}
});
}
public List<Object[]> top10BestProduct() {
HibernateTemplate tmpl = getHibernateTemplate();
return tmpl.execute(new HibernateCallback<List<Object[]>>() {
@SuppressWarnings("unchecked")
@Override
public List<Object[]> doInHibernate(Session session) throws HibernateException, SQLException {
SQLQuery query = session.createSQLQuery("select t1.`product`, sum(t2.`QUANTITY`) total_quantity from tb_chain_stock t1 " +
"left join tb_chain_sale t2 on t1.`COO_ID` = t2.stock_id " +
"group by t1.product " +
"order by total_quantity desc");
List results = query.list();
return (List<Object[]>)results;
}
});
}