Login_20250812103219.tsx 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  1. // entrypoints/popup/pages/Login.tsx
  2. import React, { useState } from 'react';
  3. import { useNavigate } from 'react-router-dom';
  4. import { Button, Input, Message, Form } from '@alifd/next';
  5. export default function Login({ setIsLoggedIn }: { setIsLoggedIn: (loggedIn: boolean) => void }) {
  6. const [username, setUsername] = useState('');
  7. const [password, setPassword] = useState('');
  8. const [loading, setLoading] = useState(false);
  9. const [errors, setErrors] = useState<{ username?: string, password?: string }>({});
  10. const [keys, setKeys] = useState('');
  11. const [validImg, setValidImg] = useState('');
  12. const navigate = useNavigate();
  13. useEffect(() => {
  14. evVerify()
  15. }, [])
  16. const validateForm = () => {
  17. const newErrors: { username?: string, password?: string } = {};
  18. if (!username.trim()) {
  19. newErrors.username = '请输入用户名';
  20. }
  21. if (!password) {
  22. newErrors.password = '请输入密码';
  23. } else if (password.length < 6) {
  24. newErrors.password = '密码长度至少为6位';
  25. }
  26. setErrors(newErrors);
  27. return Object.keys(newErrors).length === 0;
  28. };
  29. const evVerify = () => {
  30. console.log('username')
  31. fetch('https://user.landwu.com/api/user/verify', {
  32. method: 'POST',
  33. headers: {
  34. 'Content-Type': 'application/json',
  35. }
  36. }).then(resjson => {
  37. if (!resjson.ok) {
  38. throw new Error('登录失败');
  39. }
  40. return resjson.json(); // 正确解析 Response 为 JSON 数据
  41. }).then(res => {
  42. const { data = {} } = res;
  43. const { data: info = {} } = data;
  44. const { key = "", img = "" } = info;
  45. setKeys(key)
  46. setValidImg(img)
  47. })
  48. }
  49. const handleLogin = async (e: React.FormEvent) => {
  50. e.preventDefault();
  51. if (!validateForm()) {
  52. return;
  53. }
  54. setLoading(true);
  55. try {
  56. // 发送登录请求
  57. const response = await fetch('/api/login', {
  58. method: 'POST',
  59. headers: {
  60. 'Content-Type': 'application/json',
  61. },
  62. body: JSON.stringify({
  63. username,
  64. password,
  65. code
  66. }),
  67. });
  68. const data = await response.json();
  69. if (response.ok && data.success) {
  70. // 登录成功
  71. localStorage.setItem('isLoggedIn', 'true');
  72. // 如果后端返回token,也可以存储token
  73. // localStorage.setItem('token', data.token);
  74. setIsLoggedIn(true);
  75. navigate('/');
  76. Message.success('登录成功');
  77. } else {
  78. // 登录失败
  79. Message.error(data.message || '登录失败,请检查用户名和密码');
  80. }
  81. } catch (error) {
  82. console.error('登录请求失败:', error);
  83. Message.error('网络错误,请稍后重试');
  84. } finally {
  85. setLoading(false);
  86. }
  87. // 模拟登录请求
  88. // setTimeout(() => {
  89. // // 这里添加实际的登录逻辑
  90. // if (username && password) {
  91. // // 模拟登录成功
  92. // localStorage.setItem('isLoggedIn', 'true');
  93. // setIsLoggedIn(true);
  94. // // 跳转到首页
  95. // navigate('/');
  96. // Message.success('登录成功');
  97. // } else {
  98. // Message.error('登录失败,请检查用户名和密码');
  99. // }
  100. // setLoading(false);
  101. // }, 1000);
  102. };
  103. return (
  104. <div className="bg-gray-50 p-4">
  105. <div className="text-center mb-6">
  106. <h1 className="text-2xl font-bold text-gray-800">登录</h1>
  107. </div>
  108. <Form onSubmit={handleLogin}>
  109. <Form.Item
  110. label="用户名"
  111. required
  112. help={errors.username}
  113. validateState={errors.username ? 'error' : undefined}
  114. >
  115. <Input
  116. placeholder="请输入用户名"
  117. value={username}
  118. onChange={(value) => {
  119. setUsername(value);
  120. if (errors.username) {
  121. setErrors({ ...errors, username: undefined });
  122. }
  123. }}
  124. disabled={loading}
  125. />
  126. </Form.Item>
  127. <Form.Item
  128. label="密码"
  129. required
  130. help={errors.password}
  131. validateState={errors.password ? 'error' : undefined}
  132. >
  133. <Input
  134. htmlType="password"
  135. placeholder="请输入密码"
  136. value={password}
  137. onChange={(value) => {
  138. setPassword(value);
  139. if (errors.password) {
  140. setErrors({ ...errors, password: undefined });
  141. }
  142. }}
  143. disabled={loading}
  144. />
  145. </Form.Item>
  146. <Form.Item
  147. label="验证码"
  148. name="code"
  149. required
  150. >
  151. <Input
  152. size="large"
  153. addonAfter={
  154. <img
  155. src={validImg}
  156. style={{ width: 70, height: 38 }}
  157. onClick={evVerify}
  158. />
  159. }
  160. autoComplete="off"
  161. />
  162. </Form.Item>
  163. <Form.Item>
  164. <Button
  165. type="primary"
  166. htmlType="submit"
  167. loading={loading}
  168. className="w-full"
  169. >
  170. {loading ? '登录中...' : '登录'}
  171. </Button>
  172. </Form.Item>
  173. </Form>
  174. <div className="mt-4 text-center text-sm text-gray-500">
  175. <p>忘记密码?请联系管理员</p>
  176. </div>
  177. </div>
  178. );
  179. }