Java 實(shí)戰(zhàn)范例之進(jìn)銷存管理系統(tǒng)的實(shí)現(xiàn)
一、項(xiàng)目簡述
本系統(tǒng)功能包括: 庫存管理,入庫管理,出庫管理,往來管理,基礎(chǔ)資料, 系統(tǒng)管理,消息中心,系統(tǒng)監(jiān)控等等。
二、項(xiàng)目運(yùn)行
環(huán)境配置: Jdk1.8 + Tomcat8.5 + Mysql + HBuilderX ( Webstorm也 行)+ Eclispe ( IntelliJ IDEA ,Eclispe,MyEclispe , Sts都支持)。
項(xiàng)目技術(shù): Springboot + Maven + Mybatis-plus+ Vue + Redis + Shiro + Druid + logback 組成,B/S模螢;,其他:fastjson, poi, Swagger-ui, quartz, lombok (簡化代碼)等






采購發(fā)票登記代碼:
/**
* @Description: 采購發(fā)票登記
* @Author: jeecg-boot
* @Version: V1.0
*/
@Api(tags="采購發(fā)票登記")
@RestController
@RequestMapping("/finance/finPurInvoice")
@Slf4j
public class FinPurInvoiceController {
@Autowired
private IFinPurInvoiceService finPurInvoiceService;
@Autowired
private IFinPurInvoiceEntryService finPurInvoiceEntryService;
/**
* 分頁列表查詢
*
* @param finPurInvoice
* @param pageNo
* @param pageSize
* @param req
* @return
*/
@AutoLog(value = "采購發(fā)票登記-分頁列表查詢")
@ApiOperation(value="采購發(fā)票登記-分頁列表查詢", notes="采購發(fā)票登記-分頁列表查詢")
@GetMapping(value = {"/list", "/list/{isRubric}"})
public Result<?> queryPageList(FinPurInvoice finPurInvoice,
@RequestParam(name="pageNo", defaultValue="1") Integer pageNo,
@RequestParam(name="pageSize", defaultValue="10") Integer pageSize,
HttpServletRequest req) {
QueryWrapper<FinPurInvoice> queryWrapper = QueryGenerator.initQueryWrapper(finPurInvoice, req.getParameterMap());
Page<FinPurInvoice> page = new Page<FinPurInvoice>(pageNo, pageSize);
IPage<FinPurInvoice> pageList = finPurInvoiceService.page(page, queryWrapper);
return Result.ok(pageList);
}
/**
* 添加
*
* @param finPurInvoicePage
* @return
*/
@AutoLog(value = "采購發(fā)票登記-添加")
@ApiOperation(value="采購發(fā)票登記-添加", notes="采購發(fā)票登記-添加")
@PostMapping(value = "/add")
public Result<?> add(@RequestBody FinPurInvoicePage finPurInvoicePage) {
FinPurInvoice finPurInvoice = new FinPurInvoice();
BeanUtils.copyProperties(finPurInvoicePage, finPurInvoice);
finPurInvoiceService.saveMain(finPurInvoice, finPurInvoicePage.getFinPurInvoiceEntryList());
return Result.ok("添加成功!");
}
/**
* 編輯
*
* @param finPurInvoicePage
* @return
*/
@AutoLog(value = "采購發(fā)票登記-編輯")
@ApiOperation(value="采購發(fā)票登記-編輯", notes="采購發(fā)票登記-編輯")
@PutMapping(value = "/edit")
public Result<?> edit(@RequestBody FinPurInvoicePage finPurInvoicePage) {
FinPurInvoice finPurInvoice = new FinPurInvoice();
BeanUtils.copyProperties(finPurInvoicePage, finPurInvoice);
FinPurInvoice finPurInvoiceEntity = finPurInvoiceService.getById(finPurInvoice.getId());
if(finPurInvoiceEntity==null) {
return Result.error("未找到對應(yīng)數(shù)據(jù)");
}
finPurInvoiceService.updateMain(finPurInvoice, finPurInvoicePage.getFinPurInvoiceEntryList());
return Result.ok("編輯成功!");
}
/**
* 通過id刪除
*
* @param id
* @return
*/
@AutoLog(value = "采購發(fā)票登記-通過id刪除")
@ApiOperation(value="采購發(fā)票登記-通過id刪除", notes="采購發(fā)票登記-通過id刪除")
@DeleteMapping(value = "/delete")
public Result<?> delete(@RequestParam(name="id",required=true) String id) {
finPurInvoiceService.delMain(id);
return Result.ok("刪除成功!");
}
/**
* 批量刪除
*
* @param ids
* @return
*/
@AutoLog(value = "采購發(fā)票登記-批量刪除")
@ApiOperation(value="采購發(fā)票登記-批量刪除", notes="采購發(fā)票登記-批量刪除")
@DeleteMapping(value = "/deleteBatch")
public Result<?> deleteBatch(@RequestParam(name="ids",required=true) String ids) {
this.finPurInvoiceService.delBatchMain(Arrays.asList(ids.split(",")));
return Result.ok("批量刪除成功!");
}
/**
* 通過id查詢
*
* @param id
* @return
*/
@AutoLog(value = "采購發(fā)票登記-通過id查詢")
@ApiOperation(value="采購發(fā)票登記-通過id查詢", notes="采購發(fā)票登記-通過id查詢")
@GetMapping(value = "/queryById")
public Result<?> queryById(@RequestParam(name="id",required=true) String id) {
FinPurInvoice finPurInvoice = finPurInvoiceService.getById(id);
if(finPurInvoice==null) {
return Result.error("未找到對應(yīng)數(shù)據(jù)");
}
return Result.ok(finPurInvoice);
}
/**
* 通過id查詢
*
* @param id
* @return
*/
@AutoLog(value = "明細(xì)通過主表ID查詢")
@ApiOperation(value="明細(xì)主表ID查詢", notes="明細(xì)-通主表ID查詢")
@GetMapping(value = "/queryFinPurInvoiceEntryByMainId")
public Result<?> queryFinPurInvoiceEntryListByMainId(@RequestParam(name="id",required=true) String id) {
List<FinPurInvoiceEntry> finPurInvoiceEntryList = finPurInvoiceEntryService.selectByMainId(id);
return Result.ok(finPurInvoiceEntryList);
}
/**
* 導(dǎo)出excel
*
* @param request
* @param finPurInvoice
*/
@RequestMapping(value = {"/exportXls", "/exportXls/{isRubric}"})
public ModelAndView exportXls(HttpServletRequest request, FinPurInvoice finPurInvoice) {
// Step.1 組裝查詢條件查詢數(shù)據(jù)
QueryWrapper<FinPurInvoice> queryWrapper = QueryGenerator.initQueryWrapper(finPurInvoice, request.getParameterMap());
LoginUser sysUser = (LoginUser) SecurityUtils.getSubject().getPrincipal();
//Step.2 獲取導(dǎo)出數(shù)據(jù)
List<FinPurInvoice> queryList = finPurInvoiceService.list(queryWrapper);
// 過濾選中數(shù)據(jù)
String selections = request.getParameter("selections");
List<FinPurInvoice> finPurInvoiceList = new ArrayList<FinPurInvoice>();
if(oConvertUtils.isEmpty(selections)) {
finPurInvoiceList = queryList;
}else {
List<String> selectionList = Arrays.asList(selections.split(","));
finPurInvoiceList = queryList.stream().filter(item -> selectionList.contains(item.getId())).collect(Collectors.toList());
}
// Step.3 組裝pageList
List<FinPurInvoicePage> pageList = new ArrayList<FinPurInvoicePage>();
for (FinPurInvoice main : finPurInvoiceList) {
FinPurInvoicePage vo = new FinPurInvoicePage();
BeanUtils.copyProperties(main, vo);
List<FinPurInvoiceEntry> finPurInvoiceEntryList = finPurInvoiceEntryService.selectByMainId(main.getId());
vo.setFinPurInvoiceEntryList(finPurInvoiceEntryList);
pageList.add(vo);
}
// Step.4 AutoPoi 導(dǎo)出Excel
ModelAndView mv = new ModelAndView(new JeecgEntityExcelView());
mv.addObject(NormalExcelConstants.FILE_NAME, "采購發(fā)票登記列表");
mv.addObject(NormalExcelConstants.CLASS, FinPurInvoicePage.class);
mv.addObject(NormalExcelConstants.PARAMS, new ExportParams("采購發(fā)票登記數(shù)據(jù)", "導(dǎo)出人:"+sysUser.getRealname(), "采購發(fā)票登記"));
mv.addObject(NormalExcelConstants.DATA_LIST, pageList);
return mv;
}
/**
* 通過excel導(dǎo)入數(shù)據(jù)
*
* @param request
* @param response
* @return
*/
@RequestMapping(value = "/importExcel", method = RequestMethod.POST)
public Result<?> importExcel(HttpServletRequest request, HttpServletResponse response) {
MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
Map<String, MultipartFile> fileMap = multipartRequest.getFileMap();
for (Map.Entry<String, MultipartFile> entity : fileMap.entrySet()) {
MultipartFile file = entity.getValue();// 獲取上傳文件對象
ImportParams params = new ImportParams();
params.setTitleRows(2);
params.setHeadRows(1);
params.setNeedSave(true);
try {
List<FinPurInvoicePage> list = ExcelImportUtil.importExcel(file.getInputStream(), FinPurInvoicePage.class, params);
for (FinPurInvoicePage page : list) {
FinPurInvoice po = new FinPurInvoice();
BeanUtils.copyProperties(page, po);
finPurInvoiceService.saveMain(po, page.getFinPurInvoiceEntryList());
}
return Result.ok("文件導(dǎo)入成功!數(shù)據(jù)行數(shù):" + list.size());
} catch (Exception e) {
log.error(e.getMessage(),e);
return Result.error("文件導(dǎo)入失敗:"+e.getMessage());
} finally {
try {
file.getInputStream().close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
return Result.ok("文件導(dǎo)入失??!");
}
@AutoLog(value = "采購發(fā)票登記-通過id審核")
@ApiOperation(value="采購發(fā)票登記-通過id審核", notes="采購發(fā)票登記-通過id審核")
@PutMapping(value = "/approve")
public Result<?> approve(@RequestBody JSONObject json) {
finPurInvoiceService.approve(json.getString("id"));
return Result.ok("審核通過!");
}
}
到此這篇關(guān)于Java 實(shí)戰(zhàn)范例之進(jìn)銷存管理系統(tǒng)的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Java 進(jìn)銷存管理系統(tǒng)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Java 實(shí)戰(zhàn)項(xiàng)目之精品養(yǎng)老院管理系統(tǒng)的實(shí)現(xiàn)流程
- Java 實(shí)戰(zhàn)項(xiàng)目之精美物流管理系統(tǒng)的實(shí)現(xiàn)流程
- Java 實(shí)戰(zhàn)練手項(xiàng)目之校園超市管理系統(tǒng)的實(shí)現(xiàn)流程
- Java 實(shí)戰(zhàn)項(xiàng)目之CRM客戶管理系統(tǒng)的實(shí)現(xiàn)流程
- Java 實(shí)戰(zhàn)項(xiàng)目錘煉之嘟嘟健身房管理系統(tǒng)的實(shí)現(xiàn)流程
- Java 實(shí)戰(zhàn)練手項(xiàng)目之酒店管理系統(tǒng)的實(shí)現(xiàn)流程
- Java 實(shí)戰(zhàn)項(xiàng)目之倉庫管理系統(tǒng)的實(shí)現(xiàn)流程
- Java 實(shí)戰(zhàn)項(xiàng)目錘煉之小區(qū)物業(yè)管理系統(tǒng)的實(shí)現(xiàn)流程
- Java 實(shí)戰(zhàn)范例之員工管理系統(tǒng)的實(shí)現(xiàn)
- Java?實(shí)戰(zhàn)項(xiàng)目之學(xué)生信息管理系統(tǒng)的實(shí)現(xiàn)流程
相關(guān)文章
Java使用JSONObject操作json實(shí)例解析
這篇文章主要介紹了Java使用JSONObject操作json,結(jié)合實(shí)例形式較為詳細(xì)的分析了Java使用JSONObject解析json數(shù)據(jù)相關(guān)原理、使用技巧與操作注意事項(xiàng),需要的朋友可以參考下2020-04-04
Java 實(shí)戰(zhàn)項(xiàng)目基于遺傳算法學(xué)校排課系統(tǒng)的實(shí)現(xiàn)流程
讀萬卷書不如行萬里路,只學(xué)書上的理論是遠(yuǎn)遠(yuǎn)不夠的,只有在實(shí)戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用java+Springboot+Maven+mybatis+Vue+Mysql實(shí)現(xiàn)一個基于遺傳算法的學(xué)校排課系統(tǒng),大家可以在過程中查缺補(bǔ)漏,提升水平2021-11-11
使用springboot activiti關(guān)閉驗(yàn)證自動部署方式
這篇文章主要介紹了使用springboot activiti關(guān)閉驗(yàn)證自動部署方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09
Java8 Collectors求和功能的自定義擴(kuò)展操作
這篇文章主要介紹了Java8 Collectors求和功能的自定義擴(kuò)展操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02
關(guān)于feign調(diào)用的參數(shù)傳遞問題(@RequestBody和@RequestParam)
這篇文章主要介紹了關(guān)于feign調(diào)用的參數(shù)傳遞問題(@RequestBody和@RequestParam),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03
Java Socket編程心跳包創(chuàng)建實(shí)例解析
這篇文章主要介紹了Java Socket編程心跳包創(chuàng)建實(shí)例解析,具有一定借鑒價值,需要的朋友可以參考下2017-12-12

