From 895ed97195660b0196b61f5da626ac6d18e2068d Mon Sep 17 00:00:00 2001
From: luodangjia <luodangjia>
Date: 星期三, 22 一月 2025 11:54:52 +0800
Subject: [PATCH] 1

---
 ruoyi-api/ruoyi-api-company/src/main/java/com/ruoyi/company/api/domain/excel/MgtCompanyExcel.java         |    6 
 ruoyi-auth/src/main/java/com/ruoyi/auth/controller/TokenController.java                                   |   38 +--
 ruoyi-modules/ruoyi-company/src/main/java/com/ruoyi/company/utils/AliyunCloudAuthUtil.java                |   68 +++++++
 ruoyi-api/ruoyi-api-company/src/main/java/com/ruoyi/company/api/model/RegisterUser.java                   |    2 
 ruoyi-modules/ruoyi-company/pom.xml                                                                       |    5 
 doc/aa.json                                                                                               |  236 +------------------------
 ruoyi-auth/src/main/java/com/ruoyi/auth/service/SysLoginService.java                                      |   76 +++----
 ruoyi-modules/ruoyi-company/src/main/java/com/ruoyi/company/controller/front/CompanyController.java       |   16 +
 ruoyi-api/ruoyi-api-company/src/main/java/com/ruoyi/company/api/factory/RemoteCompanyFallbackFactory.java |    2 
 ruoyi-modules/ruoyi-company/src/main/java/com/ruoyi/company/service/impl/CompanyServiceImpl.java          |   32 ++-
 ruoyi-modules/ruoyi-company/src/main/resources/bootstrap.yml                                              |    2 
 pom.xml                                                                                                   |    6 
 12 files changed, 190 insertions(+), 299 deletions(-)

diff --git a/doc/aa.json b/doc/aa.json
index be35ff6..3be660a 100644
--- a/doc/aa.json
+++ b/doc/aa.json
@@ -1,234 +1,26 @@
 {
   "headers": {
     "access-control-allow-origin": "*",
-    "date": "Tue, 21 Jan 2025 09:11:42 GMT",
+    "date": "Wed, 22 Jan 2025 02:32:31 GMT",
+    "content-length": "181",
     "keep-alive": "timeout=25",
-    "transfer-encoding": "chunked",
-    "vary": "Accept-Encoding",
-    "x-acs-request-id": "05842EC7-FAA4-5BF7-9C8E-BD7E705262BF",
+    "x-acs-request-id": "C4D08986-F48C-5AB0-81BB-EA6D3E641261",
     "connection": "keep-alive",
     "content-type": "application/json;charset=utf-8",
+    "etag": "1oG9IxMCzf0kauAjlE63lUw1",
     "access-control-expose-headers": "*",
-    "x-acs-trace-id": "200f635b624967d00167ded6423480c0"
+    "x-acs-trace-id": "726453953e55e52583454e3eef889146"
   },
   "body": {
-    "RequestId": "05842EC7-FAA4-5BF7-9C8E-BD7E705262BF",
-    "Data": {
-      "SubImages": [
-        {
-          "FigureInfo": {
-            "blicense_title": {
-              "FigureCount": 1,
-              "FigureDetails": [
-                {
-                  "FigurePoints": [
-                    {
-                      "X": 648,
-                      "Y": 311
-                    },
-                    {
-                      "X": 1111,
-                      "Y": 312
-                    },
-                    {
-                      "X": 1112,
-                      "Y": 415
-                    },
-                    {
-                      "X": 648,
-                      "Y": 414
-                    }
-                  ],
-                  "FigureAngle": 0
-                }
-              ]
-            },
-            "national_emblem": {
-              "FigureCount": 1,
-              "FigureDetails": [
-                {
-                  "FigurePoints": [
-                    {
-                      "X": 787,
-                      "Y": 141
-                    },
-                    {
-                      "X": 965,
-                      "Y": 141
-                    },
-                    {
-                      "X": 964,
-                      "Y": 265
-                    },
-                    {
-                      "X": 786,
-                      "Y": 264
-                    }
-                  ],
-                  "FigureAngle": 0
-                }
-              ]
-            }
-          },
-          "SubImageId": 0,
-          "KvInfo": {
-            "KvCount": 14,
-            "Data": {
-              "RegistrationDate": "2022年08月11日",
-              "companyType": "其他有限责任公司",
-              "companyName": "新疆新省事大数据有限公司",
-              "businessScope": "许可项目:第一类增值电信业务:建筑智能化系统设计;农作物种子进出口;建设工程设计;建设工程施工;住宅室内装饰装修。(依法须经批准的项目,经相关部门批准后方可升展经营活动,具体经营项目以相关部门批准文件或许可证件为准)一般项目:数据处理和存储支持服务:人工智能理论与算法软件开发:智能机器人的研发;云计算装备技术服务;云计算设备销售;数字内容制作服务(不含出版发行);通信设备销售;安防设备销售:信息安全设备销售:信息安全设备制造:卫星导航服务;导航终端销售;导航终端制造;导航、测绘、气象及海洋专用仪器销售;环境保护专用设备销售;光通信设备销售;技术服务、技术开发、技术咨询、技术交流、技术转让、技术推广:软件开发:信息系统集成服务:卫星技术综合应用系统集成:货物进出口;农副产品销售:食品进出口:酒店管理:物业管理:广告发布;广告设计、代理;广告制作;第一类医疗器械销售;第二类医疗器栈销售;教育咨询服务(不含涉许可审批的教育培训活动);大数据服务;互联网数据服务;物联网应用服务;安全技术防范系统设计施工服务;信息系统运行维护服务:数据处理服务:信息技术咨询服务;5G通信技术服务;工业工程设计服务;移动通信设备制造;移动通信设备销售;通信传输设备专业修理;通信交换设备专业修理;网络设备制造:网络设备销售;普通机械设备安装服务;计算机软硬件及辅助设备零售;计算机软硬件及辅助设备批发;计算机软硬件及外围设备制造:平面设计;技术进出口:劳务服务(不含劳务派遣)。(除依法须经批准的项目外,凭营业执照依法自主开展经营活动)",
-              "title": "营业执照",
-              "validPeriod": "",
-              "companyForm": "",
-              "creditCode": "91650106MABWEMX61X",
-              "registeredCapital": "壹仟万元整",
-              "legalPerson": "张丹",
-              "validFromDate": "20220811",
-              "businessAddress": "新疆乌鲁木齐经济技术开发区(头屯河区)玄武湖路433号经开万达广场12号写字楼办公1217室",
-              "issueDate": "2023年07月21日",
-              "validToDate": ""
-            },
-            "KvDetails": {
-              "RegistrationDate": {
-                "KeyName": "RegistrationDate",
-                "ValueAngle": 0,
-                "Value": "2022年08月11日",
-                "KeyConfidence": 96,
-                "ValueConfidence": 96
-              },
-              "companyType": {
-                "KeyName": "companyType",
-                "ValueAngle": 0,
-                "Value": "其他有限责任公司",
-                "KeyConfidence": 100,
-                "ValueConfidence": 100
-              },
-              "companyName": {
-                "KeyName": "companyName",
-                "ValueAngle": 0,
-                "Value": "新疆新省事大数据有限公司",
-                "KeyConfidence": 100,
-                "ValueConfidence": 100
-              },
-              "businessScope": {
-                "KeyName": "businessScope",
-                "ValueAngle": 0,
-                "Value": "许可项目:第一类增值电信业务:建筑智能化系统设计;农作物种子进出口;建设工程设计;建设工程施工;住宅室内装饰装修。(依法须经批准的项目,经相关部门批准后方可升展经营活动,具体经营项目以相关部门批准文件或许可证件为准)一般项目:数据处理和存储支持服务:人工智能理论与算法软件开发:智能机器人的研发;云计算装备技术服务;云计算设备销售;数字内容制作服务(不含出版发行);通信设备销售;安防设备销售:信息安全设备销售:信息安全设备制造:卫星导航服务;导航终端销售;导航终端制造;导航、测绘、气象及海洋专用仪器销售;环境保护专用设备销售;光通信设备销售;技术服务、技术开发、技术咨询、技术交流、技术转让、技术推广:软件开发:信息系统集成服务:卫星技术综合应用系统集成:货物进出口;农副产品销售:食品进出口:酒店管理:物业管理:广告发布;广告设计、代理;广告制作;第一类医疗器械销售;第二类医疗器栈销售;教育咨询服务(不含涉许可审批的教育培训活动);大数据服务;互联网数据服务;物联网应用服务;安全技术防范系统设计施工服务;信息系统运行维护服务:数据处理服务:信息技术咨询服务;5G通信技术服务;工业工程设计服务;移动通信设备制造;移动通信设备销售;通信传输设备专业修理;通信交换设备专业修理;网络设备制造:网络设备销售;普通机械设备安装服务;计算机软硬件及辅助设备零售;计算机软硬件及辅助设备批发;计算机软硬件及外围设备制造:平面设计;技术进出口:劳务服务(不含劳务派遣)。(除依法须经批准的项目外,凭营业执照依法自主开展经营活动)",
-                "KeyConfidence": 99,
-                "ValueConfidence": 98
-              },
-              "title": {
-                "KeyName": "title",
-                "ValueAngle": 0,
-                "Value": "营业执照",
-                "KeyConfidence": 100,
-                "ValueConfidence": 100
-              },
-              "companyForm": {
-                "KeyName": "companyForm",
-                "Value": "",
-                "KeyConfidence": 100,
-                "ValueConfidence": 100
-              },
-              "validPeriod": {
-                "KeyName": "validPeriod",
-                "Value": "",
-                "KeyConfidence": 100,
-                "ValueConfidence": 100
-              },
-              "creditCode": {
-                "KeyName": "creditCode",
-                "ValueAngle": 1,
-                "Value": "91650106MABWEMX61X",
-                "KeyConfidence": 100,
-                "ValueConfidence": 100
-              },
-              "registeredCapital": {
-                "KeyName": "registeredCapital",
-                "ValueAngle": 0,
-                "Value": "壹仟万元整",
-                "KeyConfidence": 100,
-                "ValueConfidence": 100
-              },
-              "legalPerson": {
-                "KeyName": "legalPerson",
-                "ValueAngle": 0,
-                "Value": "张丹",
-                "KeyConfidence": 100,
-                "ValueConfidence": 100
-              },
-              "validFromDate": {
-                "KeyName": "validFromDate",
-                "ValueAngle": 0,
-                "Value": "20220811",
-                "KeyConfidence": 100,
-                "ValueConfidence": 96
-              },
-              "issueDate": {
-                "KeyName": "issueDate",
-                "ValueAngle": 0,
-                "Value": "2023年07月21日",
-                "KeyConfidence": 100,
-                "ValueConfidence": 100
-              },
-              "businessAddress": {
-                "KeyName": "businessAddress",
-                "ValueAngle": 0,
-                "Value": "新疆乌鲁木齐经济技术开发区(头屯河区)玄武湖路433号经开万达广场12号写字楼办公1217室",
-                "KeyConfidence": 100,
-                "ValueConfidence": 100
-              },
-              "validToDate": {
-                "KeyName": "validToDate",
-                "Value": "",
-                "KeyConfidence": 100,
-                "ValueConfidence": 100
-              }
-            }
-          },
-          "QualityInfo": {
-            "IsCopy": false
-          },
-          "BarCodeInfo": {
-            "BarCodeDetails": [],
-            "BarCodeCount": 0
-          },
-          "Type": "营业执照",
-          "QrCodeInfo": {
-            "QrCodeDetails": [
-              {
-                "QrCodeAngle": 0,
-                "Data": "http://www.gsxt.gov.cn/index.html?uniscid=91650106MABWEMX61X",
-                "QrCodePoints": [
-                  {
-                    "X": 1324,
-                    "Y": 309
-                  },
-                  {
-                    "X": 1457,
-                    "Y": 309
-                  },
-                  {
-                    "X": 1457,
-                    "Y": 442
-                  },
-                  {
-                    "X": 1324,
-                    "Y": 442
-                  }
-                ]
-              }
-            ],
-            "QrCodeCount": 1
-          },
-          "Angle": 0
-        }
-      ],
-      "Height": 1280,
-      "SubImageCount": 1,
-      "Width": 1755
+    "Message": "success",
+    "RequestId": "C4D08986-F48C-5AB0-81BB-EA6D3E641261",
+    "Code": "Success",
+    "Result": {
+      "Status": "1",
+      "OpenTime": "2022-08-11/9999-09-09",
+      "ReasonCode": "100",
+      "BizCode": "1"
     }
   },
   "statusCode": 200
-}
\ No newline at end of file
+}
diff --git a/pom.xml b/pom.xml
index 81e8034..71c0268 100644
--- a/pom.xml
+++ b/pom.xml
@@ -337,6 +337,12 @@
                 <artifactId>cloudauth20190307</artifactId>
                 <version>${aliyun-cloudauth.version}</version>
             </dependency>
+
+            <dependency>
+                <groupId>com.aliyun</groupId>
+                <artifactId>cloudauth20221125</artifactId>
+                <version>1.1.1</version>
+            </dependency>
         </dependencies>
     </dependencyManagement>
 
diff --git a/ruoyi-api/ruoyi-api-company/src/main/java/com/ruoyi/company/api/domain/excel/MgtCompanyExcel.java b/ruoyi-api/ruoyi-api-company/src/main/java/com/ruoyi/company/api/domain/excel/MgtCompanyExcel.java
index 5682961..f5e0a32 100644
--- a/ruoyi-api/ruoyi-api-company/src/main/java/com/ruoyi/company/api/domain/excel/MgtCompanyExcel.java
+++ b/ruoyi-api/ruoyi-api-company/src/main/java/com/ruoyi/company/api/domain/excel/MgtCompanyExcel.java
@@ -14,7 +14,7 @@
 public class MgtCompanyExcel {
 
     /** 公司名称 */
-    @ExcelProperty(value = "公司名称")
+    @ExcelProperty(value = "企业名称")
     private String companyName;
 
     @ExcelProperty(value = "法人")
@@ -29,10 +29,10 @@
     @ExcelProperty(value = "联系人")
     private String contactName;
 
-    @ExcelProperty(value = "联系人方式")
+    @ExcelProperty(value = "联系方式")
     private String contactPhone;
 
-    @ExcelProperty(value = "注册时间")
+    @ExcelProperty(value = "注册时间",format = "yyyy-MM-dd")
     @JsonFormat(pattern = "yyyy-MM-dd")
     private LocalDateTime createTime;
 
diff --git a/ruoyi-api/ruoyi-api-company/src/main/java/com/ruoyi/company/api/factory/RemoteCompanyFallbackFactory.java b/ruoyi-api/ruoyi-api-company/src/main/java/com/ruoyi/company/api/factory/RemoteCompanyFallbackFactory.java
index dbbeb81..aa6185c 100644
--- a/ruoyi-api/ruoyi-api-company/src/main/java/com/ruoyi/company/api/factory/RemoteCompanyFallbackFactory.java
+++ b/ruoyi-api/ruoyi-api-company/src/main/java/com/ruoyi/company/api/factory/RemoteCompanyFallbackFactory.java
@@ -6,6 +6,7 @@
 import lombok.extern.log4j.Log4j2;
 import org.springframework.cloud.openfeign.FallbackFactory;
 import org.springframework.stereotype.Component;
+import org.springframework.web.bind.annotation.GetMapping;
 
 import java.util.List;
 
@@ -16,6 +17,7 @@
     public RemoteCompanyService create(Throwable cause) {
         return new RemoteCompanyService() {
 
+            @GetMapping("/front/company/getCompanyByUserId")
             @Override
             public R<List<Company>> getCompanyByUserId(Long userId, String source) {
                 return R.fail(cause.getMessage());
diff --git a/ruoyi-api/ruoyi-api-company/src/main/java/com/ruoyi/company/api/model/RegisterUser.java b/ruoyi-api/ruoyi-api-company/src/main/java/com/ruoyi/company/api/model/RegisterUser.java
index d322d3a..3eac8dc 100644
--- a/ruoyi-api/ruoyi-api-company/src/main/java/com/ruoyi/company/api/model/RegisterUser.java
+++ b/ruoyi-api/ruoyi-api-company/src/main/java/com/ruoyi/company/api/model/RegisterUser.java
@@ -81,5 +81,7 @@
     @Schema(description = "联系人邮箱")
     private String email;
 
+    private String code;
+
 
 }
diff --git a/ruoyi-auth/src/main/java/com/ruoyi/auth/controller/TokenController.java b/ruoyi-auth/src/main/java/com/ruoyi/auth/controller/TokenController.java
index 11d5c34..340dd9b 100644
--- a/ruoyi-auth/src/main/java/com/ruoyi/auth/controller/TokenController.java
+++ b/ruoyi-auth/src/main/java/com/ruoyi/auth/controller/TokenController.java
@@ -17,7 +17,9 @@
 import com.ruoyi.common.security.auth.AuthUtil;
 import com.ruoyi.common.security.service.TokenService;
 import com.ruoyi.common.security.utils.SecurityUtils;
+import com.ruoyi.company.api.RemoteCompanyService;
 import com.ruoyi.company.api.RemoteCompanyUserService;
+import com.ruoyi.company.api.domain.Company;
 import com.ruoyi.company.api.domain.User;
 import com.ruoyi.company.api.domain.dto.MgtCompanyDTO;
 import com.ruoyi.company.api.model.RegisterUser;
@@ -35,6 +37,7 @@
 import javax.servlet.http.HttpServletRequest;
 import javax.validation.Valid;
 import java.util.HashMap;
+import java.util.List;
 import java.util.Map;
 import java.util.concurrent.TimeUnit;
 /**
@@ -58,6 +61,9 @@
 
     @Resource
     private RemoteCompanyUserService remoteCompanyUserService;
+    @Resource
+    private RemoteCompanyService remoteCompanyService;
+
     @Operation(summary = "管理端-登录")
     @PostMapping("login")
     public R<?> login(@RequestBody LoginBody form)
@@ -184,7 +190,7 @@
     @PostMapping("smsLogin")
     @Operation(summary = "验证码登录",description = "验证码登录")
     public R<Map<String, Object>> smsLogin(@RequestBody RegisterUser registerUser){
-        String smsCode = registerUser.getSmsCode();
+        String smsCode = registerUser.getCode();
         if (!"999999".equals(smsCode)) {
             String verifyKey = CacheConstants.PHONE_CODE_KEY + StringUtils.nvl(registerUser.getPhone(), "");
             String captcha = redisService.getCacheObject(verifyKey);
@@ -224,31 +230,21 @@
     public R<?> check(@RequestBody RegisterUser registerUser)
     {
         String accountName = registerUser.getAccountName();
-        R<User> userByPhoneR = remoteCompanyUserService.getUserByPhone(accountName, SecurityConstants.INNER);
-        if (R.isError(userByPhoneR)) {
-            throw new RuntimeException(userByPhoneR.getMsg());
-        }
-        boolean check = false;
-        R<User> userR = new R<>();
-        if (userByPhoneR.getData() != null) {
-            check = sysLoginService.check(userByPhoneR.getData(), registerUser.getCompanyName(), registerUser.getIdCardNumber());
-        }
-        if (!check){
-            userR = remoteCompanyUserService.getUserByAccountName(accountName, SecurityConstants.INNER);
-            if (R.isError(userR)) {
-                return R.fail("账号不存在");
-            }
-            if (userR.getData() == null) {
-                return R.fail("账号不存在");
-            }
-            check = sysLoginService.check(userR.getData(), registerUser.getCompanyName(), registerUser.getIdCardNumber());
-        }
-        if (!check) {
+        R<User> userR = remoteCompanyUserService.getUserByPhone(accountName, SecurityConstants.INNER);
+        R<User> userR2 = remoteCompanyUserService.getUserByAccountName(accountName, SecurityConstants.INNER);
+
+        User user = userR.getData();
+        Boolean flag = sysLoginService.check(user, registerUser.getCompanyName(), registerUser.getIdCardNumber());
+        User user1 = userR2.getData();
+        Boolean flag1 = sysLoginService.check(user1, registerUser.getCompanyName(), registerUser.getIdCardNumber());
+        if (!flag1 && !flag){
             return R.fail("账号不存在");
         }
         return R.ok();
     }
 
+
+
     /**
      * 重置密码
      */
diff --git a/ruoyi-auth/src/main/java/com/ruoyi/auth/service/SysLoginService.java b/ruoyi-auth/src/main/java/com/ruoyi/auth/service/SysLoginService.java
index 7570b9a..3450f8b 100644
--- a/ruoyi-auth/src/main/java/com/ruoyi/auth/service/SysLoginService.java
+++ b/ruoyi-auth/src/main/java/com/ruoyi/auth/service/SysLoginService.java
@@ -205,59 +205,51 @@
 
 
     public void resetPwd(RegisterUser registerUser) {
-        R<User> userR = resetPwdCheck(registerUser);
+        String accountName = registerUser.getAccountName();
+        R<User> userR = remoteCompanyUserService.getUserByPhone(accountName, SecurityConstants.INNER);
+        R<User> userR2 = remoteCompanyUserService.getUserByAccountName(accountName, SecurityConstants.INNER);
+
         User user = userR.getData();
+        Boolean flag = check(user, registerUser.getCompanyName(), registerUser.getIdCardNumber());
+        User user1 = userR2.getData();
+        Boolean flag1 = check(user1, registerUser.getCompanyName(), registerUser.getIdCardNumber());
+
+        if (!flag1 && !flag){
+            throw new ServiceException("账号不存在");
+        }
+        User user2;
+        if (flag){
+            user2 = user;
+        }else {
+            user2 = user1;
+        }
+
         String password = SecurityUtils.encryptPassword(registerUser.getPassword());
-        user.setPassword(password);
-        R<Void> r = remoteCompanyUserService.updateUser(user);
+        user2.setPassword(password);
+        R<Void> r = remoteCompanyUserService.updateUser(user2);
         if (R.isError(r)) {
             throw new ServiceException(userR.getMsg());
         }
     }
 
-    public R<User> resetPwdCheck(RegisterUser registerUser) {
-        String accountName = registerUser.getAccountName();
-        R<User> userByPhoneR = remoteCompanyUserService.getUserByPhone(accountName, SecurityConstants.INNER);
-        if (R.isError(userByPhoneR)) {
-            throw new RuntimeException(userByPhoneR.getMsg());
-        }
-        boolean check = false;
-        R<User> userR = new R<>();
-        if (userByPhoneR.getData() != null) {
-            check = check(userByPhoneR.getData(), registerUser.getCompanyName(), registerUser.getIdCardNumber());
-        }
-        if (!check){
-            userR = remoteCompanyUserService.getUserByAccountName(accountName, SecurityConstants.INNER);
-            if (R.isError(userR)) {
-                throw new RuntimeException(userR.getMsg());
+
+    public Boolean check(User user, String companyName, String idCardNumber) {
+        boolean flag = true;
+        if (user != null){
+            R<List<Company>> companyListR = remoteCompanyService.getCompanyByUserId(user.getUserId(), SecurityConstants.INNER);
+            List<Company> companyList = companyListR.getData();
+            long count = companyList.stream().filter(company -> company.getCompanyName()
+                    .equals(companyName) && company.getIdCardNumber().equals(idCardNumber)).count();
+            if (count == 0) {
+                flag = false;
             }
-            if (userR.getData() == null) {
-                throw new RuntimeException("账号不存在");
-            }
-            check = check(userR.getData(), registerUser.getCompanyName(), registerUser.getIdCardNumber());
+        }else {
+            flag = false;
         }
-        if (!check) {
-            throw new RuntimeException("账号不存在");
-        }
-        return userR;
+        return flag;
     }
 
-    public boolean check(User user, String companyName, String idCardNumber) {
-        Long userId = user.getUserId();
-        R<List<Company>> companyR = remoteCompanyService.getCompanyByUserId(userId, SecurityConstants.INNER);
-        if (R.isError(companyR)) {
-            throw new ServiceException(companyR.getMsg());
-        }
-        List<Company> companyList = companyR.getData();
-        if (companyList != null) {
-            long count = companyList.stream()
-                    .filter(company -> company.getCompanyName().equals(companyName) &&
-                            company.getIdCardNumber().equals(idCardNumber))
-                    .count();
-            return count > 0;
-        }
-        return false;
-    }
+
 
     /**
      * 管理端-修改密码
diff --git a/ruoyi-modules/ruoyi-company/pom.xml b/ruoyi-modules/ruoyi-company/pom.xml
index 9e2e8be..c74f4f8 100644
--- a/ruoyi-modules/ruoyi-company/pom.xml
+++ b/ruoyi-modules/ruoyi-company/pom.xml
@@ -114,6 +114,11 @@
       <groupId>com.aliyun</groupId>
       <artifactId>cloudauth20190307</artifactId>
     </dependency>
+
+    <dependency>
+      <groupId>com.aliyun</groupId>
+      <artifactId>cloudauth20221125</artifactId>
+    </dependency>
   </dependencies>
 
   <build>
diff --git a/ruoyi-modules/ruoyi-company/src/main/java/com/ruoyi/company/controller/front/CompanyController.java b/ruoyi-modules/ruoyi-company/src/main/java/com/ruoyi/company/controller/front/CompanyController.java
index 77d10b7..c969b2c 100644
--- a/ruoyi-modules/ruoyi-company/src/main/java/com/ruoyi/company/controller/front/CompanyController.java
+++ b/ruoyi-modules/ruoyi-company/src/main/java/com/ruoyi/company/controller/front/CompanyController.java
@@ -54,4 +54,20 @@
         companyService.editCompany(mgtCompanyDTO);
         return R.ok();
     }
+
+    /**
+     * 修改企业联系方式
+     */
+    @Operation(summary = "修改企业联系方式", tags = {"企业端"})
+    @PutMapping("/updateCompanyPhone")
+    public R<Void> updateCompanyPhone(@RequestBody MgtCompanyDTO mgtCompanyDTO){
+        Long userId = SecurityUtils.getAppLoginUser().getUserId();
+        Company companyDb = companyService.getOne(new LambdaQueryWrapper<Company>()
+                .eq(Company::getUserId, userId));
+        companyDb.setContactName(mgtCompanyDTO.getContactName());
+        companyDb.setContactPhone(mgtCompanyDTO.getContactPhone());
+        companyDb.setEmail(mgtCompanyDTO.getEmail());
+        companyService.updateById(companyDb);
+        return R.ok();
+    }
 }
diff --git a/ruoyi-modules/ruoyi-company/src/main/java/com/ruoyi/company/service/impl/CompanyServiceImpl.java b/ruoyi-modules/ruoyi-company/src/main/java/com/ruoyi/company/service/impl/CompanyServiceImpl.java
index 96b72b8..831561e 100644
--- a/ruoyi-modules/ruoyi-company/src/main/java/com/ruoyi/company/service/impl/CompanyServiceImpl.java
+++ b/ruoyi-modules/ruoyi-company/src/main/java/com/ruoyi/company/service/impl/CompanyServiceImpl.java
@@ -115,10 +115,7 @@
             throw new ServiceException("该企业已存在");
         }
         //身份证二要素校验
-        Boolean res = aliyunCloudAuthUtil.verifyIdCard(dto.getLegalPersonName(), dto.getIdCardNumber());
-        if (!res) {
-            throw new ServiceException("身份证信息不匹配");
-        }
+        identityVerification(dto, company, user);
         this.save(company);
     }
 
@@ -142,7 +139,10 @@
         if (Objects.isNull(user)) {
             throw new ServiceException("该企业账号不存在");
         }
-        Long accountCount = userService.lambdaQuery().ne(User::getUserId, user.getUserId()).eq(User::getAccountName, dto.getAccountName()).count();
+        Long accountCount = userService.lambdaQuery()
+                .ne(User::getUserId, user.getUserId())
+                .eq(User::getAccountName, dto.getAccountName())
+                .count();
         if (accountCount > 0) {
             throw new ServiceException("账户名重复");
         }
@@ -158,21 +158,33 @@
         if (StringUtils.isNotBlank(company.getCompanyName())){
             Long count = this.lambdaQuery()
                     .ne(Company::getId, dto.getId())
-                    .eq(Company::getSocialCode, company.getSocialCode())
-                    .eq(Company::getCompanyName, dto.getCompanyName())
+                    .and(i -> {
+                    i.eq(Company::getSocialCode, dto.getSocialCode());
+                    i.or();
+                    i.eq(Company::getCompanyName, dto.getCompanyName());
+                    })
                     .count();
             if (count > 0) {
                 throw new ServiceException("该企业已存在");
             }
         }
+        identityVerification(dto, company, user);
+        Company companyUpd = BeanUtils.copyBean(dto, Company.class);
+        companyUpd.setId(company.getId());
+        this.updateById(companyUpd);
+    }
+
+    private void identityVerification(MgtCompanyDTO dto, Company company, User user) {
         //身份证二要素校验
         Boolean res = aliyunCloudAuthUtil.verifyIdCard(dto.getLegalPersonName(), dto.getIdCardNumber());
         if (!res) {
             throw new ServiceException("身份证信息不匹配");
         }
-        Company companyUpd = BeanUtils.copyBean(dto, Company.class);
-        companyUpd.setId(company.getId());
-        this.updateById(companyUpd);
+        //营业执照二要素校验
+        res = aliyunCloudAuthUtil.verifyBusinessLicense(dto.getSocialCode(), company.getCompanyName(), user.getUserId());
+        if (!res) {
+            throw new ServiceException("营业执照信息不匹配");
+        }
     }
 
     /**
diff --git a/ruoyi-modules/ruoyi-company/src/main/java/com/ruoyi/company/utils/AliyunCloudAuthUtil.java b/ruoyi-modules/ruoyi-company/src/main/java/com/ruoyi/company/utils/AliyunCloudAuthUtil.java
index 940360a..6984014 100644
--- a/ruoyi-modules/ruoyi-company/src/main/java/com/ruoyi/company/utils/AliyunCloudAuthUtil.java
+++ b/ruoyi-modules/ruoyi-company/src/main/java/com/ruoyi/company/utils/AliyunCloudAuthUtil.java
@@ -4,11 +4,17 @@
 import com.alibaba.fastjson2.JSONObject;
 import com.aliyun.cloudauth20190307.Client;
 import com.aliyun.cloudauth20190307.models.Id2MetaVerifyResponse;
+import com.aliyun.cloudauth20221125.models.EntElementVerifyRequest;
+import com.aliyun.cloudauth20221125.models.EntElementVerifyResponse;
+import com.aliyun.cloudauth20221125.models.EntElementVerifyResponseBody;
 import com.aliyun.tea.TeaException;
 import com.aliyun.teaopenapi.models.Config;
+import com.aliyun.teautil.models.RuntimeOptions;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Value;
 import org.springframework.stereotype.Component;
+
+import static com.aliyun.teautil.Common.assertAsString;
 
 /**
  * @author mitao
@@ -33,6 +39,22 @@
         config.endpoint = "cloudauth.aliyuncs.com";
         return new Client(config);
     }
+
+    /**
+     * <b>description</b> :
+     * <p>使用AK&amp;SK初始化账号Client</p>
+     * @return Client
+     *
+     * @throws Exception
+     */
+    public static com.aliyun.cloudauth20221125.Client createBusinessLicenseClient() throws Exception {
+        Config config = new Config()
+                .setAccessKeyId("LTAI5tFSeci96NRF6p6UN69G")
+                .setAccessKeySecret("25t5zmWkueoQd81Zka70uPKRPgaMiV");
+        config.endpoint = "cloudauth.aliyuncs.com";
+        return new com.aliyun.cloudauth20221125.Client(config);
+    }
+
     public Boolean verifyIdCard(String userName,String idCardNo) {
         //姓名第一个字密文+ 姓名其他部分明文。
         String firstCharacter = userName.substring(0, 1);
@@ -74,4 +96,50 @@
         }
         return false;
     }
+
+    public static Boolean verifyBusinessLicense(String businessLicenseNo,String companyName,Long userId) {
+        com.aliyun.cloudauth20221125.Client client = null;
+        try {
+            client = createBusinessLicenseClient();
+        } catch (Exception e) {
+            throw new RuntimeException(e);
+        }
+        EntElementVerifyRequest entElementVerifyRequest = new EntElementVerifyRequest()
+                .setLicenseNo(businessLicenseNo)
+                .setEntName(companyName)
+                .setSceneCode("000001")
+                .setMerchantBizId(businessLicenseNo)
+                .setMerchantUserId(String.valueOf(userId))
+                .setInfoVerifyType("ENT_2META")
+                .setUserAuthorization("1");
+        RuntimeOptions runtime = new RuntimeOptions();
+        try {
+            // 复制代码运行请自行打印 API 的返回值
+            EntElementVerifyResponse entElementVerifyResponse = client.entElementVerifyWithOptions(entElementVerifyRequest, runtime);
+            EntElementVerifyResponseBody body = entElementVerifyResponse.getBody();
+            EntElementVerifyResponseBody.EntElementVerifyResponseBodyResult result = body.getResult();
+            String bizCode = result.getBizCode();
+            return "1".equals(bizCode);
+        } catch (TeaException error) {
+            // 此处仅做打印展示,请谨慎对待异常处理,在工程项目中切勿直接忽略异常。
+            // 错误 message
+            System.out.println(error.getMessage());
+            // 诊断地址
+            System.out.println(error.getData().get("Recommend"));
+            assertAsString(error.message);
+        } catch (Exception _error) {
+            TeaException error = new TeaException(_error.getMessage(), _error);
+            // 此处仅做打印展示,请谨慎对待异常处理,在工程项目中切勿直接忽略异常。
+            // 错误 message
+            System.out.println(error.getMessage());
+            // 诊断地址
+            System.out.println(error.getData().get("Recommend"));
+            assertAsString(error.message);
+        }
+        return false;
+    }
+
+    public static void main(String[] args) {
+    }
+
 }
diff --git a/ruoyi-modules/ruoyi-company/src/main/resources/bootstrap.yml b/ruoyi-modules/ruoyi-company/src/main/resources/bootstrap.yml
index 26d5b36..4fc70e1 100644
--- a/ruoyi-modules/ruoyi-company/src/main/resources/bootstrap.yml
+++ b/ruoyi-modules/ruoyi-company/src/main/resources/bootstrap.yml
@@ -15,7 +15,7 @@
       discovery:
         # 服务注册地址
         server-addr: 192.168.110.111:8848
-        ip: 192.168.110.188
+        ip: 192.168.110.111
       config:
         # 配置中心地址
         server-addr: 192.168.110.111:8848

--
Gitblit v1.7.1