隨便聊聊鄙公司服務器的安全設置!_PHP教程
笔者长期以来一直做得工作基本上就是开发公司的PHP程序,另外维护几台CentOS服务器,在长时间的工作中总结了一套对付攻击的小手段,不敢藏私,分享给大家,希望大家喜欢!
首先说一下服务器那边的设定状况好了,服务器在公司内部,一条光纤直接接入,有7个固定IP,每一台服务器均有自己的固定IP,另外每一台服務器均為雙網卡,除了有一個外網固定IP外還同屬於一個內網,这7个固定IP是通过一台带有路由功能的硬件防火墙进行分发的.硬件防火墙只对外开放了80端口,其余的全部都关掉了.而服务器则基本上都是CentOs,只有一台是windows.CentOs全部开了Linux系统自带的防火墙,远程管理的时候通过某种特殊手段连接到这个服务器所在的局域网的某台windows操作系统的服务器上,然后再通过这台windows上安装的SSH即可操控每一台服务器了,虽然这么设定非常麻烦,但却很安全.(这里补充说一下,每台服务器的防火墙均设定了允许某个内網IP才可SSH單向连线的规则,这设定就比较繁琐了,小孩子没有娘说起来话很长,既然很长我就不说了.)
既然如此大家或许会问,只开了一个80还有什么好攻击的呢?其实不然,首先有某公司常常会用webbench压力测试工具来试图瘫痪nginx,没办法因为这套程序之前就是他们开发的,他们知道这套程序运行的时候极其消耗CPU资源.其次有众多来自内地网友们猜测这套程序的潜在漏洞,例如猜测管理员后台入口,猜测是否有网站备份的压缩文件放在服务器上等等,他们的这些访问方式全部都是针对80端口来的,如果不采取某些措施的话Nginx会常常瘫痪掉,导致网站出现错误500或错误502,而那些猜测的害处我就更不用多说了,对于以上诸多不友好的来访者笔者只好做一些扼杀手段了.
其实做法说起来也并不复杂,首先我会用php取得来访者的访问意图,如果对方的意图有鬼或不轨满足了我的封杀条件,那么就干掉他吧!首先用PHP自动建立.sh这样一个文件,这个文件的的内容就是用来改写linux的防火墙规则(当然了我也可以改写硬件防火墙的规则,不过太麻烦了,还是偷个懒吧!),修改这个.sh文件的属性和所有者让其可以被执行,然后用linux的crontab来取得并执行这个.sh把封杀规则写入防火墙,同时给笔者发一封Email告知我某个倒霉蛋已经被封杀了即可.
下边是我的做法:
<?PHP # 自動封鎖IP QQ群:223494678 # 用法: # 1.首先把下方的PHP代碼放入被全局require的配置檔內. # 2.用SSH執行:cat /etc/crontab # 3.加入下邊兩行: # #auto lock webbench # */1 * * * * root /home/wwwroot/bossAdm_Web/webbench.sh; # 4.重啟crontab的服務:service crontab restart //封鎖任何來源的WebBench IF(isSet($_SERVER['HTTP_USER_AGENT']) And Trim($_SERVER['HTTP_USER_AGENT'])!='') { $_SERVER['HTTP_USER_AGENT']=StrToLower($_SERVER['HTTP_USER_AGENT']); IF(StriStr($_SERVER['HTTP_USER_AGENT'],'webbench')!==False And (isSet($_SERVER['REMOTE_ADDR']) And Trim($_SERVER['REMOTE_ADDR'])!='')) { DoLock($_SERVER['REMOTE_ADDR']); Die(); } } //封鎖敏感Url,針對猜測如下url的ip直接封殺 QQ群:223494678 //這段代碼最好是加入到404.php內,這樣效果更大(需要重新配置一下httpd.conf,讓404錯誤頁指向到該404.php) QQ群:223494678 IF(isSet($_SERVER['REQUEST_URI']) And Trim($_SERVER['REQUEST_URI'])!='') { IF(StriStr($_SERVER['REQUEST_URI'],'/admin')!==False Or StriStr($_SERVER['REQUEST_URI'],'/sign')!==False Or StriStr($_SERVER['REQUEST_URI'],'/reg')!==False Or StriStr($_SERVER['REQUEST_URI'],'/tiki-')!==False Or StriStr($_SERVER['REQUEST_URI'],'/join')!==False Or StriStr($_SERVER['REQUEST_URI'],'/config')!==False Or StriStr($_SERVER['REQUEST_URI'],'/backup')!==False Or StriStr($_SERVER['REQUEST_URI'],'/www')!==False Or StriStr($_SERVER['REQUEST_URI'],'/manage')!==False Or StriStr($_SERVER['REQUEST_URI'],'/password')!==False Or StriStr($_SERVER['REQUEST_URI'],'/install')!==False Or StriStr($_SERVER['REQUEST_URI'],'/phpmyadmin')!==False Or StriStr($_SERVER['REQUEST_URI'],'/webadmin')!==False Or StriStr($_SERVER['REQUEST_URI'],'/inc')!==False Or StriStr($_SERVER['REQUEST_URI'],'/user')!==False Or StriStr($_SERVER['REQUEST_URI'],'/upload')!==False Or StriStr($_SERVER['REQUEST_URI'],'/setup')!==False Or StriStr($_SERVER['REQUEST_URI'],'/sys')!==False Or StriStr($_SERVER['REQUEST_URI'],'/cert')!==False ){ DoLock($_SERVER['REMOTE_ADDR']); Die(); } } //建立sh檔,用途是封鎖ip,該sh檔會被排程以root身份執行. QQ群:223494678 Function DoLock($x){ $p='/home/wwwroot/bossAdm_Web/webbench.sh'; File_Put_Contents($p,"#! /bin/bash\n iptables -I INPUT -s {$x} -j DROP;\n echo \"{$x} - `date`\" | mail -s \"WebBench\" see7di@gmail.com;\n cat /dev/null > {$p}",LOCK_EX); Chmod($p,0755); chown($p,'www'); unSet($p,$x); }
發問之後有網友問我"特殊手段连接到这个服务器所在的局域网的某台windows操作系统的服务器上"這句話中的特殊手段究竟是什麽手段,好吧我就簡單的說一下好了,說多了我怕砸了自己的碗.首先我會登錄進入公司網站的後臺管理,然後發送一個開放3389的請求,發送之後退出後臺即可,linux服務器接收到請求(只是一個ini文件而已)之後會把這個文件通過samb通過內部局域網丟到windows服務器上,那台windows服務器上有我開發的一個監控端,用來隨時掃描是否有請求,如果有的話這個監控端就會修改硬件防火牆的設定,把3389的映射端口(65525內的某個端口映射到這台windows上的3389)開放一下,此時我就可以用3389方式連線到這台服務器了(從請求發送到開放3389大約只需要1分鐘的時間),只不過要注意的是:要改一下gpedit的設定,讓其在3389連線完畢之後自動建立一個關閉3389的請求,這樣剩下的事就交給那個監控程序來幫我關閉3389的映射端口就行了.
以上,如需交流PHP的朋友可以加我的QQ群:223494678 相信只有交流才能成长!至少我是这么认为的.:)

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

PHP的魔法方法有哪些? PHP的魔法方法包括:1.\_\_construct,用於初始化對象;2.\_\_destruct,用於清理資源;3.\_\_call,處理不存在的方法調用;4.\_\_get,實現動態屬性訪問;5.\_\_set,實現動態屬性設置。這些方法在特定情況下自動調用,提升代碼的靈活性和效率。

靜態綁定(static::)在PHP中實現晚期靜態綁定(LSB),允許在靜態上下文中引用調用類而非定義類。 1)解析過程在運行時進行,2)在繼承關係中向上查找調用類,3)可能帶來性能開銷。

PHP和Python各有優勢,選擇依據項目需求。 1.PHP適合web開發,尤其快速開發和維護網站。 2.Python適用於數據科學、機器學習和人工智能,語法簡潔,適合初學者。

PHP在電子商務、內容管理系統和API開發中廣泛應用。 1)電子商務:用於購物車功能和支付處理。 2)內容管理系統:用於動態內容生成和用戶管理。 3)API開發:用於RESTfulAPI開發和API安全性。通過性能優化和最佳實踐,PHP應用的效率和可維護性得以提升。

PHP是一種廣泛應用於服務器端的腳本語言,特別適合web開發。 1.PHP可以嵌入HTML,處理HTTP請求和響應,支持多種數據庫。 2.PHP用於生成動態網頁內容,處理表單數據,訪問數據庫等,具有強大的社區支持和開源資源。 3.PHP是解釋型語言,執行過程包括詞法分析、語法分析、編譯和執行。 4.PHP可以與MySQL結合用於用戶註冊系統等高級應用。 5.調試PHP時,可使用error_reporting()和var_dump()等函數。 6.優化PHP代碼可通過緩存機制、優化數據庫查詢和使用內置函數。 7

PHP仍然具有活力,其在現代編程領域中依然佔據重要地位。 1)PHP的簡單易學和強大社區支持使其在Web開發中廣泛應用;2)其靈活性和穩定性使其在處理Web表單、數據庫操作和文件處理等方面表現出色;3)PHP不斷進化和優化,適用於初學者和經驗豐富的開發者。

PHP和Python各有優勢,選擇應基於項目需求。 1.PHP適合web開發,語法簡單,執行效率高。 2.Python適用於數據科學和機器學習,語法簡潔,庫豐富。
