mirror of
				https://github.com/PlayEdu/h5.git
				synced 2025-10-26 12:01:21 +08:00 
			
		
		
		
	学员登录ldap优化
This commit is contained in:
		| @@ -10,3 +10,10 @@ export function login(email: string, password: string) { | ||||
| export function logout() { | ||||
|   return client.post("/api/v1/auth/logout", {}); | ||||
| } | ||||
|  | ||||
| export function loginLdap(email: string, password: string) { | ||||
|   return client.post("/api/v1/auth/login/ldap", { | ||||
|     username: email, | ||||
|     password: password, | ||||
|   }); | ||||
| } | ||||
|   | ||||
| @@ -24,6 +24,7 @@ export const InitPage = (props: Props) => { | ||||
|     if (props.configData) { | ||||
|       let config: SystemConfigStoreInterface = { | ||||
|         //系统配置 | ||||
|         "ldap-enabled": props.configData["ldap-enabled"], | ||||
|         systemApiUrl: props.configData["system-api-url"], | ||||
|         systemH5Url: props.configData["system-h5-url"], | ||||
|         systemLogo: props.configData["system-logo"], | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| import { useState, useEffect } from "react"; | ||||
| import { Button, Toast, Input, Image } from "antd-mobile"; | ||||
| import styles from "./index.module.scss"; | ||||
| import { useDispatch } from "react-redux"; | ||||
| import { useDispatch, useSelector } from "react-redux"; | ||||
| import { useNavigate } from "react-router-dom"; | ||||
| import { login, system, user } from "../../api/index"; | ||||
| import { setToken } from "../../utils/index"; | ||||
| @@ -19,6 +19,7 @@ const LoginPage = () => { | ||||
|   const [email, setEmail] = useState(""); | ||||
|   const [password, setPassword] = useState(""); | ||||
|   const [bodyHeight, setBodyHeight] = useState(0); | ||||
|   const systemConfig = useSelector((state: any) => state.systemConfig.value); | ||||
|  | ||||
|   useEffect(() => { | ||||
|     document.title = "登录"; | ||||
| @@ -29,7 +30,7 @@ const LoginPage = () => { | ||||
|   const loginSubmit = async (e: any) => { | ||||
|     if (!email) { | ||||
|       Toast.show({ | ||||
|         content: "请输入学员邮箱账号", | ||||
|         content: "请输入邮箱或uid", | ||||
|       }); | ||||
|       return; | ||||
|     } | ||||
| @@ -47,17 +48,32 @@ const LoginPage = () => { | ||||
|       return; | ||||
|     } | ||||
|     setLoading(true); | ||||
|     try { | ||||
|       let res: any = await login.login(email, password); | ||||
|       setToken(res.data.token); //将token写入本地 | ||||
|       await getSystemConfig(); //获取系统配置并写入store | ||||
|       await getUser(); //获取登录用户的信息并写入store | ||||
|       setLoading(false); | ||||
|       navigate("/member", { replace: true }); | ||||
|     } catch (e) { | ||||
|       console.error("错误信息", e); | ||||
|       setLoading(false); | ||||
|     if (systemConfig["ldap-enabled"] === "1") { | ||||
|       try { | ||||
|         let res: any = await login.loginLdap(email, password); | ||||
|         setToken(res.data.token); //将token写入本地 | ||||
|         await getSystemConfig(); //获取系统配置并写入store | ||||
|         await getUser(); //获取登录用户的信息并写入store | ||||
|         setLoading(false); | ||||
|         navigate("/member", { replace: true }); | ||||
|       } catch (e) { | ||||
|         console.error("错误信息", e); | ||||
|         setLoading(false); | ||||
|       } | ||||
|     }else{ | ||||
|       try { | ||||
|         let res: any = await login.login(email, password); | ||||
|         setToken(res.data.token); //将token写入本地 | ||||
|         await getSystemConfig(); //获取系统配置并写入store | ||||
|         await getUser(); //获取登录用户的信息并写入store | ||||
|         setLoading(false); | ||||
|         navigate("/member", { replace: true }); | ||||
|       } catch (e) { | ||||
|         console.error("错误信息", e); | ||||
|         setLoading(false); | ||||
|       } | ||||
|     } | ||||
|      | ||||
|   }; | ||||
|  | ||||
|   const getUser = async () => { | ||||
| @@ -70,6 +86,7 @@ const LoginPage = () => { | ||||
|     if (configRes.data) { | ||||
|       let config: SystemConfigStoreInterface = { | ||||
|         //系统配置 | ||||
|         "ldap-enabled": configRes.configData["ldap-enabled"], | ||||
|         systemApiUrl: configRes.data["system-api-url"], | ||||
|         systemH5Url: configRes.data["system-h5-url"], | ||||
|         systemLogo: configRes.data["system-logo"], | ||||
| @@ -110,7 +127,7 @@ const LoginPage = () => { | ||||
|         <div className={styles["input-box"]}> | ||||
|           <Input | ||||
|             className={styles["input-item"]} | ||||
|             placeholder="请输入学员邮箱账号" | ||||
|             placeholder="请输入邮箱或uid" | ||||
|             value={email} | ||||
|             onChange={(val) => { | ||||
|               setEmail(val); | ||||
|   | ||||
| @@ -1,6 +1,7 @@ | ||||
| import { createSlice } from "@reduxjs/toolkit"; | ||||
|  | ||||
| type SystemConfigStoreInterface = { | ||||
|   "ldap-enabled": string; | ||||
|   systemApiUrl: string; | ||||
|   systemPcUrl: string; | ||||
|   systemH5Url: string; | ||||
| @@ -16,6 +17,7 @@ type SystemConfigStoreInterface = { | ||||
| }; | ||||
|  | ||||
| let defaultValue: SystemConfigStoreInterface = { | ||||
|   "ldap-enabled": "", | ||||
|   systemApiUrl: "", | ||||
|   systemPcUrl: "", | ||||
|   systemH5Url: "", | ||||
|   | ||||
		Reference in New Issue
	
	Block a user