From d2038a623e02c2d7bb6b95a908832c0432adf2f0 Mon Sep 17 00:00:00 2001
From: huminmin <mac@MacBook-Pro.local>
Date: 星期四, 21 五月 2026 13:46:21 +0800
Subject: [PATCH] 增加日志

---
 src/main/java/com/ruoyi/home/controller/HomeController.java                              |   35 ++++++++
 src/main/java/com/ruoyi/sales/controller/InvoiceLedgerController.java                    |   14 +++
 src/main/java/com/ruoyi/staff/controller/StaffContractController.java                    |    3 
 src/main/java/com/ruoyi/staff/controller/StaffLeaveController.java                       |    7 +
 src/main/java/com/ruoyi/quality/controller/QualityInspectParamController.java            |    5 +
 src/main/java/com/ruoyi/sales/controller/SalesLedgerController.java                      |    4 +
 src/main/java/com/ruoyi/staff/controller/PersonalShiftController.java                    |    7 +
 src/main/java/com/ruoyi/staff/controller/StaffSchedulingController.java                  |    5 +
 src/main/java/com/ruoyi/sales/controller/SalesLedgerProductController.java               |    5 +
 src/main/java/com/ruoyi/quality/controller/QualityReportController.java                  |    8 ++
 src/main/java/com/ruoyi/staff/controller/HolidayApplicationController.java               |    6 +
 src/main/java/com/ruoyi/quality/controller/QualityTestStandardController.java            |   10 ++
 src/main/java/com/ruoyi/staff/controller/AnalyticsController.java                        |    5 +
 src/main/java/com/ruoyi/staff/controller/PersonalAttendanceLocationConfigController.java |    5 +
 src/main/java/com/ruoyi/staff/controller/StaffOnJobController.java                       |    9 ++
 src/main/java/com/ruoyi/staff/controller/SchemeApplicableStaffController.java            |    1 
 src/main/java/com/ruoyi/sales/controller/ReceiptPaymentController.java                   |   12 +++
 src/main/java/com/ruoyi/quality/controller/QualityInspectFileController.java             |    5 +
 src/main/java/com/ruoyi/quality/controller/QualityInspectController.java                 |   11 ++
 src/main/java/com/ruoyi/quality/controller/QualityUnqualifiedController.java             |   10 ++
 src/main/java/com/ruoyi/staff/controller/BankController.java                             |    1 
 src/main/java/com/ruoyi/quality/controller/QualityTestStandardBindingController.java     |    5 +
 src/main/java/com/ruoyi/quality/controller/QualityTestStandardParamController.java       |    6 +
 src/main/java/com/ruoyi/staff/controller/StaffSalaryMainController.java                  |    2 
 src/main/java/com/ruoyi/staff/controller/PersonalAttendanceRecordsController.java        |    6 +
 25 files changed, 187 insertions(+), 0 deletions(-)

diff --git a/src/main/java/com/ruoyi/home/controller/HomeController.java b/src/main/java/com/ruoyi/home/controller/HomeController.java
index fcdfc16..de31ac6 100644
--- a/src/main/java/com/ruoyi/home/controller/HomeController.java
+++ b/src/main/java/com/ruoyi/home/controller/HomeController.java
@@ -44,6 +44,7 @@
 
     @GetMapping("/approveAndDeviceTodos")
     @ApiOperation("瀹℃壒鍗忓悓锛岃澶囨姤淇緟鍔炰簨椤�")
+    @Log(title = "瀹℃壒鍗忓悓锛岃澶囨姤淇緟鍔炰簨椤�", businessType = BusinessType.OTHER)
     public AjaxResult approveAndDeviceTodos(){
         Map<String, Object> map = homeService.approveAndDeviceTodos();
         return AjaxResult.success(map);
@@ -51,6 +52,7 @@
 
     @GetMapping("/noticesCount")
     @ApiOperation("鏈繃鏈熺殑鍏憡鏁伴噺")
+    @Log(title = "鏈繃鏈熺殑鍏憡鏁伴噺", businessType = BusinessType.OTHER)
     public AjaxResult noticesCount(){
         Long count = homeService.noticesCount();
         return AjaxResult.success(count);
@@ -58,6 +60,7 @@
 
     @GetMapping("/deptStaffDistribution")
     @ApiOperation("鍚勯儴闂ㄤ汉鍛樺垎甯�")
+    @Log(title = "鍚勯儴闂ㄤ汉鍛樺垎甯�", businessType = BusinessType.OTHER)
     public AjaxResult deptStaffDistribution() {
         DeptStaffDistributionDto dto = homeService.deptStaffDistribution();
         return AjaxResult.success(dto);
@@ -65,6 +68,7 @@
 
     @GetMapping("/summaryStatistics")
     @ApiOperation("鍛樺伐-瀹㈡埛-渚涘簲鍟嗘�绘暟")
+    @Log(title = "鍛樺伐-瀹㈡埛-渚涘簲鍟嗘�绘暟", businessType = BusinessType.OTHER)
     public AjaxResult summaryStatistics() {
         HomeSummaryDto homeSummaryDto = homeService.summaryStatistics();
         return AjaxResult.success(homeSummaryDto);
@@ -73,6 +77,7 @@
     /********************************************************钀ラ攢閲囪喘绫�**************************************************/
     @GetMapping("/supplierPurchaseRanking")
     @ApiOperation("渚涘簲鍟嗛噰璐帓鍚�")
+    @Log(title = "渚涘簲鍟嗛噰璐帓鍚�", businessType = BusinessType.OTHER)
     public AjaxResult supplierPurchaseRanking(@DefaultType Integer type) {
         List<SupplierPurchaseRankingDto> list = homeService.supplierPurchaseRanking(type);
         return AjaxResult.success(list);
@@ -80,6 +85,7 @@
 
     @GetMapping("/customerRevenueAnalysis")
     @ApiOperation("瀹㈡埛钀ユ敹璐$尞鏁板�煎垎鏋�")
+    @Log(title = "瀹㈡埛钀ユ敹璐$尞鏁板�煎垎鏋�", businessType = BusinessType.OTHER)
     public AjaxResult customerRevenueAnalysis(Long customerId, @DefaultType Integer type) {
         CustomerRevenueAnalysisDto dto = homeService.customerRevenueAnalysis(customerId, type);
         return AjaxResult.success(dto);
@@ -87,6 +93,7 @@
 
     @GetMapping("/customerContributionRanking")
     @ApiOperation("瀹㈡埛閲戦璐$尞鎺掑悕")
+    @Log(title = "瀹㈡埛閲戦璐$尞鎺掑悕", businessType = BusinessType.OTHER)
     public AjaxResult customerContributionRanking(@DefaultType Integer type) {
         List<CustomerContributionRankingDto> list = homeService.customerContributionRanking(type);
         return AjaxResult.success(list);
@@ -94,6 +101,7 @@
 
     @GetMapping("/productSalesAnalysis")
     @ApiOperation("鍚勪骇鍝侀攢鍞噾棰濆垎鏋�")
+    @Log(title = "鍚勪骇鍝侀攢鍞噾棰濆垎鏋�", businessType = BusinessType.OTHER)
     public AjaxResult productSalesAnalysis() {
         List<MapDto> list = homeService.productSalesAnalysis();
         return AjaxResult.success(list);
@@ -101,6 +109,7 @@
 
     @GetMapping("/rawMaterialPurchaseAmountRatio")
     @ApiOperation("鍘熸潗鏂欓噰璐噾棰濆崰姣�")
+    @Log(title = "鍘熸潗鏂欓噰璐噾棰濆崰姣�", businessType = BusinessType.OTHER)
     public AjaxResult rawMaterialPurchaseAmountRatio(){
         List<MapDto> list = homeService.rawMaterialPurchaseAmountRatio();
         return AjaxResult.success(list);
@@ -125,6 +134,7 @@
     /********************************************************鐢熶骇绫�*****************************************************/
     @GetMapping("/inputOutputAnalysis")
     @ApiOperation("鎶曞叆浜у嚭鍒嗘瀽")
+    @Log(title = "鎶曞叆浜у嚭鍒嗘瀽", businessType = BusinessType.OTHER)
     public AjaxResult inputOutputAnalysis(@DefaultType Integer type){
       List<InputOutputAnalysisDto> list = homeService.inputOutputAnalysis(type);
         return AjaxResult.success(list);
@@ -132,6 +142,7 @@
 
     @GetMapping("/processOutputAnalysis")
     @ApiOperation("宸ュ簭浜у嚭鍒嗘瀽")
+    @Log(title = "宸ュ簭浜у嚭鍒嗘瀽", businessType = BusinessType.OTHER)
     public AjaxResult processOutputAnalysis(@DefaultType Integer type){
         List<MapDto> list = homeService.processOutputAnalysis(type);
         return AjaxResult.success(list);
@@ -139,6 +150,7 @@
 
     @GetMapping("/workOrderEfficiencyAnalysis")
     @ApiOperation("宸ュ崟鎵ц鏁堢巼鍒嗘瀽")
+    @Log(title = "宸ュ崟鎵ц鏁堢巼鍒嗘瀽", businessType = BusinessType.OTHER)
     public AjaxResult workOrderEfficiencyAnalysis(@DefaultType Integer type){
         List<WorkOrderEfficiencyDto> list = homeService.workOrderEfficiencyAnalysis(type);
         return AjaxResult.success(list);
@@ -146,6 +158,7 @@
 
     @GetMapping("/productionAccountingAnalysis")
     @ApiOperation("鐢熶骇鏍哥畻鍒嗘瀽")
+    @Log(title = "鐢熶骇鏍哥畻鍒嗘瀽", businessType = BusinessType.OTHER)
     public AjaxResult productionAccountingAnalysis(@DefaultType Integer type){
         List<ProductionAccountingDto> list   = homeService.productionAccountingAnalysis(type);
         return AjaxResult.success(list);
@@ -153,12 +166,14 @@
 
     @GetMapping("/orderCount")
     @ApiOperation("璁㈠崟鏁�")
+    @Log(title = "璁㈠崟鏁�", businessType = BusinessType.OTHER)
     public AjaxResult orderCount(){
         return AjaxResult.success(homeService.orderCount());
     }
 
     @GetMapping("/progressStatistics")
     @ApiOperation("鍚勭敓浜ц鍗曠殑瀹屾垚杩涘害缁熻")
+    @Log(title = "鍚勭敓浜ц鍗曠殑瀹屾垚杩涘害缁熻", businessType = BusinessType.OTHER)
     public AjaxResult progressStatistics(){
         ProductionProgressDto productionProgressDto = homeService.productionProgress();
         return AjaxResult.success(productionProgressDto);
@@ -166,6 +181,7 @@
 
     @GetMapping("/workInProcessTurnover")
     @ApiOperation("鍦ㄥ埗鍝佸懆杞儏鍐�")
+    @Log(title = "鍦ㄥ埗鍝佸懆杞儏鍐�", businessType = BusinessType.OTHER)
     public AjaxResult workInProcessTurnover(){
         ProductionTurnoverDto productionTurnoverDto = homeService.workInProcessTurnover();
         return AjaxResult.success(productionTurnoverDto);
@@ -173,6 +189,7 @@
 
     @GetMapping("/processDataProductionStatistics")
     @ApiOperation("宸ュ簭鏁版嵁鐢熶骇缁熻鏁版嵁")
+    @Log(title = "宸ュ簭鏁版嵁鐢熶骇缁熻鏁版嵁", businessType = BusinessType.OTHER)
     public AjaxResult processDataProductionStatistics(@DefaultType Integer type,@RequestParam(required = false) List<Long> processIds) {
         List<processDataProductionStatisticsDto> list = homeService.processDataProductionStatistics(type, processIds);
         return AjaxResult.success(list);
@@ -181,24 +198,28 @@
     /********************************************************璐ㄩ噺绫�*****************************************************/
     @GetMapping("/rawMaterialDetection")
     @ApiOperation("鍘熸潗鏂欐娴�")
+    @Log(title = "鍘熸潗鏂欐娴�", businessType = BusinessType.OTHER)
     public AjaxResult rawMaterialDetection(@DefaultType Integer type){
         return AjaxResult.success(homeService.rawMaterialDetection(type));
     }
 
     @GetMapping("/processDetection")
     @ApiOperation("杩囩▼妫�娴�")
+    @Log(title = "杩囩▼妫�娴�", businessType = BusinessType.OTHER)
     public AjaxResult processDetection(@DefaultType Integer type){
         return AjaxResult.success(homeService.processDetection(type));
     }
 
     @GetMapping("/factoryDetection")
     @ApiOperation("鎴愬搧鍑哄巶妫�娴�")
+    @Log(title = "鎴愬搧鍑哄巶妫�娴�", businessType = BusinessType.OTHER)
     public AjaxResult factoryDetection(@DefaultType Integer type){
         return AjaxResult.success(homeService.factoryDetection(type));
     }
 
     @GetMapping("/qualityInspectionCount")
     @ApiOperation("璐ㄩ噺妫�楠屾暟閲�")
+    @Log(title = "璐ㄩ噺妫�楠屾暟閲�", businessType = BusinessType.OTHER)
     public AjaxResult qualityInspectionCount(){
         QualityInspectionCountDto qualityInspectionCountDto = homeService.qualityInspectionCount();
         return AjaxResult.success(qualityInspectionCountDto);
@@ -206,6 +227,7 @@
 
     @GetMapping("/nonComplianceWarning")
     @ApiOperation("涓嶅悎鏍奸璀�")
+    @Log(title = "涓嶅悎鏍奸璀�", businessType = BusinessType.OTHER)
     public AjaxResult nonComplianceWarning(){
         NonComplianceWarningDto nonComplianceWarningDto = homeService.nonComplianceWarning();
         return AjaxResult.success(nonComplianceWarningDto);
@@ -213,6 +235,7 @@
 
     @GetMapping("/completedInspectionCount")
     @ApiOperation("瀹屾垚妫�楠屾暟")
+    @Log(title = "瀹屾垚妫�楠屾暟", businessType = BusinessType.OTHER)
     public AjaxResult completedInspectionCount(){
         List<CompletedInspectionCountDto> list = homeService.completedInspectionCount();
         return AjaxResult.success(list);
@@ -220,6 +243,7 @@
 
     @GetMapping("/unqualifiedProductRanking")
     @ApiOperation("涓嶅悎鏍间骇鍝佹帓鍚�")
+    @Log(title = "涓嶅悎鏍间骇鍝佹帓鍚�", businessType = BusinessType.OTHER)
     public AjaxResult unqualifiedProductRanking(){
         List<UnqualifiedProductRankDto> list = homeService.unqualifiedProductRanking();
         return AjaxResult.success(list);
@@ -227,6 +251,7 @@
 
     @GetMapping("/unqualifiedProductProcessingAnalysis")
     @ApiOperation("涓嶅悎鏍兼鍝佸鐞嗗垎鏋�")
+    @Log(title = "涓嶅悎鏍兼鍝佸鐞嗗垎鏋�", businessType = BusinessType.OTHER)
     public AjaxResult unqualifiedProductProcessingAnalysis(){
         List<MapDto> list = homeService.unqualifiedProductProcessingAnalysis();
         return AjaxResult.success(list);
@@ -242,6 +267,7 @@
 
     @GetMapping("/qualityInspectionStatistics")
     @ApiOperation("璐ㄩ噺缁熻")
+    @Log(title = "璐ㄩ噺缁熻", businessType = BusinessType.OTHER)
     public AjaxResult qualityInspectionStatistics(@DefaultType Integer type) {
        QualityStatisticsDto  dto = homeService.qualityInspectionStatistics(type);
         return AjaxResult.success(dto);
@@ -250,6 +276,7 @@
     /********************************************************璐㈠姟绫�*****************************************************/
     @GetMapping("/incomeExpenseAnalysis")
     @ApiOperation("鏀敹瀵规瘮鍒嗘瀽")
+    @Log(title = "鏀敹瀵规瘮鍒嗘瀽", businessType = BusinessType.OTHER)
     public AjaxResult incomeExpenseAnalysis(@DefaultType Integer type) {
         List<Map<String, Object>> result = homeService.incomeExpenseAnalysis(type);
         return AjaxResult.success(result);
@@ -257,6 +284,7 @@
 
     @GetMapping("/profitTrendAnalysis")
     @ApiOperation("鍒╂鼎瓒嬪娍鍒嗘瀽")
+    @Log(title = "鍒╂鼎瓒嬪娍鍒嗘瀽", businessType = BusinessType.OTHER)
     public AjaxResult profitTrendAnalysis(){
         List<MapDto> list = homeService.profitTrendAnalysis();
         return AjaxResult.success(list);
@@ -264,6 +292,7 @@
 
     @GetMapping("/expenseCompositionAnalysis")
     @ApiOperation("鏋勬垚鍒嗘瀽")
+    @Log(title = "鏋勬垚鍒嗘瀽", businessType = BusinessType.OTHER)
     public AjaxResult expenseCompositionAnalysis(@DefaultType Integer type) {
         List<MapDto> list = homeService.expenseCompositionAnalysis(type);
         return AjaxResult.success(list);
@@ -271,6 +300,7 @@
 
     @GetMapping("/monthlyIncome")
     @ApiOperation("鏈堝害鏀跺叆")
+    @Log(title = "鏈堝害鏀跺叆", businessType = BusinessType.OTHER)
     public AjaxResult monthlyIncome(){
         MonthlyIncomeDto dto = homeService.monthlyIncome();
         return AjaxResult.success(dto);
@@ -278,6 +308,7 @@
 
     @GetMapping("/monthlyExpenditure")
     @ApiOperation("鏈堝害鏀嚭")
+    @Log(title = "鏈堝害鏀嚭", businessType = BusinessType.OTHER)
     public AjaxResult monthlyExpenditure(){
         MonthlyExpenditureDto dto = homeService.monthlyExpenditure();
         return AjaxResult.success(dto);
@@ -295,6 +326,7 @@
 
     @GetMapping("/productCategoryDistribution")
     @ApiOperation("浜у搧澶х被鍒嗗竷")
+    @Log(title = "浜у搧澶х被鍒嗗竷", businessType = BusinessType.OTHER)
     public AjaxResult productCategoryDistribution() {
         ProductCategoryDistributionDto dto = homeService.productCategoryDistribution();
         return AjaxResult.success(dto);
@@ -302,6 +334,7 @@
 
     @GetMapping("/salesPurchaseStorageProductCount")
     @ApiOperation("閿�鍞�-閲囪喘-鍌ㄥ瓨浜у搧鏁�")
+    @Log(title = "閿�鍞�-閲囪喘-鍌ㄥ瓨浜у搧鏁�", businessType = BusinessType.OTHER)
     public AjaxResult salesPurchaseStorageProductCount(){
         List<MapDto> list = homeService.salesPurchaseStorageProductCount();
         return AjaxResult.success(list);
@@ -309,6 +342,7 @@
 
     @GetMapping("/productInOutAnalysis")
     @ApiOperation("浜у搧鍑哄叆搴撳垎鏋�")
+    @Log(title = "浜у搧鍑哄叆搴撳垎鏋�", businessType = BusinessType.OTHER)
     public AjaxResult productInOutAnalysis(@DefaultType Integer type){
         List<Map<String, Object>> result = homeService.productInOutAnalysis(type);
         return AjaxResult.success(result);
@@ -316,6 +350,7 @@
 
     @GetMapping("/productTurnoverDays")
     @ApiOperation("浜у搧鍛ㄨ浆澶╂暟")
+    @Log(title = "浜у搧鍛ㄨ浆澶╂暟", businessType = BusinessType.OTHER)
     public AjaxResult productTurnoverDays(){
         List<MapDto> list = homeService.productTurnoverDays();
         return AjaxResult.success(list);
diff --git a/src/main/java/com/ruoyi/quality/controller/QualityInspectController.java b/src/main/java/com/ruoyi/quality/controller/QualityInspectController.java
index 4ccba82..22b049f 100644
--- a/src/main/java/com/ruoyi/quality/controller/QualityInspectController.java
+++ b/src/main/java/com/ruoyi/quality/controller/QualityInspectController.java
@@ -4,6 +4,8 @@
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.ruoyi.common.enums.StockInQualifiedRecordTypeEnum;
 import com.ruoyi.common.enums.StockOutQualifiedRecordTypeEnum;
+import com.ruoyi.framework.aspectj.lang.annotation.Log;
+import com.ruoyi.framework.aspectj.lang.enums.BusinessType;
 import com.ruoyi.framework.web.domain.AjaxResult;
 import com.ruoyi.procurementrecord.service.ProcurementRecordService;
 import com.ruoyi.procurementrecord.utils.StockUtils;
@@ -55,6 +57,7 @@
      */
     @PostMapping("/add")
     @ApiOperation("鏂板妫�楠�")
+    @Log(title = "鏂板妫�楠�", businessType = BusinessType.INSERT)
     public AjaxResult add(@RequestBody QualityInspectDto qualityInspectDto) {
         return AjaxResult.success(qualityInspectService.add(qualityInspectDto));
     }
@@ -66,6 +69,7 @@
      */
     @DeleteMapping("/del")
     @ApiOperation("鍒犻櫎妫�楠�")
+    @Log(title = "鍒犻櫎妫�楠�", businessType = BusinessType.DELETE)
     public AjaxResult delQualityInspect(@RequestBody List<Integer> ids) {
         if(CollectionUtils.isEmpty(ids)){
             return AjaxResult.error("璇烽�夋嫨鑷冲皯涓�鏉℃暟鎹�");
@@ -94,6 +98,7 @@
      */
     @GetMapping("/{id}")
     @ApiOperation("妫�楠屽崟璇︽儏")
+    @Log(title = "妫�楠屽崟璇︽儏", businessType = BusinessType.OTHER)
     public AjaxResult QualityInspectDetail(@PathVariable("id") Integer id) {
         return AjaxResult.success(qualityInspectService.getDetailById(id));
     }
@@ -105,6 +110,7 @@
      */
     @PostMapping("/update")
     @ApiOperation("淇敼妫�楠屽崟")
+    @Log(title = "淇敼妫�楠屽崟", businessType = BusinessType.UPDATE)
     public AjaxResult update(@RequestBody QualityInspectDto qualityInspectDto) {
         return AjaxResult.success(qualityInspectService.updateQualityInspect(qualityInspectDto));
     }
@@ -117,6 +123,7 @@
      */
     @GetMapping("/listPage")
     @ApiOperation("妫�楠屽崟鍒嗛〉鏌ヨ")
+    @Log(title = "妫�楠屽崟鍒嗛〉鏌ヨ", businessType = BusinessType.OTHER)
     public AjaxResult qualityInspectListPage(Page page, QualityInspect qualityInspect) {
         return AjaxResult.success(qualityInspectService.qualityInspectListPage(page, qualityInspect));
     }
@@ -128,6 +135,7 @@
      */
     @PostMapping("/export")
     @ApiOperation("瀵煎嚭妫�楠屽崟")
+    @Log(title = "瀵煎嚭妫�楠屽崟", businessType = BusinessType.EXPORT)
     public void qualityInspectExport(HttpServletResponse response,QualityInspect qualityInspect) {
         qualityInspectService.qualityInspectExport(response, qualityInspect);
     }
@@ -139,6 +147,7 @@
      */
     @PostMapping("/submit")
     @ApiOperation("鎻愪氦妫�楠屽崟")
+    @Log(title = "鎻愪氦妫�楠屽崟", businessType = BusinessType.UPDATE)
     public AjaxResult submit(@RequestBody QualityInspect qualityInspect) {
         return AjaxResult.success(qualityInspectService.submit(qualityInspect));
     }
@@ -150,6 +159,7 @@
      */
     @PostMapping("/down")
     @ApiOperation("涓嬭浇妫�楠屽崟闄勪欢")
+    @Log(title = "涓嬭浇妫�楠屽崟闄勪欢", businessType = BusinessType.OTHER)
     public void down(HttpServletResponse response,@RequestBody QualityInspect qualityInspect) {
         qualityInspectService.down(response, qualityInspect);
     }
@@ -161,6 +171,7 @@
      */
     @PostMapping("/downOutReport")
     @ApiOperation("涓嬭浇鍑哄簱妫�楠屾姤鍛�")
+    @Log(title = "涓嬭浇鍑哄簱妫�楠屾姤鍛�", businessType = BusinessType.OTHER)
     public void downOutReport(HttpServletResponse response, @RequestBody QualityInspect qualityInspect) {
         qualityInspectService.downOutReport(response, qualityInspect);
     }
diff --git a/src/main/java/com/ruoyi/quality/controller/QualityInspectFileController.java b/src/main/java/com/ruoyi/quality/controller/QualityInspectFileController.java
index 48d8391..e836e5f 100644
--- a/src/main/java/com/ruoyi/quality/controller/QualityInspectFileController.java
+++ b/src/main/java/com/ruoyi/quality/controller/QualityInspectFileController.java
@@ -2,6 +2,8 @@
 
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.ruoyi.framework.aspectj.lang.annotation.Log;
+import com.ruoyi.framework.aspectj.lang.enums.BusinessType;
 import com.ruoyi.framework.web.domain.AjaxResult;
 import com.ruoyi.quality.pojo.QualityInspect;
 import com.ruoyi.quality.pojo.QualityInspectFile;
@@ -40,6 +42,7 @@
      */
     @PostMapping("/add")
     @ApiOperation("鏂板妫�楠岄檮浠�")
+    @Log(title = "鏂板妫�楠岄檮浠�", businessType = BusinessType.INSERT)
     public AjaxResult add(@RequestBody QualityInspectFile qualityInspectFile) {
         return AjaxResult.success(qualityInspectFileService.save(qualityInspectFile));
     }
@@ -51,6 +54,7 @@
      */
     @DeleteMapping("/del")
     @ApiOperation("鍒犻櫎妫�楠岄檮浠�")
+    @Log(title = "鍒犻櫎妫�楠岄檮浠�", businessType = BusinessType.DELETE)
     public AjaxResult delQualityUnqualified(@RequestBody List<Integer> ids) {
         if(CollectionUtils.isEmpty(ids)){
             return AjaxResult.error("璇烽�夋嫨鑷冲皯涓�鏉℃暟鎹�");
@@ -67,6 +71,7 @@
      */
     @GetMapping("/listPage")
     @ApiOperation("妫�楠岄檮浠跺垎椤垫煡璇�")
+    @Log(title = "妫�楠岄檮浠跺垎椤垫煡璇�", businessType = BusinessType.OTHER)
     public AjaxResult qualityInspectFileListPage(Page page, QualityInspectFile qualityInspectFile) {
         return AjaxResult.success(qualityInspectFileService.qualityInspectFileListPage(page, qualityInspectFile));
     }
diff --git a/src/main/java/com/ruoyi/quality/controller/QualityInspectParamController.java b/src/main/java/com/ruoyi/quality/controller/QualityInspectParamController.java
index be5d843..aff92e5 100644
--- a/src/main/java/com/ruoyi/quality/controller/QualityInspectParamController.java
+++ b/src/main/java/com/ruoyi/quality/controller/QualityInspectParamController.java
@@ -2,6 +2,8 @@
 
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.ruoyi.framework.aspectj.lang.annotation.Log;
+import com.ruoyi.framework.aspectj.lang.enums.BusinessType;
 import com.ruoyi.framework.web.domain.AjaxResult;
 import com.ruoyi.quality.pojo.QualityInspect;
 import com.ruoyi.quality.pojo.QualityInspectFile;
@@ -36,6 +38,7 @@
      */
     @GetMapping("/{inspectId}")
     @ApiOperation("妫�楠屽弬鏁伴」璇︽儏")
+    @Log(title = "妫�楠屽弬鏁伴」璇︽儏", businessType = BusinessType.OTHER)
     public AjaxResult QualityInspectParamDetail(@PathVariable("inspectId") Integer inspectId) {
         return AjaxResult.success(qualityInspectParamService.qualityInspectParamDetail(inspectId));
     }
@@ -48,6 +51,7 @@
      */
     @PostMapping("/update")
     @ApiOperation("淇敼妫�楠屽弬鏁伴」")
+    @Log(title = "淇敼妫�楠屽弬鏁伴」", businessType = BusinessType.UPDATE)
     public AjaxResult update(@RequestBody List<QualityInspectParam> qualityInspectParams) {
         return AjaxResult.success(qualityInspectParamService.updateBatchById(qualityInspectParams));
     }
@@ -59,6 +63,7 @@
      */
     @DeleteMapping("/del")
     @ApiOperation("鍒犻櫎妫�楠屽弬鏁伴」")
+    @Log(title = "鍒犻櫎妫�楠屽弬鏁伴」", businessType = BusinessType.DELETE)
     public AjaxResult delQualityUnqualified(@RequestBody List<Integer> ids) {
         if(CollectionUtils.isEmpty(ids)){
             return AjaxResult.error("璇烽�夋嫨鑷冲皯涓�鏉℃暟鎹�");
diff --git a/src/main/java/com/ruoyi/quality/controller/QualityReportController.java b/src/main/java/com/ruoyi/quality/controller/QualityReportController.java
index 0ad72cf..dddbba0 100644
--- a/src/main/java/com/ruoyi/quality/controller/QualityReportController.java
+++ b/src/main/java/com/ruoyi/quality/controller/QualityReportController.java
@@ -1,5 +1,7 @@
 package com.ruoyi.quality.controller;
 
+import com.ruoyi.framework.aspectj.lang.annotation.Log;
+import com.ruoyi.framework.aspectj.lang.enums.BusinessType;
 import com.ruoyi.framework.web.domain.AjaxResult;
 import com.ruoyi.quality.service.QualityReportService;
 import io.swagger.annotations.Api;
@@ -31,6 +33,7 @@
      */
     @ApiOperation("鑾峰彇妫�楠岀粺璁℃暟鎹�")
     @GetMapping("/getInspectStatistics")
+    @Log(title = "鑾峰彇妫�楠岀粺璁℃暟鎹�", businessType = BusinessType.OTHER)
     public AjaxResult getInspectStatistics() {
         return AjaxResult.success(qualityReportService.getInspectStatistics());
     }
@@ -40,6 +43,7 @@
      */
     @ApiOperation("鑾峰彇鍚堟牸鐜囩粺璁℃暟鎹�")
     @GetMapping("/getPassRateStatistics")
+    @Log(title = "鑾峰彇鍚堟牸鐜囩粺璁℃暟鎹�", businessType = BusinessType.OTHER)
     public AjaxResult getPassRateStatistics() {
         return AjaxResult.success(qualityReportService.getPassRateStatistics());
     }
@@ -49,6 +53,7 @@
      */
     @ApiOperation("鑾峰彇鏈堝害鍚堟牸鐜囩粺璁℃暟鎹�")
     @GetMapping("/getMonthlyPassRateStatistics")
+    @Log(title = "鑾峰彇鏈堝害鍚堟牸鐜囩粺璁℃暟鎹�", businessType = BusinessType.OTHER)
     public AjaxResult getMonthlyPassRateStatistics(@RequestParam("year") String year) {
         return AjaxResult.success(qualityReportService.getMonthlyPassRateStatistics(year));
     }
@@ -58,6 +63,7 @@
      */
     @ApiOperation("鑾峰彇骞村害鎬诲悎鏍肩巼缁熻鏁版嵁")
     @GetMapping("/getYearlyPassRateStatistics")
+    @Log(title = "鑾峰彇骞村害鎬诲悎鏍肩巼缁熻鏁版嵁", businessType = BusinessType.OTHER)
     public AjaxResult getYearlyPassRateStatistics(@RequestParam("year") String year) {
         return AjaxResult.success(qualityReportService.getYearlyPassRateStatistics(year));
     }
@@ -67,6 +73,7 @@
      */
     @ApiOperation("鑾峰彇鏈堝害瀹屾垚鏄庣粏鏁版嵁")
     @GetMapping("/getMonthlyCompletionDetails")
+    @Log(title = "鑾峰彇鏈堝害瀹屾垚鏄庣粏鏁版嵁", businessType = BusinessType.OTHER)
     public AjaxResult getMonthlyCompletionDetails(@RequestParam("year") String year) {
         return AjaxResult.success(qualityReportService.getMonthlyCompletionDetails(year));
     }
@@ -76,6 +83,7 @@
      */
     @ApiOperation("鑾峰彇鐑偣妫�娴嬫寚鏍囩粺璁�")
     @GetMapping("/getTopParameters")
+    @Log(title = "鑾峰彇鐑偣妫�娴嬫寚鏍囩粺璁�", businessType = BusinessType.OTHER)
     public AjaxResult getTopParameters(@RequestParam("modelType") Integer modelType) {
         return AjaxResult.success(qualityReportService.getTopParameters(modelType));
     }
diff --git a/src/main/java/com/ruoyi/quality/controller/QualityTestStandardBindingController.java b/src/main/java/com/ruoyi/quality/controller/QualityTestStandardBindingController.java
index aab4d05..08182b8 100644
--- a/src/main/java/com/ruoyi/quality/controller/QualityTestStandardBindingController.java
+++ b/src/main/java/com/ruoyi/quality/controller/QualityTestStandardBindingController.java
@@ -1,6 +1,8 @@
 package com.ruoyi.quality.controller;
 
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
+import com.ruoyi.framework.aspectj.lang.annotation.Log;
+import com.ruoyi.framework.aspectj.lang.enums.BusinessType;
 import com.ruoyi.framework.web.domain.AjaxResult;
 import com.ruoyi.quality.pojo.QualityTestStandardBinding;
 import com.ruoyi.quality.pojo.QualityTestStandardParam;
@@ -37,6 +39,7 @@
      */
     @PostMapping("/add")
     @ApiOperation("鏂板妫�娴嬫爣鍑嗕富琛ㄤ笌浜у搧鍏宠仈琛�")
+    @Log(title = "鏂板妫�娴嬫爣鍑嗕富琛ㄤ笌浜у搧鍏宠仈琛�", businessType = BusinessType.INSERT)
     public AjaxResult add(@RequestBody List<QualityTestStandardBinding> qualityTestStandardBindings) {
         return AjaxResult.success(qualityTestStandardBindingService.add(qualityTestStandardBindings));
     }
@@ -48,6 +51,7 @@
      */
     @DeleteMapping("/del")
     @ApiOperation("鍒犻櫎妫�娴嬫爣鍑嗕富琛ㄤ笌浜у搧鍏宠仈琛�")
+    @Log(title = "鍒犻櫎妫�娴嬫爣鍑嗕富琛ㄤ笌浜у搧鍏宠仈琛�", businessType = BusinessType.DELETE)
     public AjaxResult delQualityTestStandard(@RequestBody List<Integer> ids) {
         if(CollectionUtils.isEmpty(ids)){
             return AjaxResult.error("璇烽�夋嫨鑷冲皯涓�鏉℃暟鎹�");
@@ -61,6 +65,7 @@
      */
     @GetMapping("/list")
     @ApiOperation("妫�娴嬫寚鏍囩淮鎶ゆ煡璇�")
+    @Log(title = "妫�娴嬫寚鏍囩淮鎶ゆ煡璇�", businessType = BusinessType.OTHER)
     public AjaxResult listBinding(Long testStandardId) {
         return AjaxResult.success(qualityTestStandardBindingService.listBinding(testStandardId));
     }
diff --git a/src/main/java/com/ruoyi/quality/controller/QualityTestStandardController.java b/src/main/java/com/ruoyi/quality/controller/QualityTestStandardController.java
index 888dd0b..a428b4b 100644
--- a/src/main/java/com/ruoyi/quality/controller/QualityTestStandardController.java
+++ b/src/main/java/com/ruoyi/quality/controller/QualityTestStandardController.java
@@ -2,6 +2,8 @@
 
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.ruoyi.framework.aspectj.lang.annotation.Log;
+import com.ruoyi.framework.aspectj.lang.enums.BusinessType;
 import com.ruoyi.framework.web.domain.AjaxResult;
 import com.ruoyi.quality.pojo.QualityTestStandard;
 import com.ruoyi.quality.pojo.QualityTestStandardParam;
@@ -43,6 +45,7 @@
      */
     @PostMapping("/add")
     @ApiOperation("鏂板妫�娴嬫爣鍑�")
+    @Log(title = "鏂板妫�娴嬫爣鍑�", businessType = BusinessType.INSERT)
     public AjaxResult add(@RequestBody QualityTestStandard qualityTestStandard) {
         return AjaxResult.success(qualityTestStandardService.save(qualityTestStandard));
     }
@@ -54,6 +57,7 @@
      */
     @DeleteMapping("/del")
     @ApiOperation("鍒犻櫎妫�娴嬫爣鍑�")
+    @Log(title = "鍒犻櫎妫�娴嬫爣鍑�", businessType = BusinessType.DELETE)
     public AjaxResult delQualityTestStandard(@RequestBody List<Integer> ids) {
         if(CollectionUtils.isEmpty(ids)){
             return AjaxResult.error("璇烽�夋嫨鑷冲皯涓�鏉℃暟鎹�");
@@ -68,6 +72,7 @@
      */
     @PostMapping("/update")
     @ApiOperation("淇敼妫�娴嬫爣鍑�")
+    @Log(title = "淇敼妫�娴嬫爣鍑�", businessType = BusinessType.UPDATE)
     public AjaxResult update(@RequestBody QualityTestStandard qualityTestStandard) {
         return AjaxResult.success(qualityTestStandardService.updateById(qualityTestStandard));
     }
@@ -80,6 +85,7 @@
      */
     @GetMapping("/listPage")
     @ApiOperation("妫�娴嬫爣鍑嗗垎椤垫煡璇�")
+    @Log(title = "妫�娴嬫爣鍑嗗垎椤垫煡璇�", businessType = BusinessType.OTHER)
     public AjaxResult qualityTestStandardListPage(Page page, QualityTestStandard qualityTestStandard) {
         return AjaxResult.success(qualityTestStandardService.qualityTestStandardListPage(page, qualityTestStandard));
     }
@@ -91,6 +97,7 @@
      */
     @PostMapping("/copyParam")
     @ApiOperation("澶嶅埗妫�娴嬫爣鍑嗗弬鏁�")
+    @Log(title = "澶嶅埗妫�娴嬫爣鍑嗗弬鏁�", businessType = BusinessType.OTHER)
     public AjaxResult copyParam(@RequestBody QualityTestStandard qualityTestStandard) {
         return AjaxResult.success(qualityTestStandardService.copyParam(qualityTestStandard));
     }
@@ -102,6 +109,7 @@
      */
     @PostMapping("/qualityTestStandardAudit")
     @ApiOperation("鎵归噺瀹℃牳妫�娴嬫爣鍑�")
+    @Log(title = "鎵归噺瀹℃牳妫�娴嬫爣鍑�", businessType = BusinessType.OTHER)
     public AjaxResult qualityTestStandardAudit(@RequestBody List<QualityTestStandard> qualityTestStandards) {
         return AjaxResult.success(qualityTestStandardService.updateBatchById(qualityTestStandards));
     }
@@ -112,6 +120,7 @@
      */
     @GetMapping("/getQualityTestStandardByProductId")
     @ApiOperation("鏍规嵁浜у搧id鏌ヨ鐩稿叧鐨勬楠屾爣鍑�")
+    @Log(title = "鏍规嵁浜у搧id鏌ヨ鐩稿叧鐨勬楠屾爣鍑�", businessType = BusinessType.OTHER)
     public AjaxResult getQualityTestStandardByProductId(@Nonnull Long productId, @Nonnull Integer inspectType, String process) {
         return AjaxResult.success(qualityTestStandardService.getQualityTestStandardByProductId(productId,inspectType,process));
     }
@@ -122,6 +131,7 @@
      */
     @GetMapping("/getQualityTestStandardParamByTestStandardId")
     @ApiOperation("鏍规嵁妫�娴嬫爣鍑唅d鏌ヨ鐩稿叧鐨勬楠屾爣鍑嗗弬鏁�")
+    @Log(title = "鏍规嵁妫�娴嬫爣鍑唅d鏌ヨ鐩稿叧鐨勬楠屾爣鍑嗗弬鏁�", businessType = BusinessType.OTHER)
     public AjaxResult getQualityTestStandardParamByTestStandardId(Long testStandardId) {
         return AjaxResult.success(qualityTestStandardParamService.list(Wrappers.<QualityTestStandardParam>lambdaQuery().eq(QualityTestStandardParam::getTestStandardId, testStandardId)));
     }
diff --git a/src/main/java/com/ruoyi/quality/controller/QualityTestStandardParamController.java b/src/main/java/com/ruoyi/quality/controller/QualityTestStandardParamController.java
index 6a110a5..ad69a4a 100644
--- a/src/main/java/com/ruoyi/quality/controller/QualityTestStandardParamController.java
+++ b/src/main/java/com/ruoyi/quality/controller/QualityTestStandardParamController.java
@@ -2,6 +2,8 @@
 
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.ruoyi.framework.aspectj.lang.annotation.Log;
+import com.ruoyi.framework.aspectj.lang.enums.BusinessType;
 import com.ruoyi.framework.web.domain.AjaxResult;
 import com.ruoyi.quality.pojo.QualityTestStandard;
 import com.ruoyi.quality.pojo.QualityTestStandardParam;
@@ -37,6 +39,7 @@
      */
     @PostMapping("/add")
     @ApiOperation("鏂板妫�娴嬫爣鍑嗗弬鏁�")
+    @Log(title = "鏂板妫�娴嬫爣鍑嗗弬鏁�", businessType = BusinessType.INSERT)
     public AjaxResult add(@RequestBody QualityTestStandardParam qualityTestStandardParam) {
         return AjaxResult.success(qualityTestStandardParamService.save(qualityTestStandardParam));
     }
@@ -48,6 +51,7 @@
      */
     @DeleteMapping("/del")
     @ApiOperation("鍒犻櫎妫�娴嬫爣鍑嗗弬鏁�")
+    @Log(title = "鍒犻櫎妫�娴嬫爣鍑嗗弬鏁�", businessType = BusinessType.DELETE)
     public AjaxResult delQualityTestStandard(@RequestBody List<Integer> ids) {
         if(CollectionUtils.isEmpty(ids)){
             return AjaxResult.error("璇烽�夋嫨鑷冲皯涓�鏉℃暟鎹�");
@@ -62,6 +66,7 @@
      */
     @PostMapping("/update")
     @ApiOperation("淇敼妫�娴嬫爣鍑嗗弬鏁�")
+    @Log(title = "淇敼妫�娴嬫爣鍑嗗弬鏁�", businessType = BusinessType.UPDATE)
     public AjaxResult update(@RequestBody QualityTestStandardParam qualityTestStandardParam) {
         return AjaxResult.success(qualityTestStandardParamService.updateById(qualityTestStandardParam));
     }
@@ -72,6 +77,7 @@
      */
     @GetMapping("/list")
     @ApiOperation("鏌ヨ妫�娴嬫爣鍑嗗弬鏁�")
+    @Log(title = "鏌ヨ妫�娴嬫爣鍑嗗弬鏁�", businessType = BusinessType.OTHER)
     public AjaxResult list(Long testStandardId) {
         return AjaxResult.success(qualityTestStandardParamService.list(Wrappers.<QualityTestStandardParam>lambdaQuery().eq(QualityTestStandardParam::getTestStandardId,testStandardId)));
     }
diff --git a/src/main/java/com/ruoyi/quality/controller/QualityUnqualifiedController.java b/src/main/java/com/ruoyi/quality/controller/QualityUnqualifiedController.java
index b38f2f6..11edb08 100644
--- a/src/main/java/com/ruoyi/quality/controller/QualityUnqualifiedController.java
+++ b/src/main/java/com/ruoyi/quality/controller/QualityUnqualifiedController.java
@@ -1,6 +1,8 @@
 package com.ruoyi.quality.controller;
 
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.ruoyi.framework.aspectj.lang.annotation.Log;
+import com.ruoyi.framework.aspectj.lang.enums.BusinessType;
 import com.ruoyi.framework.web.domain.AjaxResult;
 import com.ruoyi.quality.pojo.QualityUnqualified;
 import com.ruoyi.quality.service.IQualityUnqualifiedService;
@@ -33,6 +35,7 @@
      */
     @PostMapping("/add")
     @ApiOperation("鏂板涓嶅悎鏍肩鐞�")
+    @Log(title = "鏂板涓嶅悎鏍肩鐞�", businessType = BusinessType.INSERT)
     public AjaxResult add(@RequestBody QualityUnqualified qualityUnqualified) {
         qualityUnqualified.setInspectState(0);
         return AjaxResult.success(qualityUnqualifiedService.save(qualityUnqualified));
@@ -46,6 +49,7 @@
      */
     @DeleteMapping("/del")
     @ApiOperation("鍒犻櫎涓嶅悎鏍肩鐞�")
+    @Log(title = "鍒犻櫎涓嶅悎鏍肩鐞�", businessType = BusinessType.DELETE)
     public AjaxResult delQualityUnqualified(@RequestBody List<Integer> ids) {
         qualityUnqualifiedService.listByIds(ids).stream().forEach(qualityUnqualified -> {
             if (qualityUnqualified.getInspectState() == 1) {
@@ -63,6 +67,7 @@
      */
     @GetMapping("/{id}")
     @ApiOperation("涓嶅悎鏍肩鐞嗚鎯�")
+    @Log(title = "涓嶅悎鏍肩鐞嗚鎯�", businessType = BusinessType.OTHER)
     public AjaxResult QualityUnqualifiedDetail(@PathVariable("id") Integer id) {
         return AjaxResult.success(qualityUnqualifiedService.getUnqualified(id));
     }
@@ -75,6 +80,7 @@
      */
     @PostMapping("/update")
     @ApiOperation("涓嶅悎鏍肩鐞嗕慨鏀�")
+    @Log(title = "涓嶅悎鏍肩鐞嗚鎯�", businessType = BusinessType.UPDATE)
     public AjaxResult update(@RequestBody QualityUnqualified qualityUnqualified) {
         return AjaxResult.success(qualityUnqualifiedService.updateById(qualityUnqualified));
     }
@@ -88,6 +94,7 @@
      */
     @GetMapping("/listPage")
     @ApiOperation("涓嶅悎鏍肩鐞嗗垎椤垫煡璇�")
+    @Log(title = "涓嶅悎鏍肩鐞嗗垎椤垫煡璇�", businessType = BusinessType.OTHER)
     public AjaxResult qualityUnqualifiedListPage(Page page, QualityUnqualified qualityUnqualified) {
         return AjaxResult.success(qualityUnqualifiedService.qualityUnqualifiedListPage(page, qualityUnqualified));
     }
@@ -100,6 +107,7 @@
      */
     @PostMapping("/export")
     @ApiOperation("涓嶅悎鏍肩鐞嗗鍑�")
+    @Log(title = "涓嶅悎鏍肩鐞嗗鍑�", businessType = BusinessType.EXPORT)
     public void qualityUnqualifiedExport(HttpServletResponse response, QualityUnqualified qualityUnqualified) {
         qualityUnqualifiedService.qualityUnqualifiedExport(response, qualityUnqualified);
     }
@@ -112,12 +120,14 @@
      */
     @PostMapping("/deal")
     @ApiOperation("涓嶅悎鏍肩鐞嗗鐞�")
+    @Log(title = "涓嶅悎鏍肩鐞嗗鐞�", businessType = BusinessType.OTHER)
     public AjaxResult deal(@RequestBody QualityUnqualified qualityUnqualified) {
         return AjaxResult.success(qualityUnqualifiedService.deal(qualityUnqualified));
     }
 
     @GetMapping("/downloadReturnRecord")
     @ApiOperation("涓嬭浇涓嶅悎鏍肩鐞嗗鐞嗚褰�")
+    @Log(title = "涓嬭浇涓嶅悎鏍肩鐞嗗鐞嗚褰�", businessType = BusinessType.OTHER)
     public void downloadReturnRecord(@RequestParam("id") Long id,HttpServletResponse response) throws IOException {
         qualityUnqualifiedService.downloadReturnRecord(id,response);
     }
diff --git a/src/main/java/com/ruoyi/sales/controller/InvoiceLedgerController.java b/src/main/java/com/ruoyi/sales/controller/InvoiceLedgerController.java
index ca1460c..a798d18 100644
--- a/src/main/java/com/ruoyi/sales/controller/InvoiceLedgerController.java
+++ b/src/main/java/com/ruoyi/sales/controller/InvoiceLedgerController.java
@@ -43,6 +43,7 @@
      */
     @PostMapping("/saveOrUpdate")
     @ApiOperation("寮�绁ㄥ彴璐︽柊澧�")
+    @Log(title = "寮�绁ㄥ彴璐︽柊澧�", businessType = BusinessType.UPDATE)
     public AjaxResult invoiceLedgerSaveOrUpdate(@RequestBody InvoiceRegistrationProductDto productDto) {
         invoiceLedgerService.invoiceLedgerSaveOrUpdate(productDto);
         return AjaxResult.success();
@@ -55,6 +56,7 @@
      */
     @DeleteMapping("/del")
     @ApiOperation("寮�绁ㄥ彴璐﹀垹闄�")
+    @Log(title = "寮�绁ㄥ彴璐﹀垹闄�", businessType = BusinessType.DELETE)
     public AjaxResult invoiceLedgerDel(@RequestBody List<Integer> ids) {
         invoiceLedgerService.invoiceLedgerDel(ids);
         return AjaxResult.success();
@@ -68,6 +70,7 @@
      */
     @GetMapping("/page")
     @ApiOperation("寮�绁ㄥ彴璐﹀垎椤垫煡璇�")
+    @Log(title = "寮�绁ㄥ彴璐﹀垎椤垫煡璇�", businessType = BusinessType.OTHER)
     public AjaxResult invoiceLedgerPage(Page page, InvoiceLedgerDto invoiceLedgerDto) {
         return AjaxResult.success(invoiceLedgerService.invoiceLedgerPage(page, invoiceLedgerDto));
     }
@@ -79,6 +82,7 @@
      */
     @GetMapping("/fileList")
     @ApiOperation("寮�绁ㄥ彴璐︽枃浠舵煡璇�")
+    @Log(title = "寮�绁ㄥ彴璐︽枃浠舵煡璇�", businessType = BusinessType.OTHER)
     public AjaxResult invoiceLedgerFileList(Integer invoiceLedgerId) {
         return AjaxResult.success(invoiceLedgerService.invoiceLedgerFileList(invoiceLedgerId));
     }
@@ -104,6 +108,7 @@
      */
     @PostMapping("/uploadFile")
     @ApiOperation("寮�绁ㄥ彴璐︽枃浠朵笂浼�")
+    @Log(title = "寮�绁ㄥ彴璐︽枃浠朵笂浼�", businessType = BusinessType.OTHER)
     public AjaxResult invoiceLedgerUploadFile(MultipartFile file) {
         try {
             return AjaxResult.success(invoiceLedgerService.invoiceLedgerUploadFile(file));
@@ -120,6 +125,7 @@
      */
     @PostMapping("/export")
     @ApiOperation("寮�绁ㄥ彴璐﹀鍑�")
+    @Log(title = "寮�绁ㄥ彴璐﹀鍑�", businessType = BusinessType.EXPORT)
     public void invoiceLedgerExport(HttpServletResponse response, InvoiceRegistrationProductDto invoiceRegistrationProductDto) {
         invoiceLedgerService.invoiceLedgerExport(response, invoiceRegistrationProductDto);
     }
@@ -131,6 +137,7 @@
      */
     @GetMapping("/info")
     @ApiOperation("寮�绁ㄥ彴璐﹁鎯�")
+    @Log(title = "寮�绁ㄥ彴璐﹁鎯�", businessType = BusinessType.OTHER)
     public AjaxResult invoiceLedgerInfo(Integer id) {
         return AjaxResult.success(invoiceLedgerService.invoiceLedgerDetail(id));
     }
@@ -142,6 +149,7 @@
      */
     @PostMapping("/commitFile")
     @ApiOperation("鏂囦欢鎻愪氦")
+    @Log(title = "鏂囦欢鎻愪氦", businessType = BusinessType.OTHER)
     public AjaxResult invoiceLedgerCommitFile(@RequestBody InvoiceLedgerDto invoiceLedgerDto) {
         try {
             invoiceLedgerService.invoiceLedgerCommitFile(invoiceLedgerDto);
@@ -158,6 +166,7 @@
      */
     @GetMapping("/list")
     @ApiOperation("寮�绁ㄥ彴璐︽煡璇�")
+    @Log(title = "寮�绁ㄥ彴璐︽煡璇�", businessType = BusinessType.OTHER)
     public AjaxResult invoiceLedgerList(InvoiceLedgerDto invoiceLedgerDto) {
         return AjaxResult.success(invoiceLedgerService.invoiceLedgerList(invoiceLedgerDto));
     }
@@ -170,6 +179,7 @@
      */
     @GetMapping("/salesAccount")
     @ApiOperation("瀹㈡埛閿�鍞褰�")
+    @Log(title = "瀹㈡埛閿�鍞褰�", businessType = BusinessType.OTHER)
     public AjaxResult invoiceLedgerSalesAccount(Page page, InvoiceLedgerDto invoiceLedgerDto) {
         return AjaxResult.success(invoiceLedgerService.invoiceLedgerSalesAccount(page,invoiceLedgerDto));
     }
@@ -179,6 +189,7 @@
      */
     @GetMapping("/getInvoiceAmount")
     @ApiOperation("鏈湀寮�绁ㄩ噾棰�")
+    @Log(title = "鏈湀寮�绁ㄩ噾棰�", businessType = BusinessType.OTHER)
     public AjaxResult getInvoiceAmount() {
         try {
             BigDecimal amount = invoiceLedgerService.getInvoiceAmount();
@@ -196,6 +207,7 @@
      */
     @GetMapping("/registrationProductPage")
     @ApiOperation("浜у搧寮�绁ㄨ褰曟煡璇�")
+    @Log(title = "浜у搧寮�绁ㄨ褰曟煡璇�", businessType = BusinessType.OTHER)
     public AjaxResult registrationProductPage(Page page, InvoiceRegistrationProductDto registrationProductDto) {
 
         return AjaxResult.success(invoiceLedgerService.registrationProductPage(page,registrationProductDto));
@@ -208,6 +220,7 @@
      */
     @GetMapping("/invoiceLedgerProductInfo")
     @ApiOperation("浜у搧寮�绁ㄨ鎯�")
+    @Log(title = "浜у搧寮�绁ㄨ鎯�", businessType = BusinessType.OTHER)
     public AjaxResult invoiceLedgerProductDetail(Integer id) {
         return AjaxResult.success(invoiceLedgerService.invoiceLedgerProductDetail(id));
     }
@@ -219,6 +232,7 @@
      */
     @DeleteMapping("delInvoiceLedger/{invoiceRegistrationProductId}")
     @ApiOperation("寮�绁ㄥ彴璐﹀垹闄�")
+    @Log(title = "寮�绁ㄥ彴璐﹀垹闄�", businessType = BusinessType.DELETE)
     public AjaxResult delInvoiceLedger(@PathVariable Integer invoiceRegistrationProductId) {
         try {
             invoiceLedgerService.delInvoiceLedger(invoiceRegistrationProductId);
diff --git a/src/main/java/com/ruoyi/sales/controller/ReceiptPaymentController.java b/src/main/java/com/ruoyi/sales/controller/ReceiptPaymentController.java
index aa10b54..1e851ed 100644
--- a/src/main/java/com/ruoyi/sales/controller/ReceiptPaymentController.java
+++ b/src/main/java/com/ruoyi/sales/controller/ReceiptPaymentController.java
@@ -42,6 +42,7 @@
      * @return
      */
     @PostMapping("/saveOrUpdate")
+    @Log(title = "鏂板鍥炴鐧昏", businessType = BusinessType.INSERT)
     public AjaxResult receiptPaymentSaveOrUpdate (@RequestBody List<ReceiptPayment> receiptPayment) {
         receiptPaymentService.receiptPaymentSaveOrUpdate(receiptPayment);
         return AjaxResult.success();
@@ -53,6 +54,7 @@
      * @return
      */
     @PostMapping("/update")
+    @Log(title = "淇敼鍥炴鐧昏", businessType = BusinessType.UPDATE)
     @Transactional(rollbackFor = Exception.class)
     public AjaxResult receiptPaymentUpdate (@RequestBody ReceiptPayment receiptPayment) {
         return AjaxResult.success(receiptPaymentService.receiptPaymentUpdate(receiptPayment));
@@ -64,6 +66,7 @@
      * @return
      */
     @DeleteMapping("/del")
+    @Log(title = "鍒犻櫎鍥炴鐧昏", businessType = BusinessType.DELETE)
     @Transactional(rollbackFor = Exception.class)
     public AjaxResult receiptPaymentDel (@RequestBody List<Integer> ids) {
         return AjaxResult.success(receiptPaymentService.receiptPaymentDel(ids));
@@ -75,6 +78,7 @@
      * @return
      */
     @GetMapping("/customerInteractions")
+    @Log(title = "鏌ヨ瀹㈡埛寰�鏉ヨ褰�", businessType = BusinessType.OTHER)
     public AjaxResult customerInteractions (InvoiceLedgerDto receiptPaymentDto) {
         return AjaxResult.success(receiptPaymentService.customerInteractions(receiptPaymentDto));
     }
@@ -85,6 +89,7 @@
      * @return
      */
     @GetMapping("/info")
+    @Log(title = "鏌ヨ鍥炴鐧昏璇︽儏", businessType = BusinessType.OTHER)
     public AjaxResult receiptPaymentInfo (Integer id) {
         return AjaxResult.success(receiptPaymentService.receiptPaymentInfo(id));
     }
@@ -93,6 +98,7 @@
      * 鏈湀鍥炴閲戦
      */
     @GetMapping("/getReceiptAmount")
+    @Log(title = "鏌ヨ鏈湀鍥炴閲戦", businessType = BusinessType.OTHER)
     public AjaxResult getReceiptAmount() {
         try {
             BigDecimal receiptAmount = receiptPaymentService.getReceiptAmount();
@@ -109,12 +115,14 @@
      * @return
      */
     @GetMapping("/bindInvoiceNoRegPage")
+    @Log(title = "鏌ヨ宸茬粡缁戝畾鍙戠エ鐨勫紑绁ㄥ彴璐�", businessType = BusinessType.OTHER)
     public AjaxResult bindInvoiceNoRegPage(Page page, ReceiptPaymentDto receiptPaymentDto) {
         return AjaxResult.success(receiptPaymentService.bindInvoiceNoRegPage(page,receiptPaymentDto));
     }
 
     @ApiModelProperty("瀵煎嚭鍥炴鐧昏")
     @PostMapping("/export")
+    @Log(title = "瀵煎嚭鍥炴鐧昏", businessType = BusinessType.EXPORT)
     public void export(HttpServletResponse response, String ids) {
         if (ids == null || ids.isEmpty()) {
             receiptPaymentService.exportPaymentList(response, null);
@@ -134,6 +142,7 @@
      * @return
      */
     @GetMapping("/invoiceInfo")
+    @Log(title = "鏌ヨ寮�绁ㄥ彴璐﹁鎯�", businessType = BusinessType.OTHER)
     public AjaxResult invoiceInfo (Integer id) {
         return AjaxResult.success(receiptPaymentService.invoiceInfo(id));
     }
@@ -142,6 +151,7 @@
      * 鏈湀搴旀敹,鍥炴閲戦
      */
     @GetMapping("/getAmountMouth")
+    @Log(title = "鏌ヨ鏈湀搴旀敹,鍥炴閲戦", businessType = BusinessType.OTHER)
     public AjaxResult getAmountMouth() {
         return  AjaxResult.success(receiptPaymentService.getAmountMouth());
     }
@@ -149,6 +159,7 @@
     /**
      * 鏌ヨ鍥炴璁板綍
      */
+    @Log(title = "鏌ヨ鍥炴璁板綍", businessType = BusinessType.OTHER)
     @GetMapping("/receiptPaymentHistoryList")
     public TableDataInfo receiptPaymentHistoryList(ReceiptPaymentDto receiptPaymentDto) {
         startPage();
@@ -160,6 +171,7 @@
      * 鏌ヨ鍥炴璁板綍
      */
     @GetMapping("/receiptPaymentHistoryListPage")
+    @Log(title = "鏌ヨ鍥炴璁板綍", businessType = BusinessType.OTHER)
     public IPage<ReceiptPaymentDto> receiptPaymentHistoryListPage(Page page, ReceiptPaymentDto receiptPaymentDto) {
         return receiptPaymentService.receiptPaymentHistoryListPage(page,receiptPaymentDto);
     }
diff --git a/src/main/java/com/ruoyi/sales/controller/SalesLedgerController.java b/src/main/java/com/ruoyi/sales/controller/SalesLedgerController.java
index 182366c..ccef1a4 100644
--- a/src/main/java/com/ruoyi/sales/controller/SalesLedgerController.java
+++ b/src/main/java/com/ruoyi/sales/controller/SalesLedgerController.java
@@ -76,6 +76,7 @@
 
     @ApiOperation("瀵煎嚭閿�鍞彴璐︽ā鏉�")
     @PostMapping("/exportTemplate")
+    @Log(title = "瀵煎嚭閿�鍞彴璐︽ā鏉�", businessType = BusinessType.EXPORT)
     public void exportTemplate(HttpServletResponse response) {
         // 1. 妯℃澘鏂囦欢鍦╮esources/static涓嬬殑璺緞
         String templatePath = "static/閿�鍞彴璐﹀鍏ユā鏉�.xlsx";
@@ -117,6 +118,7 @@
      */
     @GetMapping("/list")
     @ApiOperation("鏌ヨ閿�鍞彴璐﹀垪琛�")
+    @Log(title = "鏌ヨ閿�鍞彴璐﹀垪琛�", businessType = BusinessType.OTHER)
     public TableDataInfo list(Page page, SalesLedgerDto salesLedgerDto) {
         startPage();
         List<SalesLedger> list = salesLedgerService.selectSalesLedgerList(salesLedgerDto);
@@ -146,6 +148,7 @@
      */
     @GetMapping("/getSalesLedgerWithProducts")
     @ApiOperation("鏌ヨ閿�鍞彴璐﹀拰浜у搧鐖跺瓙鍒楄〃")
+    @Log(title = "鏌ヨ閿�鍞彴璐﹀拰浜у搧鐖跺瓙鍒楄〃", businessType = BusinessType.OTHER)
     public SalesLedgerDto getSalesLedgerWithProducts(SalesLedgerDto salesLedgerDto) {
         return salesLedgerService.getSalesLedgerWithProducts(salesLedgerDto);
     }
@@ -214,6 +217,7 @@
      */
     @GetMapping("/listNoPage")
     @ApiOperation("鏌ヨ閿�鍞彴璐︿笉鍒嗛〉")
+    @Log(title = "鏌ヨ閿�鍞彴璐︿笉鍒嗛〉", businessType = BusinessType.OTHER)
     public AjaxResult listNoPage(SalesLedgerDto salesLedgerDto) {
         List<SalesLedger> list = salesLedgerService.selectSalesLedgerList(salesLedgerDto);
         return AjaxResult.success(list);
diff --git a/src/main/java/com/ruoyi/sales/controller/SalesLedgerProductController.java b/src/main/java/com/ruoyi/sales/controller/SalesLedgerProductController.java
index de51845..a227225 100644
--- a/src/main/java/com/ruoyi/sales/controller/SalesLedgerProductController.java
+++ b/src/main/java/com/ruoyi/sales/controller/SalesLedgerProductController.java
@@ -47,6 +47,7 @@
      * 鍥炴鐧昏鍒嗛〉鏌ヨ
      */
     @GetMapping("/listPageSalesLedger")
+    @Log(title = "鍥炴鐧昏鍒嗛〉鏌ヨ", businessType = BusinessType.OTHER)
     public AjaxResult listPage(Page page, SalesLedgerProductDto salesLedgerProduct) {
         IPage<SalesLedgerProductDto> list = salesLedgerProductService.listPage(page,salesLedgerProduct);
         return AjaxResult.success(list);
@@ -57,6 +58,7 @@
      * 浠樻鐧昏鍒嗛〉鏌ヨ
      */
     @GetMapping("/listPagePurchaseLedger")
+    @Log(title = "浠樻鐧昏鍒嗛〉鏌ヨ", businessType = BusinessType.OTHER)
     public AjaxResult listPagePurchaseLedger(Page page, SalesLedgerProductDto salesLedgerProduct) {
         IPage<SalesLedgerProductDto> list = salesLedgerProductService.listPagePurchaseLedger(page,salesLedgerProduct);
         return AjaxResult.success(list);
@@ -67,6 +69,7 @@
      * 鏌ヨ浜у搧淇℃伅鍒楄〃
      */
     @GetMapping("/list")
+    @Log(title = "鏌ヨ浜у搧淇℃伅鍒楄〃", businessType = BusinessType.OTHER)
     public AjaxResult list(SalesLedgerProduct salesLedgerProduct) {
         List<SalesLedgerProduct> list = salesLedgerProductService.selectSalesLedgerProductList(salesLedgerProduct);
         list.forEach(item -> {
@@ -124,6 +127,7 @@
      * 鑾峰彇浜у搧淇℃伅璇︾粏淇℃伅
      */
     @GetMapping(value = "/{id}")
+    @Log(title = "鏌ヨ浜у搧淇℃伅璇︾粏淇℃伅", businessType = BusinessType.OTHER)
     public AjaxResult getInfo(@PathVariable("id") Long id)
     {
         return success(salesLedgerProductService.selectSalesLedgerProductById(id));
@@ -154,6 +158,7 @@
 
     //鏍规嵁浜у搧id鑾峰彇bom鍒ゆ柇搴撳瓨鏄惁鍏呰冻
     @GetMapping("/judgmentInventory")
+    @Log(title = "鍒ゆ柇搴撳瓨鏄惁鍏呰冻", businessType = BusinessType.OTHER)
     public R judgmentInventory(SalesLedgerProduct salesLedgerProduct) {
         return  salesLedgerProductService.judgmentInventory(salesLedgerProduct);
     }
diff --git a/src/main/java/com/ruoyi/staff/controller/AnalyticsController.java b/src/main/java/com/ruoyi/staff/controller/AnalyticsController.java
index 2c81a47..3bd6e1c 100644
--- a/src/main/java/com/ruoyi/staff/controller/AnalyticsController.java
+++ b/src/main/java/com/ruoyi/staff/controller/AnalyticsController.java
@@ -1,5 +1,7 @@
 package com.ruoyi.staff.controller;
 
+import com.ruoyi.framework.aspectj.lang.annotation.Log;
+import com.ruoyi.framework.aspectj.lang.enums.BusinessType;
 import com.ruoyi.framework.web.domain.AjaxResult;
 import com.ruoyi.staff.service.AnalyticsService;
 import io.swagger.annotations.Api;
@@ -20,18 +22,21 @@
 
     @GetMapping("/reason")
     @ApiOperation("鍛樺伐绂昏亴鍘熷洜鍒嗘瀽")
+    @Log(title = "鍛樺伐绂昏亴鍘熷洜鍒嗘瀽", businessType = BusinessType.OTHER)
     public AjaxResult staffLeaveReasonAnalytics() {
         return AjaxResult.success(analyticsService.staffLeaveReasonAnalytics());
     }
 
     @GetMapping("/monthly_turnover_rate")
     @ApiOperation("12涓湀鍛樺伐绂昏亴鐜囧垎鏋�")
+    @Log(title = "12涓湀鍛樺伐绂昏亴鐜囧垎鏋�", businessType = BusinessType.OTHER)
     public AjaxResult getMonthlyTurnoverRateFor12Months() {
         return AjaxResult.success(analyticsService.getMonthlyTurnoverRateFor12Months());
     }
 
     @GetMapping("/total_statistic")
     @ApiOperation("鍛樺伐鎬荤粺璁″垎鏋�")
+    @Log(title = "鍛樺伐鎬荤粺璁″垎鏋�", businessType = BusinessType.OTHER)
     public AjaxResult getTotalStatistic() {
         return AjaxResult.success(analyticsService.getTotalStatistic());
     }
diff --git a/src/main/java/com/ruoyi/staff/controller/BankController.java b/src/main/java/com/ruoyi/staff/controller/BankController.java
index 32f9e93..9b5322b 100644
--- a/src/main/java/com/ruoyi/staff/controller/BankController.java
+++ b/src/main/java/com/ruoyi/staff/controller/BankController.java
@@ -31,6 +31,7 @@
 
     @GetMapping("/list")
     @ApiOperation("鏌ヨ閾惰绠$悊琛ㄥ垪琛�")
+    @Log(title = "閾惰绠$悊琛�", businessType = BusinessType.OTHER)
     public AjaxResult list() {
         return AjaxResult.success(bankService.list());
     }
diff --git a/src/main/java/com/ruoyi/staff/controller/HolidayApplicationController.java b/src/main/java/com/ruoyi/staff/controller/HolidayApplicationController.java
index 6a4e407..324da7b 100644
--- a/src/main/java/com/ruoyi/staff/controller/HolidayApplicationController.java
+++ b/src/main/java/com/ruoyi/staff/controller/HolidayApplicationController.java
@@ -1,6 +1,8 @@
 package com.ruoyi.staff.controller;
 
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.ruoyi.framework.aspectj.lang.annotation.Log;
+import com.ruoyi.framework.aspectj.lang.enums.BusinessType;
 import com.ruoyi.framework.web.domain.AjaxResult;
 import com.ruoyi.staff.pojo.HolidayApplication;
 import com.ruoyi.staff.service.HolidayApplicationService;
@@ -20,6 +22,7 @@
      */
     @GetMapping("/listPage")
     @ApiOperation("璇峰亣鐢宠鍒嗛〉鏌ヨ")
+    @Log(title = "璇峰亣鐢宠鍒嗛〉鏌ヨ", businessType = BusinessType.OTHER)
     public AjaxResult listPage(Page page, HolidayApplication holidayApplication){
         return AjaxResult.success(holidayApplicationService.listPage(page, holidayApplication));
     }
@@ -28,6 +31,7 @@
      */
     @PostMapping("/add")
     @ApiOperation("鏂板璇峰亣鐢宠")
+    @Log(title = "鏂板璇峰亣鐢宠", businessType = BusinessType.INSERT)
     public AjaxResult add(@RequestBody HolidayApplication holidayApplication){
         return AjaxResult.success(holidayApplicationService.save(holidayApplication));
     }
@@ -36,6 +40,7 @@
      */
     @PostMapping("/update")
     @ApiOperation("淇敼璇峰亣鐢宠")
+    @Log(title = "淇敼璇峰亣鐢宠", businessType = BusinessType.UPDATE)
     public AjaxResult update(@RequestBody HolidayApplication holidayApplication){
         return AjaxResult.success(holidayApplicationService.updateById(holidayApplication));
     }
@@ -44,6 +49,7 @@
      */
     @DeleteMapping("/delete/{id}")
     @ApiOperation("鍒犻櫎璇峰亣鐢宠")
+    @Log(title = "鍒犻櫎璇峰亣鐢宠", businessType = BusinessType.DELETE)
     public AjaxResult delete(@PathVariable("id") Long id){
         return AjaxResult.success(holidayApplicationService.removeById(id));
     }
diff --git a/src/main/java/com/ruoyi/staff/controller/PersonalAttendanceLocationConfigController.java b/src/main/java/com/ruoyi/staff/controller/PersonalAttendanceLocationConfigController.java
index 5eabe99..3a48ede 100644
--- a/src/main/java/com/ruoyi/staff/controller/PersonalAttendanceLocationConfigController.java
+++ b/src/main/java/com/ruoyi/staff/controller/PersonalAttendanceLocationConfigController.java
@@ -1,6 +1,8 @@
 package com.ruoyi.staff.controller;
 
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.ruoyi.framework.aspectj.lang.annotation.Log;
+import com.ruoyi.framework.aspectj.lang.enums.BusinessType;
 import com.ruoyi.framework.web.domain.AjaxResult;
 import com.ruoyi.framework.web.domain.R;
 import com.ruoyi.staff.dto.PersonalAttendanceRecordsDto;
@@ -33,12 +35,14 @@
 
     @ApiOperation("鏂板/淇敼浜哄憳鎵撳崱瑙勫垯閰嶇疆")
     @PostMapping("/add")
+    @Log(title = "鏂板/淇敼浜哄憳鎵撳崱瑙勫垯閰嶇疆", businessType = BusinessType.INSERT)
     public R add(@RequestBody PersonalAttendanceLocationConfig personalAttendanceLocationConfig){
         return R.ok(personalAttendanceLocationConfigService.saveOrUpdate(personalAttendanceLocationConfig));
     }
 
     @ApiOperation("鍒嗛〉鏌ヨ浜哄憳鎵撳崱瑙勫垯閰嶇疆")
     @GetMapping("/listPage")
+    @Log(title = "鍒嗛〉鏌ヨ浜哄憳鎵撳崱瑙勫垯閰嶇疆", businessType = BusinessType.OTHER)
     public R listPage(Page page){
         return R.ok(personalAttendanceLocationConfigService.page(page));
     }
@@ -46,6 +50,7 @@
 
     @ApiOperation("鍒犻櫎浜哄憳鎵撳崱瑙勫垯閰嶇疆")
     @DeleteMapping("/del")
+    @Log(title = "鍒犻櫎浜哄憳鎵撳崱瑙勫垯閰嶇疆", businessType = BusinessType.DELETE)
     public R del(@RequestBody List<Integer> ids) {
         return R.ok(personalAttendanceLocationConfigService.removeBatchByIds(ids));
     }
diff --git a/src/main/java/com/ruoyi/staff/controller/PersonalAttendanceRecordsController.java b/src/main/java/com/ruoyi/staff/controller/PersonalAttendanceRecordsController.java
index d6a8ce3..1e9e472 100644
--- a/src/main/java/com/ruoyi/staff/controller/PersonalAttendanceRecordsController.java
+++ b/src/main/java/com/ruoyi/staff/controller/PersonalAttendanceRecordsController.java
@@ -1,6 +1,8 @@
 package com.ruoyi.staff.controller;
 
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.ruoyi.framework.aspectj.lang.annotation.Log;
+import com.ruoyi.framework.aspectj.lang.enums.BusinessType;
 import com.ruoyi.framework.web.domain.AjaxResult;
 import com.ruoyi.staff.dto.PersonalAttendanceRecordsDto;
 import com.ruoyi.staff.pojo.PersonalAttendanceRecords;
@@ -29,24 +31,28 @@
 
     @ApiOperation("鏂板鎵撳崱绛惧埌")
     @PostMapping("")
+    @Log(title = "鏂板鎵撳崱绛惧埌", businessType = BusinessType.INSERT)
     public AjaxResult add(@RequestBody PersonalAttendanceRecordsDto personalAttendanceRecordsDto){
         return AjaxResult.success(personalAttendanceRecordsService.add(personalAttendanceRecordsDto));
     }
 
     @ApiOperation("鍒嗛〉鏌ヨ鎵撳崱绛惧埌")
     @GetMapping("/listPage")
+    @Log(title = "鍒嗛〉鏌ヨ鎵撳崱绛惧埌", businessType = BusinessType.OTHER)
     public AjaxResult listPage(Page page, PersonalAttendanceRecordsDto personalAttendanceRecordsDto){
         return AjaxResult.success(personalAttendanceRecordsService.listPage(page, personalAttendanceRecordsDto));
     }
 
     @ApiOperation("鑾峰彇褰撳墠浜虹殑鑰冨嫟鐩稿叧鏁版嵁")
     @GetMapping("/today")
+    @Log(title = "鑾峰彇褰撳墠浜虹殑鑰冨嫟鐩稿叧鏁版嵁", businessType = BusinessType.OTHER)
     public AjaxResult todayInfo(PersonalAttendanceRecordsDto personalAttendanceRecordsDto){
         return AjaxResult.success(personalAttendanceRecordsService.todayInfo(personalAttendanceRecordsDto));
     }
 
     @ApiOperation("瀵煎嚭鎵撳崱绛惧埌")
     @PostMapping("/export")
+    @Log(title = "瀵煎嚭鎵撳崱绛惧埌", businessType = BusinessType.EXPORT)
     public void export(HttpServletResponse response, PersonalAttendanceRecordsDto personalAttendanceRecordsDto) {
         personalAttendanceRecordsService.export(response, personalAttendanceRecordsDto);
     }
diff --git a/src/main/java/com/ruoyi/staff/controller/PersonalShiftController.java b/src/main/java/com/ruoyi/staff/controller/PersonalShiftController.java
index 85ff013..c0a49d9 100644
--- a/src/main/java/com/ruoyi/staff/controller/PersonalShiftController.java
+++ b/src/main/java/com/ruoyi/staff/controller/PersonalShiftController.java
@@ -4,6 +4,8 @@
 import com.alibaba.excel.write.style.HorizontalCellStyleStrategy;
 import com.alibaba.excel.write.style.column.LongestMatchColumnWidthStyleStrategy;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.ruoyi.framework.aspectj.lang.annotation.Log;
+import com.ruoyi.framework.aspectj.lang.enums.BusinessType;
 import com.ruoyi.framework.web.domain.R;
 import com.ruoyi.staff.dto.PerformanceShiftAddDto;
 import com.ruoyi.staff.pojo.PersonalAttendanceLocationConfig;
@@ -41,24 +43,28 @@
 
     @ApiOperation("浜哄憳鎺掔彮")
     @PostMapping("/add")
+    @Log(title = "浜哄憳鎺掔彮", businessType = BusinessType.INSERT)
     public R add(@RequestBody PerformanceShiftAddDto performanceShiftAddDto){
         return R.ok(personalShiftService.performanceShiftAdd(performanceShiftAddDto));
     }
 
     @ApiOperation(value = "鏈堜唤鍒嗛〉鏌ヨ")
     @GetMapping("page")
+    @Log(title = "鏈堜唤鍒嗛〉鏌ヨ", businessType = BusinessType.OTHER)
     public R performanceShiftPage(Integer size, Integer current, String time, String userName, Integer sysDeptId) {
         return R.ok(personalShiftService.performanceShiftPage(new Page<>(current, size), time, userName, sysDeptId));
     }
 
     @ApiOperation(value = "骞翠唤鍒嗛〉鏌ヨ")
     @GetMapping("pageYear")
+    @Log(title = "骞翠唤鍒嗛〉鏌ヨ", businessType = BusinessType.OTHER)
     public R performanceShiftPageYear(Integer size, Integer current, String time, String userName, Integer sysDeptId) {
         return R.ok(personalShiftService.performanceShiftPageYear(new Page<>(current, size), time, userName, sysDeptId));
     }
 
     @ApiOperation(value = "鐝鐘舵�佷慨鏀�")
     @PostMapping("update")
+    @Log(title = "鐝鐘舵�佷慨鏀�", businessType = BusinessType.UPDATE)
     public R performanceShiftUpdate(@RequestBody PersonalShift personalShift) {
         personalShiftService.performanceShiftUpdate(personalShift);
         return R.ok();
@@ -66,6 +72,7 @@
 
     @ApiOperation(value = "瀵煎嚭")
     @GetMapping("export")
+    @Log(title = "瀵煎嚭", businessType = BusinessType.EXPORT)
     public void exportToExcel(@NotNull(message = "鏃堕棿涓嶈兘涓虹┖锛�") String time, String userName, Integer sysDeptId, Boolean isMonth, HttpServletResponse response) throws Exception {
         Map<Object, Object> data;
         response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
diff --git a/src/main/java/com/ruoyi/staff/controller/SchemeApplicableStaffController.java b/src/main/java/com/ruoyi/staff/controller/SchemeApplicableStaffController.java
index 39f1ef0..9f5f24c 100644
--- a/src/main/java/com/ruoyi/staff/controller/SchemeApplicableStaffController.java
+++ b/src/main/java/com/ruoyi/staff/controller/SchemeApplicableStaffController.java
@@ -36,6 +36,7 @@
 
     @GetMapping("/listPage")
     @ApiOperation(value = "鍒嗛〉鏌ヨ")
+    @Log(title = "鍒嗛〉鏌ヨ", businessType = BusinessType.OTHER)
     public AjaxResult listPage(Page page, SchemeApplicableStaff schemeApplicableStaff) {
         return schemeApplicableStaffService.listPage(page,schemeApplicableStaff);
     }
diff --git a/src/main/java/com/ruoyi/staff/controller/StaffContractController.java b/src/main/java/com/ruoyi/staff/controller/StaffContractController.java
index 3614ea8..6d6dff8 100644
--- a/src/main/java/com/ruoyi/staff/controller/StaffContractController.java
+++ b/src/main/java/com/ruoyi/staff/controller/StaffContractController.java
@@ -1,6 +1,8 @@
 package com.ruoyi.staff.controller;
 
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.ruoyi.framework.aspectj.lang.annotation.Log;
+import com.ruoyi.framework.aspectj.lang.enums.BusinessType;
 import com.ruoyi.framework.web.domain.AjaxResult;
 import com.ruoyi.staff.pojo.StaffContract;
 import com.ruoyi.staff.service.StaffContractService;
@@ -30,6 +32,7 @@
      */
     @GetMapping("/listPage")
     @ApiOperation("鍛樺伐鍚堝悓鍒嗛〉鏌ヨ")
+    @Log(title = "鍛樺伐鍚堝悓鍒嗛〉鏌ヨ", businessType = BusinessType.OTHER)
     public AjaxResult staffContractListPage(Page page, StaffContract staffContract) {
         return AjaxResult.success(staffContractService.staffContractListPage(page, staffContract));
     }
diff --git a/src/main/java/com/ruoyi/staff/controller/StaffLeaveController.java b/src/main/java/com/ruoyi/staff/controller/StaffLeaveController.java
index 21e00b6..75acf88 100644
--- a/src/main/java/com/ruoyi/staff/controller/StaffLeaveController.java
+++ b/src/main/java/com/ruoyi/staff/controller/StaffLeaveController.java
@@ -1,6 +1,8 @@
 package com.ruoyi.staff.controller;
 
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.ruoyi.framework.aspectj.lang.annotation.Log;
+import com.ruoyi.framework.aspectj.lang.enums.BusinessType;
 import com.ruoyi.framework.web.domain.AjaxResult;
 import com.ruoyi.staff.dto.StaffLeaveDto;
 import com.ruoyi.staff.service.StaffLeaveService;
@@ -30,6 +32,7 @@
      */
     @GetMapping("/listPage")
     @ApiOperation("鏂板绂昏亴鍒嗛〉鏌ヨ")
+    @Log(title = "鏂板绂昏亴鍒嗛〉鏌ヨ", businessType = BusinessType.OTHER)
     public AjaxResult staffLeaveListPage(Page page, StaffLeaveDto staffLeaveDto) {
         return AjaxResult.success(staffLeaveService.staffLeaveListPage(page, staffLeaveDto));
     }
@@ -41,6 +44,7 @@
      */
     @PostMapping("")
     @ApiOperation("鏂板绂昏亴")
+    @Log(title = "鏂板绂昏亴", businessType = BusinessType.INSERT)
     public AjaxResult add(@RequestBody StaffLeaveDto staffLeaveDto) {
         return AjaxResult.success(staffLeaveService.add(staffLeaveDto));
     }
@@ -53,6 +57,7 @@
      */
     @PutMapping("/{id}")
     @ApiOperation("鏇存柊绂昏亴淇℃伅")
+    @Log(title = "鏇存柊绂昏亴淇℃伅", businessType = BusinessType.UPDATE)
     public AjaxResult update(@PathVariable("id") Long id, @RequestBody StaffLeaveDto staffLeaveDto) {
         return AjaxResult.success(staffLeaveService.update(id, staffLeaveDto));
     }
@@ -64,6 +69,7 @@
      */
     @DeleteMapping("/del")
     @ApiOperation("鍒犻櫎鍏ヨ亴")
+    @Log(title = "鍒犻櫎鍏ヨ亴", businessType = BusinessType.DELETE)
     public AjaxResult del(@RequestBody List<Integer> ids) {
         if(CollectionUtils.isEmpty(ids)){
             return AjaxResult.error("璇烽�夋嫨鑷冲皯涓�鏉℃暟鎹�");
@@ -77,6 +83,7 @@
      */
     @PostMapping("/export")
     @ApiOperation("绂昏亴瀵煎嚭")
+    @Log(title = "绂昏亴瀵煎嚭", businessType = BusinessType.EXPORT)
     public void export(HttpServletResponse response, StaffLeaveDto staffLeaveDto) {
         staffLeaveService.export(response, staffLeaveDto);
     }
diff --git a/src/main/java/com/ruoyi/staff/controller/StaffOnJobController.java b/src/main/java/com/ruoyi/staff/controller/StaffOnJobController.java
index 625ce34..9e56328 100644
--- a/src/main/java/com/ruoyi/staff/controller/StaffOnJobController.java
+++ b/src/main/java/com/ruoyi/staff/controller/StaffOnJobController.java
@@ -39,6 +39,7 @@
      */
     @GetMapping("/listPage")
     @ApiOperation("鍦ㄨ亴鍛樺伐鍙拌处鍒嗛〉鏌ヨ")
+    @Log(title = "鍦ㄨ亴鍛樺伐鍙拌处鍒嗛〉鏌ヨ", businessType = BusinessType.OTHER)
     public AjaxResult staffOnJobListPage(Page page, StaffOnJob staffOnJob) {
         return AjaxResult.success(staffOnJobService.staffOnJobListPage(page, staffOnJob));
     }
@@ -49,6 +50,7 @@
      */
     @GetMapping("/list")
     @ApiOperation("鍦ㄨ亴鍛樺伐涓嬫媺(鏂板绂昏亴鐢�)")
+    @Log(title = "鍦ㄨ亴鍛樺伐涓嬫媺(鏂板绂昏亴鐢�)", businessType = BusinessType.OTHER)
     public AjaxResult staffOnJobList(StaffOnJob staffOnJob) {
         return AjaxResult.success(staffOnJobService.staffOnJobList(staffOnJob));
     }
@@ -60,6 +62,7 @@
      */
     @PostMapping("")
     @ApiOperation("鏂板鍏ヨ亴")
+    @Log(title = "鏂板鍏ヨ亴", businessType = BusinessType.INSERT)
     public AjaxResult add(@RequestBody StaffOnJobDto staffOnJob) {
         return AjaxResult.success(staffOnJobService.add(staffOnJob));
     }
@@ -71,6 +74,7 @@
      */
     @PutMapping("/{id}")
     @ApiOperation("鏇存柊鍏ヨ亴淇℃伅")
+    @Log(title = "鏇存柊鍏ヨ亴淇℃伅", businessType = BusinessType.UPDATE)
     public AjaxResult update(@PathVariable("id") Long id, @RequestBody StaffOnJobDto staffOnJobDto) {
         return AjaxResult.success(staffOnJobService.update(id, staffOnJobDto));
     }
@@ -82,6 +86,7 @@
      */
     @DeleteMapping("/del")
     @ApiOperation("鍒犻櫎鍏ヨ亴")
+    @Log(title = "鍒犻櫎鍏ヨ亴", businessType = BusinessType.DELETE)
     public AjaxResult delStaffOnJobs(@RequestBody List<Integer> ids) {
         if(CollectionUtils.isEmpty(ids)){
             return AjaxResult.error("璇烽�夋嫨鑷冲皯涓�鏉℃暟鎹�");
@@ -96,6 +101,7 @@
      */
     @GetMapping("/{id}")
     @ApiOperation("鍦ㄨ亴鍛樺伐璇︽儏")
+    @Log(title = "鍦ㄨ亴鍛樺伐璇︽儏", businessType = BusinessType.OTHER)
     public AjaxResult staffOnJobDetail(@PathVariable("id") Long id) {
         return AjaxResult.success(staffOnJobService.staffOnJobDetail(id));
     }
@@ -108,6 +114,7 @@
      */
     @PostMapping("/renewContract/{id}")
     @ApiOperation("缁鍚堝悓")
+    @Log(title = "缁鍚堝悓", businessType = BusinessType.UPDATE)
     public AjaxResult renewContract(@PathVariable("id") Long id, @RequestBody StaffContract staffContract) {
         return AjaxResult.success(staffOnJobService.renewContract(id, staffContract));
     }
@@ -133,6 +140,7 @@
      */
     @PostMapping("/export")
     @ApiOperation("鍦ㄨ亴鍛樺伐瀵煎嚭")
+    @Log(title = "鍦ㄨ亴鍛樺伐瀵煎嚭", businessType = BusinessType.EXPORT)
     public void staffOnJobExport(HttpServletResponse response,StaffOnJob staffOnJob) {
         staffOnJobService.staffOnJobExport(response, staffOnJob);
     }
@@ -144,6 +152,7 @@
      */
     @PostMapping("/exportCopy")
     @ApiOperation("word妯℃澘鍚堝悓鍦ㄨ亴鍛樺伐瀵煎嚭")
+    @Log(title = "word妯℃澘鍚堝悓鍦ㄨ亴鍛樺伐瀵煎嚭", businessType = BusinessType.EXPORT)
     public AjaxResult exportCopy(HttpServletResponse response,@RequestBody StaffOnJob staffOnJob) throws Exception{
        return AjaxResult.success(staffOnJobService.exportCopy(response, staffOnJob));
     }
diff --git a/src/main/java/com/ruoyi/staff/controller/StaffSalaryMainController.java b/src/main/java/com/ruoyi/staff/controller/StaffSalaryMainController.java
index ad43b6c..a40f338 100644
--- a/src/main/java/com/ruoyi/staff/controller/StaffSalaryMainController.java
+++ b/src/main/java/com/ruoyi/staff/controller/StaffSalaryMainController.java
@@ -34,12 +34,14 @@
 
     @GetMapping("/listPage")
     @ApiOperation("鍛樺伐宸ヨ祫涓昏〃鍒嗛〉鏌ヨ")
+    @Log(title = "鍛樺伐宸ヨ祫涓昏〃鍒嗛〉鏌ヨ", businessType = BusinessType.OTHER)
     public AjaxResult listPage(Page page, StaffSalaryMain staffSalaryMain) {
         return staffSalaryMainService.listPage(page, staffSalaryMain);
     }
 
     @ApiOperation("閫氳繃閮ㄩ棬ids鑾峰彇鐢ㄦ埛淇℃伅璁$畻姣忎釜鍛樺伐鐨勫伐璧�")
     @PostMapping("/calculateSalary")
+    @Log(title = "閫氳繃閮ㄩ棬ids鑾峰彇鐢ㄦ埛淇℃伅璁$畻姣忎釜鍛樺伐鐨勫伐璧�", businessType = BusinessType.OTHER)
     public AjaxResult calculateSalary(@RequestBody CalculateSalaryDto calculateSalaryDto) {
         return staffSalaryMainService.calculateSalary(calculateSalaryDto);
     }
diff --git a/src/main/java/com/ruoyi/staff/controller/StaffSchedulingController.java b/src/main/java/com/ruoyi/staff/controller/StaffSchedulingController.java
index e7d41e2..83f665f 100644
--- a/src/main/java/com/ruoyi/staff/controller/StaffSchedulingController.java
+++ b/src/main/java/com/ruoyi/staff/controller/StaffSchedulingController.java
@@ -35,12 +35,14 @@
 
     @PostMapping("/listPage")
     @ApiOperation("鎺掔彮鍒嗛〉鏌ヨ")
+    @Log(title = "鎺掔彮鍒嗛〉鏌ヨ", businessType = BusinessType.OTHER)
     public AjaxResult listPage(@RequestBody SearchSchedulingVo vo){
        return AjaxResult.success(staffSchedulingService.listPage(vo));
     }
 
     @PostMapping("/save")
     @ApiOperation("淇濆瓨鎺掔彮")
+    @Log(title = "淇濆瓨鎺掔彮", businessType = BusinessType.UPDATE)
     public AjaxResult save(@RequestBody @Validated SaveStaffSchedulingDto saveStaffSchedulingDto){
         staffSchedulingService.saveStaffScheduling(saveStaffSchedulingDto);
         return AjaxResult.success();
@@ -48,6 +50,7 @@
 
     @DeleteMapping("/delByIds")
     @ApiOperation("鎵归噺鍒犻櫎鎺掔彮")
+    @Log(title = "鎵归噺鍒犻櫎鎺掔彮", businessType = BusinessType.DELETE)
     public AjaxResult delByIds(@RequestBody List<Integer> ids){
         staffSchedulingService.removeByIds(ids);
         return AjaxResult.success();
@@ -55,6 +58,7 @@
 
     @DeleteMapping("/del/{id}")
     @ApiOperation("鍒犻櫎鎺掔彮")
+    @Log(title = "鍒犻櫎鎺掔彮", businessType = BusinessType.DELETE)
     public AjaxResult del(@PathVariable("id") Integer id){
         staffSchedulingService.removeById(id);
         return AjaxResult.success();
@@ -65,6 +69,7 @@
      */
     @GetMapping("/getCurrentUserLatestScheduling")
     @ApiOperation("鑾峰彇褰撳墠鐢ㄦ埛鏈�鏂版帓鐝褰�")
+    @Log(title = "鑾峰彇褰撳墠鐢ㄦ埛鏈�鏂版帓鐝褰�", businessType = BusinessType.OTHER)
     public AjaxResult getCurrentUserLatestScheduling(){
         return AjaxResult.success(staffSchedulingService.getCurrentUserLatestScheduling());
     }

--
Gitblit v1.9.3