@import url(http://i.cnblogs.com/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/css/cuteeditor.css);
参考:   http://gzzhang.blog.51cto.com/5312382/1125092

随着IIS7的发布,IIS自带的FTP终于能自定义验证了.

目前知道的自定义接口共三个  自定义校验, 自定义主目录,自定义日志

分别是 Microsoft.Web.FtpServer的

IFtpAuthenticationProvider,
        IFtpRoleProvider       主目录: IFtpHomeDirectoryProvider  日志的没测试, 可以在WWW.IIS.NET直接找到的

步骤:

1.  首先创建 C#类库 (要选择 2.0  / 3.5 框架) ,有说 .NET 4.0不支持 ,但是这个没做验证,需要后期继续测试

2.  然后增加生成事件  后期处理  VS2012版本:

net stop ftpsvc
call "%VS110COMNTOOLS%\vsvars32.bat">null
gacutil.exe /if "$(TargetPath)"
net start ftpsvc   VS2013 =vs120 ,其他版本递减

3. 添加签名(无密码)

4. 代码

namespace FtpHomeDirectory

{

    public class FtpHomeDirDemo : BaseProvider,

        IFtpHomeDirectoryProvider

    {

        string IFtpHomeDirectoryProvider.GetUserHomeDirectoryData(

            string sessionId,

            string siteName,

            string userName)

        {

            // Note: You would add your own custom logic here.

            // Return the user's home directory based on their user name.

            string homedir = @"D:\Ftptest\" + userName;

            VASLog.WriteLog_day(@"d:\Ftptest", "ftplog", "siteName: " + siteName + "   用户想要得到的目录是:"+homedir+" ;");

            return homedir;

        }

    }

}

密码验证

namespace FtpAuthenticationDemo

{

    public class FtpAuthDemo : BaseProvider,

        IFtpAuthenticationProvider,

        IFtpRoleProvider  

    {

        //void IFtpLogProvider.Log(FtpLogEntry loggingParameters)

        //{

        //    // Note: You would add your own custom logic here.

        //    // Open the log file for output.

        //    using (StreamWriter sw =

        //        new StreamWriter(@"C:\inetpub\logs\LogFiles\FTPSVC8\myftplog.log", true))

        //    {

        //        // Retrieve the current date and time for the log entry.

        //        DateTime dt = DateTime.Now;

        //        // Retrieve the user name.

        //        string un = loggingParameters.UserName;

        //        // Write the log entry to the log file.

        //        sw.WriteLine("{0}\t{1}\t{2}\t{3}\t{4}\t{5}",

        //            dt.ToShortDateString(),

        //            dt.ToLongTimeString(),

        //            loggingParameters.RemoteIPAddress,

        //            (un.Length == 0) ? "-" : un,

        //            loggingParameters.Command,

        //            loggingParameters.SessionId);

        //    }

        //}

        bool IFtpAuthenticationProvider.AuthenticateUser(

            string sessionId,

            string siteName,

            string userName,

            string userPassword,

            out string canonicalUserName)

        {

            // Note: You would add your own custom logic here.

            canonicalUserName = userName;

            //string strUserName = "test";

            //string strPassword = "123";

            VASLog.WriteLog_day(@"d:\Ftptest", "ftplog", canonicalUserName + "   siteName: " +siteName +"   校验总是可以成功的;");

            return true;

            // Verify that the user name and password are valid.

            // Note: In this example, the user name is case-insensitive

            // and the password is case-sensitive.

            //if (((userName.Equals(strUserName,

            //    StringComparison.OrdinalIgnoreCase)) == true) &&

            //    userPassword == strPassword)

            //{

            //    return true;

            //}

            //else

            //{

            //    return true;

            //}

        }

        bool IFtpRoleProvider.IsUserInRole(

            string sessionId,

            string siteName,

            string userName,

            string userRole)

        {

            // Note: You would add your own custom logic here.

            string strUserName = "MyUser";

            string strRoleName = "MyRole";

            //VASLog.WriteLog_day(@"d:\Ftptest", "ftplog", "IsUserInRole");

            return true;

            // Verify that the user name and role name are valid.

            // Note: In this example, both the user name and

            // the role name are case-insensitive.

            if (((userName.Equals(strUserName,

                StringComparison.OrdinalIgnoreCase)) == true) &&

                ((userRole.Equals(strRoleName,

                StringComparison.OrdinalIgnoreCase)) == true))

            {

                return true;

            }

            else

            {

                return false;

            }

        }

        //string IFtpHomeDirectoryProvider.GetUserHomeDirectoryData(

        //        string sessionId,

        //        string siteName,

        //        string userName)

        //{

        //    VASLog.WriteLog_day(@"d:\Ftptest", "ftplog", "GetUserHomeDirectoryData");

        //    // Note: You would add your own custom logic here.

        //    // Return the user's home directory based on their user name.

        //    return @"d:\FtpTest\" + userName;

        //}

    }

}

尽量两个分开吧

生成后,在输出里可以看到

1>  
1>  Microsoft (R) .NET Global Assembly Cache Utility.  Version 4.0.30319.17929
1>  版权所有(C) Microsoft Corporation。保留所有权利。
1>  
1>  程序集已成功添加到缓存中
1>  Microsoft FTP Service 服务正在启动 .
1>  Microsoft FTP Service 服务已经启动成功。

然后要做的,就是配置IIS了

1. 在IIS的根基目录中,配置 FTP身份验证,禁用其他选项,在右侧自定义提供程序中,注册刚才的DLL,

http://www.iis.net/learn/develop/developing-for-ftp/how-to-use-managed-code-c-to-create-a-simple-ftp-authentication-provider

2. FTP规则里,允许所有账户

3. 同样的注册主目录DLL

4. 跟密码验证不同,主目录的DLL,还需要设置两个地方

http://www.iis.net/learn/develop/developing-for-ftp/how-to-use-managed-code-c-to-create-a-simple-ftp-home-directory-provider

cd  %systemroot%/system32/Inetsrv/

AppCmd set site "YourFTP" /+ftpServer.customFeatures.providers.[name='FtpHomeDirectoryDemo',enabled='true']
AppCmd set site "YourFTP" /ftpServer.userIsolation.mode:Custom

注意:  第一个appcmd 里面的 name = ftphomedirectorydemo 这个name,是在上面注册在IIS里的名称,跟DLL的空间类名没关系,一定要注意

禁用缓存,以管理员身份运行:
cd /d "%SystemRoot%\System32\Inetsrv"
Appcmd.exe set config -section:system.ftpServer/caching /credentialsCache.enabled:"False" /commit:apphost

这个一定要执行,不然,修改了数据库的密码之后,依然旧密码要保留一点时间,但是原因是什么,不理解.

现象,好像是登录时,直接就过了验证,进入到了目录获取的地方去了.

这样设置之后,才能启用主目录的设置

5. 在FTP用户隔离里,选择 下面的 用户名目录(禁用全局虚拟目录) ,这个用不用,还不知道,有待测试! 原理上考虑,这个其实没作用了,毕竟主目录在DLL里,已经可以定义了

这里应该在FTP用户隔离 属性设置中,改成自定义(简单测试了下,好像是这样)

这里有个好玩的,如果继续设置LocalUser虚拟目录(物理目录也可以的),指向了同名FTP用户名的文件夹下面,

这时候设置IP限制之类的,也是生效的,这样子,可以针对单独的FTP做限制了。

FTP 7.5 自定义扩展功能的更多相关文章

  1. Java 自定义FTP连接池

    转自:https://blog.csdn.net/eakom/article/details/79038590 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn ...

  2. 虚拟机中使用centos7搭建ftp服务器

    应用场景 本地windows作为客户端,虚拟机CentOS7作为服务器端,搭建FTP服务器,本地访问虚拟机实现文件的上传下载.如何在虚拟机安装centos7就不在赘述. 1.在centos7上安装vs ...

  3. FTP和TCP的文件传输效率对比测试分析

    前言 最近因项目需要,需要把一定数量的中等文件从开发板上传到电脑上,分别选择了FTP和TCP自定义协议两种方式进行传输,进行了简单的对比测试,故做如下记录. 测试环境 开发板:Linux,ARMv7 ...

  4. 一文看懂web服务器、应用服务器、web容器、反向代理服务器区别与联系

    我们知道,不同肤色的人外貌差别很大,而双胞胎的辨识很难.有意思的是Web服务器/Web容器/Web应用程序服务器/反向代理有点像四胞胎,在网络上经常一起出现.本文将带读者对这四个相似概念如何区分. 1 ...

  5. Web服务器、应用服务器、Web容器、反向代理服务器区别与联系

    作者: 帅虫哥 出处:www.cnblogs.com/vipyoumay/p/7455431.html(点击尾部阅读原文前往) 我们知道,不同肤色的人外貌差别很大,而双胞胎的辨识很难.有意思的是Web ...

  6. [转帖]一文看懂web服务器、应用服务器、web容器、反向代理服务器区别与联系

    一文看懂web服务器.应用服务器.web容器.反向代理服务器区别与联系 https://www.cnblogs.com/vipyoumay/p/7455431.html 我们知道,不同肤色的人外貌差别 ...

  7. Membership三步曲之入门篇 - Membership基础示例

    Membership 三步曲之入门篇 - Membership基础示例 Membership三步曲之入门篇 -  Membership基础示例 Membership三步曲之进阶篇 -  深入剖析Pro ...

  8. Android Weekly Notes Issue #232

    Android Weekly Issue #232 November 20th, 2016 Android Weekly Issue #232 本期内容包括: Kotlin的优势讨论; MVVM模式结 ...

  9. 开源免费的HTML5游戏引擎

    青瓷引擎的成长 青瓷引擎自2015年4月项目启动开始,7月首次亮相2015年ChinaJoy,便得到业界的极大关注,随后开启限量测试,收到数百个开发者团队的试用申请及反馈,期间经历了18个内测版本,完 ...

随机推荐

  1. 21.编写一个Java应用程序,该程序包括3个类:Monkey类、People类和主类 E。要求: (1) Monkey类中有个构造方法:Monkey (String s),并且有个public void speak() 方法,在speak方法中输出“咿咿呀呀......”的信息。 (2)People类是Monkey类的子类,在People类中重写方法speak(),在speak方法 中输出“小样

    //Monkey类 package d922; public class Monkey { Monkey() { } Monkey (String s) { System.out.println(s) ...

  2. Mac 必备软件 Quicksilver

    http://www.xdanger.com/2007/03/30/000067.html

  3. mybatis遇见的奇葩问题(返回null)

    1.问题描述 select 语句没有问题,执行完毕后通过日志也可以看出 select到数据了,但是拿到的值就是null 2.原因 原来是有人将对象变量命名给改了,导致select到结果后不能映射成为对 ...

  4. vs2010环境下将Win32控制台应用程序,改为Win32项目

    进入工程属性后,一次进入下面选项做相应修改 连接器 ---> 系统 --->子系统: 控制台 (/SUBSYSTEM:CONSOLE)改为:窗口 (/SUBSYSTEM:WINDOWS)

  5. iOS的一些关键字

    最近在使用Swift的过程中,感觉到苹果公司为了迎合Swift,在Objective-C中添加了许多关键字.这些关键字一般用来用来修饰属性,或者方法的参数以及方法的返回值等等.而在以前的Objecti ...

  6. php 验证码类

    <?php  class Vcode {   private $width; //宽   private $height; //高   private $num;  //数量   private ...

  7. javaWEB总结(6):ServletRequest

    1.首先看ServletRequest的API javax.servlet Interface ServletRequest All Known Subinterfaces: HttpServletR ...

  8. 《Windows驱动开发技术详解》之分层驱动程序

    分层驱动程序概念 分层的目的是将功能复杂的驱动程序分解成多个简单的驱动程序.一般来说,他们是指两个或两个 以上的驱动程序,它们分别创建设备对象,并且形成一个由高到低的设备对象栈.IRP请求一般会被传送 ...

  9. 批量创建IP方法

    以下教程,将告诉大家如何在Windows系统中通过命令行,批量添加IP.目标,在本机的的网卡名称为“本地连接”的网卡中,批量添加192.168.1段的ip地址,起开始IP为10,每次增加1,知道22为 ...

  10. YII 常用路径总结

      Yii framework已经定义的命名空间常量 system: 指向Yii框架目录; YII\framework zii: 指向zii library 目录; YII\framework\zii ...