• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            無法遞歸的五點半

            for_each(day.begin(),day.end(),bind2nd(Add(),me))

            導航

            <2007年3月>
            25262728123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            統計

            常用鏈接

            留言簿(4)

            隨筆分類

            隨筆檔案

            文章分類

            相冊

            收藏夾

            C++

            Unix/Linux

            個人主頁

            其他

            軟件工程

            網絡管理

            綜合

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            評論排行榜

            OpenSSH下SFTP的配置

            OpenSSH網站上那只SSH刺河豚將FTP埋葬

            有關sftp有人推薦www.ssh.com的實現,不過我更喜歡開源的產品,特別是Open系列的安全產品。

            需求

            首先我們明確我們的目標,我們是希望通過SFTP代替FTP,需求是這樣的:
            1. 這些用戶只能通過SFT訪問服務器
            2. 用戶要鎖定在相應的目錄下
            我想通常的思路是這樣的:
            1. 打開OpenSSH的SFTP
            2. 將這些用戶設置在一個
            3. 讓OpenSSH識別這個組,只允許這些用戶使用SFTP
            4. 最后系統要自動的將用戶chroot在用戶目錄下

            配置

            我開始都覺得是不是要求太高,不過OpenSSH可以解決以上所有問題。話說回來,如果不能解決怎么可以把FTP埋葬呢。

            SSHD_CONFIG

            sshd通常是打開了sftp的,不過我們應該使用internal-sftp在sshd_conf中作如下配置:
             1 # Subsystem sftp /usr/lib/openssh/sftp-server # 注釋掉
             2 Subsystem sftp internal-sftp
             3 
             4 ##
             5 Match group sftponly
             6     ChrootDirectory /sftphome/%u
             7     X11Forwarding no
             8     AllowTcpForwarding no
             9     ForceCommand internal-sftp
            10 
            解釋一下:當sshd匹配到sftponly組中的用戶,就會強制使用sftp(ForceCommand的作用),并將用戶限定在/sftphome/下相應用戶的目錄下(ChrootDirectory的作用)。

            創建用戶

            我們需要創建相應的用戶了:

            #useradd -G sftponly -d /sftphome/sftpuser  -s /usr/sbin/nologin sftpuser
            #tail /etc/password

            sftpuser:x:
            1000:1000::/sftphome/sftpuser:/usr/sbin/nologin
            #passwd sftpuser
            你可以在其他機器上用sftp登錄試試了。你的連接將會被reset!去看看sshd的日志,你會發現pam.d的認證是通過了的,但是chroot失敗了。按網絡上的說法
            #chown root /sftphome/sftpuser
            #chmod 
            755 /sftphome/sftpuser
            再試,可以登錄。新的問題是不能在此目錄下寫入。對的嘛,755對于組用戶是不能寫啊。再試試775,剛才的問題就來又了,chroot失敗。

            以上內容網絡上一google一大把。

            可以登錄不能寫這個問題真讓人困惑!后來我想可能應該這樣理解:既然要chroot,那個目錄不屬于root肯定是不行的(說錯了,猛拍磚)。那我們就不能為用戶提供完整的sftp服務了嗎?我想可以這樣
            #mkdir /sftphome/sftpuser/space
            #chown sftpuser.sftpuser /sftphome/sftpuser/space
            由系統管理員為sftp用戶提供一個目錄,并設置其用戶屬性,用戶在這個目錄下用戶是可寫的。當然可以創建很多個。

            這樣算不算解決這個問題呢?暫且如此吧。如果您有好方法,一定告知哦。


            posted on 2009-12-02 21:04 五點半 閱讀(5382) 評論(3)  編輯 收藏 引用 所屬分類: 開發環境

            評論

            # re: OpenSSH下SFTP的配置 2010-09-03 01:50 Holden

            chown sftpuser.sftpuser /sftphome/sftpuser/space 應為
            chown sftpuser:sftponly /sftphome/sftpuser/space?  回復  更多評論   

            # re: OpenSSH下SFTP的配置 2010-09-03 08:54 lambdacpp

            @Holden
            應該都是可以的。
              回復  更多評論   

            # re: OpenSSH下SFTP的配置 2010-09-19 10:34 kangzj

            應該沒有啥好辦法了  回復  更多評論   

            丁香狠狠色婷婷久久综合| 久久ZYZ资源站无码中文动漫| 99久久无色码中文字幕| 久久国产免费直播| 久久美女人爽女人爽| 久久久精品国产亚洲成人满18免费网站| 99久久精品免费看国产| 久久天天婷婷五月俺也去| 少妇内射兰兰久久| 久久久99精品成人片中文字幕| 一本一道久久精品综合| 久久青草国产精品一区| 国产精品嫩草影院久久| 亚洲AV无码久久精品狠狠爱浪潮| 99蜜桃臀久久久欧美精品网站| 99久久国产综合精品成人影院| 久久精品国产亚洲一区二区| 中文无码久久精品| 久久精品国产精品亚洲毛片 | 狠狠色丁香婷综合久久| 久久久久四虎国产精品| 久久毛片免费看一区二区三区| 久久一日本道色综合久久| 久久夜色撩人精品国产| 亚洲欧美一级久久精品| 久久久久久国产a免费观看不卡| 亚洲国产精品成人久久蜜臀| 亚洲午夜久久久久久久久久| 久久亚洲日韩精品一区二区三区 | 国产精品综合久久第一页| 久久涩综合| av午夜福利一片免费看久久| 久久婷婷五月综合97色直播| 99久久er这里只有精品18| 久久久久国产精品三级网| 亚洲色欲久久久综合网| 国产精品激情综合久久| 日韩精品久久久久久免费| 久久综合伊人77777| 蜜臀久久99精品久久久久久小说 | 久久精品国产第一区二区|