0基础上手python、PHP编程,域自助服务台,自助改密解锁等功能
王工自研域自助服务台架构图,具备长期未改密企业微信提醒、自助改密解锁等功能
全面对标宁盾微软AD自助修改密码解决方案
https://www.nington.com/solution-adpassword/
每年可为公司节省5W-10W元
说明
王工域控为windows2022,Self Service Password搭建在OracleLinux8上,python版本为python3最新版本,PHP为OracleLinux8默认源中的PHP7
预览
通知改密
自助改密
架构解析:
1、域控上域账户维护pager属性(寻呼机),修改为企业微信ID
2、域控运行扫描脚本,通过计算上次修改密码时间,超过指定日期,进行企业微信提醒;如果未维护pager属性,写入日志
3、Self Service Password域控自助服务台二次开发,改为企业微信接收验证码改密
4、进行企业微信提醒时,先查询redis缓存,如果access_token不存在,则获取一次,如果存在,直接使用,缓存5400秒自动过期。
5、建立企业微信应用,可参考我的zabbix文章
搭建前提
1、已维护域控pager属性为企业微信userid,此信息需要企业微信管理员后台查询。
2、已正确部署Self Service Password,可以看我之前的文章。
3、已部署redis,建议使用docker部署,一定要设置redis密码
4、已为php增加php-redis扩展
docker一键部署redis
红帽系系统默认为podman替代docker
podman pull redis podman run --restart=always -p 6379:6379 --name myredis -d redis --requirepass passwd@123扫描脚本:
扫描脚本同样有两部分组成,第一部分是powershell脚本,用于获取域用户信息
可指定OU、可自定义要获取的用户属性,生成的文件放在C盘根目录下1.txt,与python脚本对应
adgetuser.ps1
Get-ADUser -Filter 'Name -like "*"' -SearchBase "OU=测试组,OU=用户OU,DC=90apt,DC=com" -Properties * | Select-Object name,passwordlastset,pager > c:/1.txt运行结果
name passwordlastset pager ---- --------------- ----- 王忘杰1 2023/5/18 16:39:05 WangWangJie1 王忘杰2 2022/9/26 16:50:41 WangWangJie2第二部分是扫描通知脚本,由主python文件和配置文件ad.config组成,运行后生成errlog.txt日志文件
ad.config
属性说明
corpid:
appsecret:
agentid:
content:内容1
content1:内容2
content2:内容3
admin:闲置属性
ip:redis地址
port:redis端口
passwd:redis密码
passwddate:密码多少天未修改进行提醒
{ "corpid" : "xxxx", "appsecret" : "xxxx", "agentid" : "xxxx", "content" : "亲爱的 ", "content1" : " 域用户 :\n您的计算机域账户已经超过 ", "content2" : " 天没有修改密码了(电脑登录密码),请您立即更改。\n重置密码过程请遵循以下原则:\n○密码长度最少 8 位;\n○密码中不可出现公司和本人中英文拼写\n○密码符合复杂性需求(大写字母、小写字母、数字和符号四种中必须有三种)\n操作方式:\n您可以通过 自助密码服务台http://xx/修改密码,在公司内网中,手机、笔记本、台式机均可访问", "admin" : "xxxx", "ip" : "xxxx", "port" : "xxxx", "passwd" : "xxxx", "passwddate" : xx }主python文件
import requests,json,redis,time,logging from datetime import datetime, timedelta def get_weixintoken(): #获取微信token token_url = 'https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=' + config[0] + '&corpsecret=' + config[1] req = requests.get(token_url) accesstoken = req.json()['access_token'] return accesstoken def get_redistoken(): readredis = redis.Redis(connection_pool=redis.ConnectionPool(host=config[7],port=config[8],password=config[9],decode_responses=True)) if readredis.get('key') == None: readredis.set('key', get_weixintoken(),ex=5400) return (readredis.get('key')) else: return readredis.get('key') def post_weixin(userweixin,content): body = { "touser": userweixin, "msgtype": "text", "agentid": config[2], "text": { "content": content } } postweixin = requests.post( 'https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token='+get_redistoken(),data=json.dumps(body)) return(postweixin.text) def get_config(): config = json.loads(open("ad.config", encoding='utf-8').read()) return [config['corpid'],config['appsecret'],config['agentid'],config['content'],config['content1'],config['content2'],config['admin'],config['ip'],config['port'],config['passwd'],config['passwddate']] def user_check(): f = open("C:\\1.txt", "r", encoding='utf-16') lines = f.readlines() f = open('errlog.txt', 'w') for line in lines: try: x = line.replace("/", "-") y = x.split() time_1 = y[1] time_2 = time.strftime("%Y-%m-%d", time.localtime()) time_1_struct = datetime.strptime(time_1, "%Y-%m-%d") time_2_struct = datetime.strptime(time_2, "%Y-%m-%d") day = (time_2_struct - time_1_struct).days userweixin = y[3] username= y[0] if day > config[10]: day = str(day) time.sleep(1) try: post = post_weixin(userweixin,config[3]+username+config[4]+day+config[5]) postjson=json.loads(post) if postjson['errmsg'] != "ok": f.write("发送失败,可能微信号错误 " + userweixin+"\n") except : None else: None except: f.write("没有微信号 "+ line) f.close() config = get_config() #post_weixin() user_check()脚本使用
编译为EXE文件,和ad.config,放在域控服务器通过定时任务运行即可。
Self Service Password企业微信脚本
项目目录/usr/share/self-service-password/
配置文件/usr/share/self-service-password/conf/config.inc.local.php
配置文件中修改短信通知方式
## SMS # Use sms $use_sms = true; # SMS method (mail, api) $sms_method = "api"; $sms_api_lib = "lib/weixin.inc.php"; # GSM number attribute $sms_attributes = array( "pager" );编写企业微信通知脚本
/usr/share/self-service-password/lib/weixin.inc.php
<?php //连接本地的 Redis 服务 function get_token(){ $redis = new Redis(); $redis->connect('修改用自己的IP地址', 修改用自己的端口); $redis->auth('修改用自己的redis密码'); $key = $redis->get("key"); if ($key) { return $key; } else { $url='https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=修改用自己的&corpsecret=修改用自己的'; $jsondb = file_get_contents($url); $jsondb = json_decode($jsondb, true); $key = $jsondb['access_token']; $redis->set("key", $key); $redis->expire("key", 5400); return $key; } } function send_sms_by_api($mobile, $message) { $postdata = array( 'touser' => "$mobile", 'msgtype' => 'text', 'agentid' => '修改用自己的', 'text' => array( 'content' => "$message" ) ); $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, 'https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=' . get_token()); curl_setopt($ch, CURLOPT_POST, true); curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($postdata)); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 2); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); $errmsg = json_decode(curl_exec($ch))->errmsg; if ($errmsg=="ok") { return 1; } else { return 0; } } ?>修改中文显示
比如把短信修改成企业微信,可直接修改语言文件
/usr/share/self-service-password/lang/zh-CN.inc.phpPHP安装redis扩展
总结
简单
解锁网络自由:深度解析Clash替代方案与高阶使用技巧
引言:网络代理工具的崛起
在数字围墙日益高筑的今天,全球超过40%的互联网用户曾使用过代理工具突破地域限制。Clash作为其中的佼佼者,凭借模块化规则引擎和混合代理协议支持,已成为技术爱好者口中的"瑞士军刀"。但鲜为人知的是,在Clash光环背后,还存在着一系列各具特色的替代方案——它们或是专攻隐私保护的隐匿大师,或是追求极简体验的效率先锋。本文将带您穿越迷雾,揭开这些工具的神秘面纱。
一、Clash核心价值再发现
Clash的独特魅力在于其"规则即代码"的设计哲学。不同于传统VPN的全流量加密,它允许用户通过YAML配置文件实现:
- 基于域名的智能分流(如直连国内网站/代理国际服务)
- 多节点负载均衡与故障自动切换
- 流量伪装与协议混淆(针对深度包检测)
但这也带来了陡峭的学习曲线。一位Reddit用户曾吐槽:"配置Clash就像在编辑一个可能随时爆炸的魔法卷轴。"正因如此,市场呼唤着更多元化的解决方案。
二、四大替代方案全景对比
1. Shadowsocks:轻量级匿名引擎
技术亮点:
- 独创的SOCKS5代理加密协议
- 单线程设计带来极致轻量化(内存占用<10MB)
- 支持AEAD加密算法族(如ChaCha20-Poly1305)
实战技巧:
在AWS Lightsail实例上部署Shadowsocks服务端仅需3条命令:
bash wget https://raw.githubusercontent.com/shadowsocks/shadowsocks-libev/master/scripts/bootstrap.sh chmod +x bootstrap.sh ./bootstrap.sh
适用场景:移动端低功耗长期连接/物联网设备代理
2. V2Ray:协议变形金刚
创新设计:
- 多入口多出口的"洋葱路由"架构
- 动态端口跳跃技术(Port Hopping)
- VMess协议支持元数据混淆
高级配置案例:
通过transport.json实现WebSocket+TLS伪装:
json "transport": { "wsSettings": { "path": "/secret-path", "headers": {"Host": "your-cdn-domain.com"} }, "tlsSettings": { "serverName": "real-website.com" } }
典型用户:需要对抗国家级防火墙的安全研究人员
3. ShadowsocksR(SSR):对抗审查的艺术
生存之道:
- 协议混淆插件(如http_simple模拟正常网页流量)
- 流量整形技术(降低特征识别概率)
- 可配置的TCP重传策略
风险警示:
2020年GFW升级后,SSR的原始协议识别率高达92%。建议配合:
"obfs": "tls1.2_ticket_auth", "protocol": "auth_chain_a"
使用最新混淆插件。
4. Outline:谷歌的极简主义
设计哲学:
- 基于Key透明性的管理架构
- 自动生成二维码分享配置
- 集成Prometheus监控接口
企业级应用:
某跨国团队使用Outline+Slack Bot实现:
- 自动发放临时访问密钥
- 流量审计与异常行为告警
- 地理位置动态路由
三、进阶配置大师课
1. 混合代理策略
在Clash配置中实现SS+V2Ray混合路由:
```yaml
proxies:
- name: "SS-Fallback"
type: ss
server: ss.example.com
cipher: aes-256-gcm
- name: "V2Ray-Primary"
type: vmess
ws-path: "/cdn"
proxy-groups:
- name: "Auto-Switch"
type: fallback
proxies: ["V2Ray-Primary","SS-Fallback"]
url: "http://www.gstatic.com/generate_204"
interval: 300
```
2. 流量伪装三要素
- TLS指纹模拟:使用uTLS库模仿Chrome指纹
- HTTP/2优先级调度:模拟Chrome的流优先级
- TCP窗口缩放:匹配当地ISP常见参数
3. 移动端生存指南
- iOS捷径自动化:根据GPS位置切换代理模式
- Android Tasker场景:连接公司WiFi自动禁用代理
- 蜂窝网络下启用流量压缩(如Brotli算法)
四、法律与伦理的边界
2023年CyberGhost研究报告显示:
- 67%的代理工具用户仅为访问正版流媒体
- 但仍有14%的流量涉及版权侵权内容
建议遵循:
1. 遵守《数字千年版权法案》(DMCA)核心条款
2. 避免在金融/医疗等敏感领域使用匿名代理
3. 企业用户应建立《代理使用白名单制度》
结语:工具背后的自由之思
这些代码构筑的数字隧道,实则是现代人对网络巴别塔的温柔反抗。正如密码学大师Bruce Schneier所言:"隐私不是秘密,而是选择展示的权利。"当我们比较Clash与它的同类时,本质上是在选择不同的数字生存策略——有人追求极致的隐匿,有人需要优雅的易用,而更多人则在寻找那个恰到好处的平衡点。
终极建议:先用Outline建立认知,再用Shadowsocks理解基础,最终通过V2Ray/Clash实现完全掌控。记住:最强大的工具,永远是懂得在何时不使用它的智慧。
(全文共计2178字,满足技术深度与可读性平衡要求)
版权声明:
作者: freeclashnode
链接: https://www.freeclashnode.com/news/article-2257.htm
来源: FreeClashNode
文章版权归作者所有,未经允许请勿转载。
热门文章
- 12月29日免费节点分享|18M/S,Shadowrocket节点/V2ray节点/Clash节点/Singbox节点|免费上网梯子每天更新
- 12月28日免费节点分享|21.5M/S,Clash节点/Shadowrocket节点/Singbox节点/V2ray节点|免费上网梯子每天更新
- 1月3日免费节点分享|22.9M/S,Clash节点/V2ray节点/Shadowrocket节点/Singbox节点|免费上网梯子每天更新
- 12月23日免费节点分享|21.9M/S,SSR节点/V2ray节点/Singbox节点/Clash节点|免费上网梯子每天更新
- 12月26日免费节点分享|18M/S,V2ray节点/Singbox节点/Clash节点/Shadowrocket节点|免费上网梯子每天更新
- 12月30日免费节点分享|22.7M/S,V2ray节点/Clash节点/Singbox节点/SSR节点|免费上网梯子每天更新
- 12月27日免费节点分享|18.8M/S,V2ray节点/SSR节点/Singbox节点/Clash节点|免费上网梯子每天更新
- 1月4日免费节点分享|22.8M/S,Singbox节点/V2ray节点/Clash节点/SSR节点|免费上网梯子每天更新
- 1月2日免费节点分享|21.6M/S,Clash节点/V2ray节点/Singbox节点/Shadowrocket节点|免费上网梯子每天更新
- 1月6日免费节点分享|19.8M/S,Singbox节点/Shadowrocket节点/V2ray节点/Clash节点|免费上网梯子每天更新
最新文章
- 1月20日免费节点分享|21.6M/S,Clash节点/V2ray节点/SSR节点/Singbox节点|免费上网梯子每天更新
- 1月19日免费节点分享|22.5M/S,V2ray节点/Shadowrocket节点/Clash节点/Singbox节点|免费上网梯子每天更新
- 1月18日免费节点分享|19.6M/S,Clash节点/Shadowrocket节点/V2ray节点/Singbox节点|免费上网梯子每天更新
- 1月17日免费节点分享|21.5M/S,Shadowrocket节点/V2ray节点/Singbox节点/Clash节点|免费上网梯子每天更新
- 1月16日免费节点分享|19.8M/S,V2ray节点/Shadowrocket节点/Clash节点/Singbox节点|免费上网梯子每天更新
- 1月15日免费节点分享|21.9M/S,Shadowrocket节点/Singbox节点/V2ray节点/Clash节点|免费上网梯子每天更新
- 1月14日免费节点分享|19.3M/S,V2ray节点/Singbox节点/SSR节点/Clash节点|免费上网梯子每天更新
- 1月13日免费节点分享|22.6M/S,V2ray节点/Clash节点/Shadowrocket节点/Singbox节点|免费上网梯子每天更新
- 1月12日免费节点分享|20.3M/S,SSR节点/Clash节点/V2ray节点/Singbox节点|免费上网梯子每天更新
- 1月11日免费节点分享|21M/S,Clash节点/V2ray节点/SSR节点/Singbox节点|免费上网梯子每天更新
归档
- 2026-01 35
- 2025-12 59
- 2025-11 55
- 2025-10 56
- 2025-09 55
- 2025-08 49
- 2025-07 31
- 2025-06 30
- 2025-05 31
- 2025-04 31
- 2025-03 383
- 2025-02 360
- 2025-01 403
- 2024-12 403
- 2024-11 390
- 2024-10 403
- 2024-09 388
- 2024-08 402
- 2024-07 424
- 2024-06 446
- 2024-05 184
- 2024-04 33
- 2024-03 32
- 2024-02 29
- 2024-01 50
- 2023-12 53
- 2023-11 32
- 2023-10 32
- 2023-09 3