git 使用
参考:https://blog.csdn.net/weixin_60033897/article/details/136016074
在服务器端创建公钥私钥
git config --global user.email "1686660735@qq.com"
git config --global user.name qinliangql
git config --global -l # 查看信息
# 这样可以生成指定文件的私钥和公钥,避免和本地和服务器的连接私钥公钥冲突
ssh-keygen -t rsa -C "1686660735@qq.com" -f /home/qinl/.ssh/git_private_key
查看自己的公钥
cat /home/qinl/.ssh/git_private_key.pub
提交公钥到github
如果.ssh文件夹下没有config还需要创建config
touch config
输入
Host github.com
User git
Hostname ssh.github.com
PreferredAuthentications publickey
IdentityFile /home/qinl/.ssh/git_private_key
测试
ssh -T git@github.com
git 提交代码
# 查看修改
git status
# dev 分支是干净的,那么拉取最新分支
git fetch origin dev:dev
# 基于dev创建并切换新分支,没有-b就算直接切换
git checkout -b feature/disabled-mail-ustc
# ...修改并测试代码
# 查看修改
git status
# 保留修改
git add -u
git add 文件绝对路径
# 本地提交 后面这个是一句描述的话
git commit -m "Feature: disabled mail.ustc.edu.cn"
# 上传到远程分支,并提交pr,选择我审核,这里origin只是远程,合并到什么分支到时候还要选择
git push origin feature/disabled-mail-ustc
# 切换为 dev分支
git checkout dev
# dev 分支是干净的,那么拉取最新分支
git fetch origin dev:dev
git 忽略文件权限更改
git config core.filemode false
Debug 理清楚逻辑
先login 获得token,之后把token复制到get里面,token选这个
GET 只要有params+Au
部署前端
在前端上传在前端生成的ssh私钥,注意这次是在root/…sh中用,所以要改点东西
进入front的pod,自己创建一个文件夹
git clone git@github.com:USTC-MCCLab/aiarena-frontend.git
局域网设代理
下载慢可以直接设定代理到局网上的本机上
export http_proxy=192.168.160.118:7890
export https_proxy=192.168.160.118:7890
clash中还要allow LAN
修改
修改vite.config.js
,和自己的gateway相对应,只修改user和group
另外注意gateway中有个CORS组件可以控制哪些前端地址可以经过gateway,需要要把自己的前端地址9996
添加进去
aiarena-frontend中启动
# 启动前端
npm install
npm run dev:linux
npm run这个可以用tmux一直跑着,修改代码会自动更新
同时分别在gateway和user的pod中把服务启动起来,可以在tmux中启动避免这个问题
访问前端
访问前端口(这个9996其实就是映射到前端的5086)
http://192.168.4.11:9996/
账户密码和后端的对应,遇到问题可以通过ctrl+shift+c
调试看界面和F12
效果一样
邮箱问题
最开始必须限制校内邮箱
定位代码
修改为更常见的邮箱格式
email: [
{ required: true, message: '请输入邮箱', type: 'error' },
{
validator: (val) => {
const regex = /^\w+([-+.']\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/;
return regex.test(val);
},
message: '请输入有效的邮箱地址',
type: 'error',
},
],
现在正常别的邮箱:
错误地址:
邮箱格式,正则表达式
-
校内邮箱的正则表达式:
/^[a-zA-Z0-9._%+-]+@(ustc\.edu\.cn|mail\.ustc\.edu\.cn)$/
^
:表示字符串的开始。[a-zA-Z0-9._%+-]+
:匹配一个或多个由字母(大小写)、数字、.
、_
、%
、+
和-
组成的字符,这些是邮箱地址中本地部分(即@
符号前面的部分)的常见字符。@
:匹配@
符号,它是邮箱地址的必需部分。(ustc\.edu\.cn|mail\.ustc\.edu\.cn)
:这是一个捕获组,用于匹配两个可能的域名之一。|
是逻辑或操作符,意味着匹配其中的任意一个。\.
用于匹配.
字符(因为在正则表达式中.
是一个特殊字符,代表任意字符,所以需要转义)。所以这部分会匹配@ustc.edu.cn
或@mail.ustc.edu.cn
。$
:表示字符串的结束。
这个正则表达式确保输入的邮箱地址是校内邮箱(即
@ustc.edu.cn
或@mail.ustc.edu.cn
)。 -
通用的邮箱正则表达式:
/^\w+([-+.']\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/
\w+
:匹配一个或多个单词字符(等价于[a-zA-Z0-9_]
)。([-+.']\w+)*
:可选地匹配一个或多个由-
、+
、.
或'
开头的单词字符序列。@
:匹配@
符号。\w+
:再次匹配一个或多个单词字符。([-.]\w+)*
:可选地匹配一个或多个由-
或.
开头的单词字符序列。\.
:匹配.
字符。\w+
:再次匹配一个或多个单词字符。([-.]\w+)*
:最后,可选地匹配一个或多个由-
或.
开头的单词字符序列。
这个正则表达式是一个更通用的邮箱验证规则,它尝试匹配大多数常见的邮箱地址格式,但并不保证能匹配所有有效的邮箱地址(因为有些邮箱地址可能包含非ASCII字符或更复杂的结构)。但它足够用于大多数常见的验证场景。
权限认证修改
参考:https://github.com/USTC-MCCLab/aiarena-backend/commit/c265e3c872c39d5e9dfd24bdb9f9b003f2ef0a3c
前端加密
npm install bcryptjs