分类 笔记 下的文章
解决双屏分辨率不同导致微信无法截图问题
应用程序右键点击属性-兼容性-更改高DPI设置-替代高DPI缩放行为打钩
系统部署相关shell脚本
批量复制程序脚本:
#!/bin/bash
#---------------------------------------
# 批量复制部署系统程序
# author: SenSen 1050575278
# date: 2021/10/16
#---------------------------------------
#确定版本号
read -p "Enter Version Code to continue : " code
if [ "$code" ]; then
#待部署系统文件夹名称 todo 待通过dns文件获取
sysDir=(t001 t002)
#源文件 依据系统版本
sourceDir="/web/source/${code}.zip";
#判断文件是否存在
if [ ! -f "${sourceDir}" ];then
echo "Error: File not found"
exit
fi
#安装目录
baseDir='/web/oa/'
for f in "${sysDir[@]}"
do
#获取当前时间
curtime=`date +"%Y/%m/%d %H:%M:%S"`
#复制
cp -rf ${sourceDir} ${baseDir}${f}".zip"
#解压 默认解压到当前
unzip -oq ${baseDir}${f} -d ${baseDir}${f}
#变更用户组
chown -R www:www ${baseDir}${f}
#删除压缩包
rm -rf ${baseDir}${f}".zip"
echo "${curtime} ${f} done"
done
else
echo "Error: param is empty"
fi
清理缓存:
#!/bin/bash
#---------------------------------------
# 清理系统临时文件
# author: SenSen 1050575278
# date: 2021/10/10
#---------------------------------------
read -p "Warning! Enter 'y' to continue : " input
#判断是否存在参数,不存在则取消
if [ "$input" == 'y' ] || [ "$input" == 'Y' ]; then
#所在目录
dir='/web/oa/'
#自动获取系统目录文件 仅可包含oa系统文件
sysDir=`ls /web/oa`
#排除目录
excluded=()
for f in ${sysDir}
do
#获取当前时间
curtime=`date +"%Y/%m/%d %H:%M:%S"`
#排除指定目录
if [[ ${excluded[@]/${f}/} != ${excluded[@]} ]]; then
echo "jump"
continue
fi
#进入目录
cd ${dir}${f}
#执行对应操作
#清除runtime 不包含log session等 todo 支持删除缓存或所有
rm -rf runtime/cache/*
rm -rf runtime/index/temp/*
#清除uploads
rm -rf public/phpExcel/*
echo "${curtime} ${f} done"
done
else
echo "Error: invalid input"
fi
批量修改网站配置:
#!/bin/bash
#---------------------------------------
# 批量生成网站配置文件
# author: SenSen 1050575278
# date: 2021/10/16
#---------------------------------------
#进入伪静态目录
cd /www/server/panel/vhost/nginx
baseDir='/web/oa/'
sysDir=`ls /web/oa`
#循环生成伪静态
for f in ${sysDir}
do
#复制
cp "thinkphp_conf.conf" "${f}.speaklaw.cn.conf"
#替换
find "${f}.speaklaw.cn.conf" | xargs sed -i "s/sensen/${f}/"
echo "${f} done"
done
创建新的系统:
#!/bin/bash
#---------------------------------------
# 创建新的OA系统
# author: SenSen 1050575278
# date: 2021/11/29
#---------------------------------------
if [ "$1" ] && [ "$2" ]; then
#获取当前时间
curtime=`date +"%Y/%m/%d %H:%M:%S"`
#所在目录
cd /web/oa
rsync -av --exclude-from="/web/shell/create.exclude" ${1}/ ${2}/
#拷贝原env配置
cd ${2}
cp -r public/install/.env ./.env
#todo 暂不考虑自动创建网站+配置
else
echo "Error: param1 is source ('like a001') && param2 is target ('like a999')"
fi
系统升级脚本:
#!/bin/bash
#---------------------------------------
# 批量更新多文件夹内容 支持排除指定目录
# 注:多系统升级时,为避免文件冲突,建议
# 单次单压缩包更新
# author: SenSen 1050575278
# date: 2021/09/10
#---------------------------------------
#添加定时任务 10min
# */10 * * * * /www/upgrade/upgrade.sh
#记录日志
log="/web/upgrade/upgrade.log"
#进入升级包所在目录 升级包必须包含version.txt文件
cd /web/upgrade/fix
#判断目录中是否有文件 原则上一次只能存在一个文件,避免多个升级包导致混乱
count=`ls -l|grep '^-'|wc -l`
#获取所有系统 废弃
# source ./wlt_dir.sh
#所在目录
baseDir='/web/oa/'
#自动获取系统目录文件 仅可包含oa系统文件
sysDir=`ls /web/oa`
#排除目录
excluded=()
#测试示例
#sysDir=('wlt_3163')
#获取当前目录下的升级包
fixFile=`ls`
if [ $count -ne 0 ]; then
for i in ${fixFile}
do
#获取当前时间
curtime=`date +"%Y/%m/%d %H:%M:%S"`
for f in ${sysDir}
do
#排除指定目录
if [[ ${excluded[@]/${f}/} != ${excluded[@]} ]]; then
continue
fi
echo "系统:${f} 升级文件:${i}">>${log}
#解压到对应系统目录
unzip -oq ${i} -d ${baseDir}${f}
echo "${curtime} ${i} done">>${log}
done
done
#移动升级包
mv ${i} /web/upgrade/bak;
echo "${i} upgrade successfully">>$log
else
echo "upgrade_fix is empty"
fi
判断是否开启允许trace方法
TRACE是一种HTTP方法,允许TRACE方法的Web服务器存在跨站脚本漏洞。
检测方法:curl -v -X TRACE http://www.yourserver.com
curl --insecure -v -X TRACE https://www.yourserver.com
依据返回信息判断
处理方式:
禁用TRACE方法,IIS可使用URLScan禁用,而Apache则可使用mod_rewrite模块禁用或在httpd.conf中配置TraceEnable off
。
PhpSpreadsheet导出excel时科学计数法
导出excel时默认长数字使用科学计数法导致数值不准确,推荐处理方式:
self::$sheet->setCellValueExplicit($span . $column, $value, DataType::TYPE_STRING);
VMware开机启动操作系统 局域网共享访问
为方便测试使用VMware搭建了LNMP服务器,共享给局域网使用。
配置开机自启动lnmp服务器系统:
- 创建vm.bat
"D:\install\vmware12\vmrun.exe" start "F:\Virtual Machines\CentOS\CentOS.vmx"
- 添加到开机启动目录中
C:\ProgramData\Microsoft\Windows\Start Menu\Programs\StartUp
注:网络连接使用“桥接模式”,并在“虚拟网络编辑器”中桥接到对应的本机有线或无线网卡上。
编辑vim /etc/sysconfig/network-scripts/ifcfg-ens33
BOOTPROTO=static
IPADDR=192.168.10.110
NETMASK=255.255.255.0
NETWORK=192.168.10.0
GATEWAY=192.168.10.1
DNS1=119.29.29.29
DNS2=8.8.8.8
ONBOOT=yes
去除phpoffice默认插入图片产生边框
项目中通过phpoffice(v0.17)生成word文件,插入word的图片默认带黑边框问题。
解决方式:
路径:vendor/phpoffice/phpword/src/PhpWord/TemplateProcess.php
位置:578行 stroked=""
$imgTpl = '<w:pict><v:shape type="#_x0000_t75" style="width:{WIDTH};height:{HEIGHT};" stroked=""><v:imagedata r:id="{RID}" o:title=""/></v:shape></w:pict>';
composer基础使用
Composer 需要 PHP 5.3.2+ 以上版本,且需要开启 openssl。
composer -v
查看版本
推荐使用阿里云全量镜像:composer config -g repo.packagist composer https://mirrors.aliyun.com/composer/
如仅当前项目使用则可去除-g
选项。
取消配置:composer config -g --unset repos.packagist