javascript-obfuscator js混肴 (用户界面版)

混肴的作用

防止浏览器的js/html/css代码被他人盗用。下述只实现了js的混肴。html/css可仿照js逻辑实现

预览图

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

mix.sh混肴脚本

#!/bin/bash  
  
# 检查 terser 是否可用  
if ! command -v javascript-obfuscator &> /dev/null; then  
    echo "javascript-obfuscator 不可用,请安装后再运行此脚本。执行安装:npm install -g javascript-obfuscator"  
    exit 1  
fi 
  
# 获取当前目录下的所有子目录(只考虑一级子目录)并自然排序  
dirs=($(find . -maxdepth 1 -mindepth 1 -type d -exec basename {} \; | sort))  
  
# 显示目录列表并让用户选择  
for (( i=0; i<${#dirs[@]}; i++ )); do  
    echo "$((i + 1)). ${dirs[$i]}"  
done  
read -p "请选择js存储目录(1-${#dirs[@]}):" choice1  
  
# 检查输入是否有效  
if ! [[ "$choice1" =~ ^[1-9][0-9]*$ ]] || [[ "$choice1" -gt ${#dirs[@]} ]]; then  
    echo "无效的输入,请重新运行脚本"  
    exit 1  
fi  
  
# 转换为0-based索引  
choice1=$((choice1-1))  
selected_dir="./${dirs[$choice1]}"  
  
# 第二步:列出目录下的js文件并自然排序  
files=($(find "$selected_dir/js" -type f -name "*.js" | sort))  

# 显示文件列表并让用户选择  
for (( i=0; i<${#files[@]}; i++ )); do  
    filename=$(basename -- "${files[$i]}")  
    echo "$(($i+1))). ${filename}"  
done  
read -p "请选择要混肴的js(1-${#files[@]})" choice2  
  
# 检查输入是否有效  
if ! [[ "$choice2" =~ ^[1-9][0-9]*$ ]] || [[ "$choice2" -gt ${#files[@]} ]]; then  
    echo "无效的输入,请重新运行脚本"  
    exit 1  
fi  
  
# 转换为0-based索引  
choice2=$((choice2-1))  
full_file_path="${files[$choice2]}"  
echo "混肴的js路径:$full_file_path"
# 第三步:执行混淆并保存到新位置  
dir_part="${full_file_path%/*}"  # 移除最后一个 / 及其后的内容  
dir_part="${dir_part#./}"   # 如果需要,移除开头的 ./  

output_dir="./copy/$dir_part"  
mkdir -p "$output_dir"  # 确保目录存在 
output_file="./copy/${full_file_path#./}"   #去掉./前缀

javascript-obfuscator "$full_file_path" --config "./config.json" --output "$output_file"
  
echo "混淆后的文件已保存到:$output_file"

#目录结构必须是/主目录/js/*.js

config.json

{  
  "compact": true,  
  "mangle": true,  
  "controlFlowFlattening": false,  
  "numbersToExpressions": false,  
  "splitStrings": false,  
  "stringArray": false,  
  "stringArrayThreshold": 0.75,  
  "simplify": true,  
  "deadCodeInjection": false,  
  "debugProtection": false,  
  "debugProtectionInterval": 0,  
  "selfDefending": false,  
  "reservedNames": [],  
  "transformObjectKeys": true, 
  "reservedStrings": [],  
  "rotateStringArray": true,  
  "renameGlobals": false,  
  "seed": 0  
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

幽·

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值