保誠-保戶業務員媒合平台
jack
2023-08-08 d39218d56f5d1c96667035e969d414aa8a2fb81e
[UPDATE] 更新前端aes加密密碼的實作
修改2個檔案
21 ■■■■ 已變更過的檔案
PAMapp/shared/services/login.service.ts 20 ●●●● 修補檔 | 檢視 | 原始 | 究查 | 歷程
pamapi/src/main/java/com/pollex/pam/web/rest/EServiceResource.java 1 ●●●● 修補檔 | 檢視 | 原始 | 究查 | 歷程
PAMapp/shared/services/login.service.ts
@@ -1,7 +1,7 @@
import { http } from "./httpClient";
import { AxiosResponse } from 'axios';
import _ from "lodash";
import AES from 'crypto-js/aes';
import CryptoJS from "crypto-js";
import { ConsultantLoginInfo } from "../models/ConsultantLoginInfo";
import { LoginRequest } from "../models/loginRequest.model";
@@ -85,8 +85,22 @@
  /** 顧問登入 **/
  logInToConsultant(consultantDto:ConsultantLoginInfo, verificationCode: string):Promise<AxiosResponse<LoginSuccessToken>>{
    const encryptPassword = AES.encrypt(consultantDto.password, 'PAM KEY').toString();
    return http.post(`/eService/authenticate/${verificationCode}`, { ...consultantDto, password: encryptPassword });
    // const encryptPassword = AES.encrypt(consultantDto.password, 'PAM KEY').toString();
    const plaintext = "Hello, AES!";
      const key = "PAMKEY1234567890";
      const iv = "0123456789abcdef";
      const keyBytes = CryptoJS.enc.Utf8.parse(key);
      const ivBytes = CryptoJS.enc.Utf8.parse(iv);
      const encrypted = CryptoJS.AES.encrypt(plaintext, keyBytes, {
        iv: ivBytes,
        mode: CryptoJS.mode.CBC,
        padding: CryptoJS.pad.Pkcs7,
      });
      console.log("Encrypted Text:", encrypted.toString());
    return http.post(`/eService/authenticate/${verificationCode}`, { ...consultantDto, password: encrypted.toString() });
  }
}
pamapi/src/main/java/com/pollex/pam/web/rest/EServiceResource.java
@@ -54,6 +54,7 @@
            , HttpServletResponse response, HttpServletRequest request,
            @PathVariable String imgCode){
        
        String paswword = AesUtil.aesDecode(eServiceLoginVM.getPassword());
        if(!StringUtils.hasText(paswword)) {
            throw new OtpLoginFailException("密碼解密失敗");