vsftpd

来源:https://www.cnblogs.com/littlebylittle/archive/2020/03/07/12431856.html
-Advertisement-
Play Games

匿名用戶 anonymous_enable=YES anon_umask=022 anon_upload_enable=YES anon_mkdir_write_enable=YES anon_other_write_enable=YES anon_root=/var/ftp anon_max_ra ...


匿名用戶

anonymous_enable=YES
anon_umask=022
anon_upload_enable=YES
anon_mkdir_write_enable=YES
anon_other_write_enable=YES
anon_root=/var/ftp
anon_max_rate=0

本地用戶

local_enable=YES
local_umask=022
local_root=/var/ftp
chroot_local_user=YES #開啟用戶家目錄限制
chroot_list_enable=YES # 開啟白名單
chroot_list_file=/etc/vsftpd/chroot_list #允許chroot_list裡面的用戶可以切換目錄
local_max_rate=0
userlist_enable=YES &userlist_deny=YES#禁止/etc/vsftpd/user_list裡面的用戶登錄ftp
userlist_enable=YES &userlist_deny=NO#僅允許/etc/vsftpd/user_list裡面的用戶登錄ftp

#配置文件ftpusers
禁止/etc/vsftpd/ftpusers裡面的用戶登錄ftp且許可權比user_list還要高,即時生效
#被動模式
pasv_enable=YES
pasv_min_port=30000
pasv_max_port=35000

虛擬用戶

需要生成資料庫文件而且要拿一個本地用戶來映射虛擬用戶,做虛擬用戶配置文件設置時,必須將主配置文件中的  自定義的匿名用戶相關設置  註釋掉給映射用戶的家目錄設置o+r讓虛擬用戶有讀許可權

vim vsftpd.user #奇數行:用戶,偶數行:密碼
db_load -T -t hash -f vsftpd.user vsftpd.db #對文件加密
#修改許可權 
chmod 600 vsftpd.db
#創建虛擬用戶的映射用戶,並指定其家目錄
useradd -d /var/ftproot -s /sbin/nologin  virtual
#建立PAM文件,添加虛擬用戶支持
cp -a /etc/pam.d/vsftpd /etc/pam.d/vsftpd.pam
cat /etc/pam.d/vsftpd.pam
auth    required        pam_userdb.so db=/etc/vsftpd/vsftpd
account required        pam_userdb.so db=/etc/vsftpd/vsftpd
#修改vsftpd.conf 添加支持配置
#pam_service_name=vsftpd
pam_service_name=vsftpd.pam
guest_enable=YES
guest_username=virtual
user_config_dir=/etc/vsftpd/dir
#做虛擬用獨立戶配置文件設置時,必須將主配置文件中的  自定義的匿名用戶相關設置  註釋掉
anon_upload_enable=YES  #允許上傳文件
anon_mkdir_write_enable=YES  #允許創建目錄
anon_other_write_enable=YES  #允許修改文件
#給映射用戶的家目錄設置o+r讓虛擬用戶有讀許可權

500 OOPS: vsftpd: refusing to run with writable root inside chroot()
Login failed.
chmod a-w /var/ftproot 或者配置文件(主配置文件或者虛擬用戶配置文件都可以)添加allow_writeable_chroot=YES

 安全

抓包
tcpdump -i ens32 -nn -X -vv tcp port 21 and ip host 源ip
-i  #interface
-n  #對地址以數字方式顯示,否則顯示主機名
-nn  #除了-n作用外,將埠顯示為數值,否則顯示市口服務名
-X  #輸出包的頭部數據,以16進位和ascii兩種方式同時輸出
-vv  #顯示更詳細的輸出

openssl

rpm -q openssl
查看vsftpd是否支持openssl
ldd /usr/sbin/vsftpd | grep libssl
生成加密信息的秘鑰和證書文件
位置:/etc/ssl/certs/
openssl genrsa -out vsftpd.key 1024
openssl req -new -key vsftpd.key -out vsftpd.csr
openssl x509 -req -days 365 -sha256 -in vsftpd.csr -signkey vsftpd.key -out vsftpd.crt
生成秘鑰和證書文件後,將本目錄(/etc/ssl/certs/)的許可權修改為500
chmod 500 /etc/ssl/certs/

 

修改主配置文件

#啟用ssl
ssl_enable=YES
#開啟TLSV1 SSLV2 SSLV3支持
ssl_tlsv1=YES
ssl_sslv2=YES
ssl_sslv3=YES
#允許匿名用戶[虛擬用戶]
allow_anon_ssl=YES
#匿名用戶登錄和傳輸時強制使用ssl
force_anon_logins_ssl=YES
force_anon_data_ssl=YES
#本地登錄和傳輸時強制使用ssl
force_local_logins_ssl=YES
force_local_data_ssl=YES

rsa_cert_file=/etc/ssl/certs/vsftpd.crt
rsa_private_key_file=/etc/ssl/certs/vsftpd.key
配置完之後重啟服務

使用客戶端連接的時候選擇 TLS/SSL顯示加密可以看到證書信息

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 到目前為止,看到的所有動畫都使用線性插值從起點到終點。但如果需要創建具有多個分段的動畫和不規則移動的動畫。例如,可能希望創建一個動畫,快速地將一個元素滑入到視圖中,然後慢慢地將它移到正確位置。可通過創建兩個連續的動畫,並使用BeginTime屬性在第一個動畫之後開始第二個動畫來實現這種效果。然而,還 ...
  • 微信門戶應用管理系統,採用基於 MVC + Bootstrap + Ajax + Enterprise Library的技術路線,界面層採用Boostrap + Metronic組合的前端框架,數據訪問層支持Oracle、SQLServer、MySQL、PostgreSQL等資料庫。框架以MVC5,... ...
  • 上一篇說的是asp.net mvc核心UseMvc的過程,末尾想捋一下asp.net核心的路由流轉過程,現在看來還是要準備下一個代碼,熟悉了代碼,那麼整個流轉過程就通了〜 不多說,今兒先看下,RouteContext: private RouteData _routeData; public Rou ...
  • 一 前言 實戰踩坑系列,調用第三方Oracle存儲,各種血淚史,現記錄如下。 二 入坑 首先,調用Oracle需要安裝客戶端驅動才行,但是在程式開發中下載客戶端驅動是一個不明智的選擇。於是,不管是微軟,還是oracle,都提供了方便我們程式開發的插件(dll/nuget),如System.Data. ...
  • 一.準備環境 1.1 運行環境Linxu系統 CentOS7.5【騰訊雲】 1.2 安裝Docker https://www.cnblogs.com/bob-zb/p/12401407.html 1.3 在Docker中安裝jenkins https://www.cnblogs.com/bob-zb ...
  • 存儲日誌 public void log(string neirong) { var path = @"D:\xx文件名xx\Log\" + "日誌" + ".log"; using (StreamWriter st = new StreamWriter(path, append: true)) { ...
  • 一、目錄的認識 https://www.runoob.com/aspnet/mvc-folders.html 二、約定大於配置 1、方法的名稱與視圖的名稱一致。 2、視圖要放在Views文件下的當前方法所在控制器名稱一致的文件夾內。 三、添加數據 1、如果方法的參數與表單元素name屬性的值一致的話 ...
  • Github是一個面向開源及私有軟體項目的托管平臺,擁有4000萬開發者,超過210萬企業和組織使用,有1億個項目(github.com 2019年8月),如此多的開發者,如此多的項目,如何使用更好的學習這些項目,如何跟著大牛學習,下麵將介紹Github的探索功能,幫助你更好的使用項目和學習。 1. ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...