VoDA.FtpServer ist eine einfache FTP-Serverbibliothek. Diese Bibliothek vereinfacht die Interaktion mit dem FTP-Protokoll bis auf die Ereignisebene. Alle Anfragen an den Server im Zusammenhang mit der Autorisierung oder der Arbeit mit Daten führen zu Ereignissen, die Sie implementieren müssen.
Um den Server zu starten, müssen Sie ein FtpServerBuilder-Objekt erstellen und es mithilfe von Funktionen konfigurieren, wie im folgenden Beispiel gezeigt. Weitere Informationen zu den einzelnen Funktionen finden Sie unter ConfigurationParameters. Rufen Sie nach der Konfiguration die Funktion Build()
auf, um einen Server zu erstellen.
Ein Beispiel für einen FTP-Server zum Arbeiten mit dem Dateisystem finden Sie im Testprojekt.
var server = new FtpServerBuilder ( )
. ListenerSettings ( ( config ) =>
{
config . Port = 21 ; // enter the port
config . ServerIp = System . Net . IPAddress . Any ;
} )
. Log ( ( config ) =>
{
config . Level = LogLevel . Information ; // enter log level. Default: Information
} )
. Certificate ( ( config ) =>
{
config . CertificatePath = ". \ server.crt" ;
config . CertificateKey = ". \ server.key" ;
} )
. Authorization ( ( config ) =>
{
config . UseAuthorization = true ; // enable or disable authorization
config . UsernameVerification += ( username ) => { .. . } ; // username verification
config . PasswordVerification += ( username , password ) => { .. . } ; //verification of username and password
} )
. FileSystem ( ( fs ) =>
{
fs . OnDeleteFile += ( client , path ) => { .. . } ; // delete file event
fs . OnRename += ( client , from , to ) => { .. . } ; // rename item event
fs . OnDownload += ( client , path ) => { .. . } ; // download file event
fs . OnGetList += ( client , path ) => { .. . } ; // get items in folder event
fs . OnExistFile += ( client , path ) => { .. . } ; // file check event
fs . OnExistFoulder += ( client , path ) => { .. . } ; // folder check event
fs . OnCreate += ( client , path ) => { .. . } ; // file creation event
fs . OnAppend += ( client , path ) => { .. . } ; // append file event
fs . OnDeleteFolder += ( client , path ) => { .. . } ; // remove folder event
fs . OnUpload += ( client , path ) => { .. . } ; // upload file event
fs . OnGetFileSize += ( client , path ) => { .. . } ; // get file size event
fs . OnGetFileModificationTime += ( client , path ) => { .. . } ; // returns the last modified date of the file
} )
. Build ( ) ;
// Start FTP-serer
server . StartAsync ( System . Threading . CancellationToken . None ) . Wait ( ) ;
Oder Sie können Ihre eigene Klasse verwenden, die von der Kontextklasse erbt. Ein Beispiel finden Sie unten.
In diesem Beispiel erbt die Klasse MyAuthorization
von VoDA.FtpServer.Contexts.AuthorizationOptionsContext
und die Klasse MyFileSystem
von VoDA.FtpServer.Contexts.FileSystemOptionsContext
var server = new FtpServerBuilder ( )
. ListenerSettings ( ( config ) =>
{
config . Port = 21 ; // enter the port
config . ServerIp = System . Net . IPAddress . Any ;
} )
. Log ( ( config ) =>
{
config . Level = LogLevel . Information ; // enter log level. Default: Information
} )
. Certificate ( ( config ) =>
{
config . CertificatePath = ". \ server.crt" ;
config . CertificateKey = ". \ server.key" ;
} )
. Authorization < MyAuthorization > ( )
. FileSystem < MyFileSystem > ( )
. Build ( ) ;
// Start FTP-serer
server . StartAsync ( System . Threading . CancellationToken . None ) . Wait ( ) ;
Vollständiges Beispiel finden Sie im Testprojekt.