• <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年9月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            30123456

            統計

            常用鏈接

            留言簿(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 五點半 閱讀(5391) 評論(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

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

            久久夜色撩人精品国产小说| 精品免费tv久久久久久久| 国产免费久久精品99久久| 久久久久国产精品麻豆AR影院| 久久午夜综合久久| 久久精品人人做人人妻人人玩| 大美女久久久久久j久久| 精品久久人人爽天天玩人人妻| 99久久精品国产麻豆| 九九精品久久久久久噜噜| 国内精品久久久久影院免费| 无码任你躁久久久久久老妇App| 久久伊人精品青青草原高清| 伊人久久国产免费观看视频| 久久精品一区二区| 亚洲熟妇无码另类久久久| 精品久久久久久无码免费| 久久99精品久久久久久动态图 | 一本久久a久久精品亚洲| 久久精品人人做人人爽电影| 伊人色综合久久天天人手人婷| 国产精品免费久久久久影院| 久久久久久九九99精品| 久久久精品久久久久影院| 国产精品成人99久久久久 | 亚洲日本va午夜中文字幕久久| 久久婷婷五月综合国产尤物app| 国产香蕉97碰碰久久人人| 日本强好片久久久久久AAA| 久久人妻无码中文字幕| 欧美粉嫩小泬久久久久久久 | 久久电影网一区| 伊人久久精品无码二区麻豆| 亚洲国产成人久久综合一区77| 国内精品久久久久久久亚洲| 狠狠狠色丁香婷婷综合久久五月| 狠狠88综合久久久久综合网| 久久亚洲美女精品国产精品| 久久国产欧美日韩精品| 精品久久久久久无码专区| 久久99热狠狠色精品一区|