CVE-2023-3009
简介
TeamPass 是一个密码管理器,专门用于通过在团队成员之间共享密码来以协作方式管理密码,提供大量功能,允许根据为每个用户定义的访问权限以有组织的方式管理的密码和相关数据, 是一个开源免费使用的产品,根据 OpenSource GNU GPL-3.0 分发。
影响版本
Teampass<3.0.9
下载地址
https://github.com/nilsteampassnet/TeamPass/archive/refs/tags/3.0.8.zip
安装
PHP版本要求>7.4
data:image/s3,"s3://crabby-images/bde28/bde28aa29a99c341c9d66496ea57dd59e983afac" alt=""
下一步
data:image/s3,"s3://crabby-images/a2472/a2472a7ce63bd4284ef2b658366a57eb09113b15" alt=""
安装环境需要linux,centos7换源,其实windows也可以安装
data:image/s3,"s3://crabby-images/9872d/9872d59f2a04f46d17efeb2784c03f8caefe6715" alt=""
yum install https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
yum-config-manager --enable remi-php74
data:image/s3,"s3://crabby-images/82e72/82e721c31a0c068cec56c3020005610a83bd26e4" alt=""
yum install php php-cli php-fpm php-mysqlnd php-zip php-devel php-gd php-mcrypt php-mbstring php-curl php-xmlrpc php-xml
php -v
data:image/s3,"s3://crabby-images/fd3be/fd3beda78495d963601b981325abf8463808de70" alt=""
安装phpmyadmin
yum install phpmyadmin
- 配置phpMyAdmin:
vim /etc/httpd/conf.d/phpMyAdmin.conf
- 将以下行添加到文件中:
<Directory /usr/share/phpMyAdmin/>
AddDefaultCharset UTF-8
</Directory>
重启Apache:
data:image/s3,"s3://crabby-images/974a5/974a5c20736a95d53aae3a69c4a52af73d0dbe38" alt=""
systemctl restart httpd.service
根据apache版本修改phpadmin配置
vim /etc/httpd/conf.d/phpMyAdmin.conf
data:image/s3,"s3://crabby-images/12f00/12f00c7489f6e8c678913653fad6cb5b76034ee3" alt=""
centos7开放防火墙80端口
firewall-cmd --zone=public --add-port=80/tcp --permanent
firewall-cmd --reload
data:image/s3,"s3://crabby-images/4f0a6/4f0a6943ac1c985b79449f0fb0bebad62a769d0d" alt=""
update user set authentication_string=password('1qaz@WSX') where user='root';
安装ssl证书
mkdir -p /etc/ssl/localcerts
openssl req -new -x509 -days 365 -nodes -out /etc/ssl/localcerts/apache.pem -keyout /etc/ssl/localcerts/apache.key
chmod 600 /etc/ssl/localcerts/apache*
sudo ln -s /etc/httpd/conf.modules.d/10-a2enmod.conf /etc/httpd/conf.modules.d/00-base.conf
a2enmod ssl
环境问题,这里装证书时最麻烦的,ssl协议能走没问题。这里其实有相对来说更简单的安装方法
结合Docker
docker pull teampass/teampass //拉取镜像
wget https://github.com/nilsteampassnet/TeamPass/archive/refs/tags/3.0.8.zip //下载项目
unzipc TeamPass-3.0.8 //解压
mv TeamPass-3.0.8 teampass //改名
docker run -p 80:80 teampass/teampass
data:image/s3,"s3://crabby-images/3742f/3742fb02621ea3293c8a5bf3c670315abee07dfb" alt=""
dcoker ps //查看docker容器id
docker cp ./teampass/ a4fb5937eaa8:/var/www/html/ //将文件复制到docker镜像中
data:image/s3,"s3://crabby-images/752d4/752d4298d88dd5fa721b6cbdfe704e4f44cc5e9c" alt=""
以此方法安装也可以,该环境中时已经安装好了ssl证书的
data:image/s3,"s3://crabby-images/8f903/8f903b118f302d4ed03bafc80c669f7326fd742e" alt=""
准备工作做好之后就可以正常走安装流程了。
data:image/s3,"s3://crabby-images/c8441/c84411646e0a297761a25490ba7bf72a139eba69" alt=""
data:image/s3,"s3://crabby-images/64b70/64b7098e8936063e57c639c9f26e7acd8d73c339" alt=""
效果
data:image/s3,"s3://crabby-images/f5128/f5128d6d118744a71569c5eea60e25a554b072dc" alt=""
目前在版本3.0.9
中已修复
https://github.com/nilsteampassnet/teampass/commit/6ba8cf1f4b89d62a08d122d533ccf4cb4e26a4ee?diff=unified
data:image/s3,"s3://crabby-images/9af4f/9af4f77af183636d046b4fc34025bf7224ec56e6" alt=""
可以看到在js中添加了过滤
data:image/s3,"s3://crabby-images/e0c5e/e0c5e5f7a41a68e127695c91e3d6cd7cad0ca167" alt=""
在releases中无最新版本的源文件。