我使用C#& amp;创建了一个Windows服务。 VS 2012 Express。在我成功安装服务之后但是当我尝试启动它时,我在Windows应用程序日志中收到以下错误:服务运行时无法更改服务名称。
我是一名VB6程序员在C#尝试我的手(从服务开始叫我疯了)......
您的投入将不胜感激。
这是我的代码:
using System;
using System.IO;
using System.ComponentModel;
using System.ServiceProcess;
using System.Configuration.Install;
public class KFolderWatcher : ServiceBase
{
public const string MyServiceName = "KFolderWatcher";
private FileSystemWatcher watcher = null;
public KFolderWatcher()
{
this.ServiceName = "KFolderWatcher";
this.CanStop = true;
this.CanPauseAndContinue = false;
this.AutoLog = true;
}
protected override void OnStart(string[] args)
{
this.ServiceName = MyServiceName;
// Create a new FileSystemWatcher with the path and jpg file filter
FileSystemWatcher watcher = new FileSystemWatcher("c:\\scans\\", "*.jpg");
//Watch for changes in LastAccess and LastWrite times, and the renaming of files or directories.
watcher.NotifyFilter = NotifyFilters.LastAccess
| NotifyFilters.LastWrite
| NotifyFilters.FileName
| NotifyFilters.DirectoryName;
// Add event handlers.
watcher.Changed += new FileSystemEventHandler(OnChanged);
watcher.Created += new FileSystemEventHandler(OnChanged);
watcher.Deleted += new FileSystemEventHandler(OnChanged);
watcher.Renamed += new RenamedEventHandler(OnRenamed);
// Begin watching.
watcher.EnableRaisingEvents = true;
}
protected override void OnStop()
{
watcher.EnableRaisingEvents = false;
watcher.Dispose();
//LogEvent("Monitoring Stopped");
Console.WriteLine("Monitoring Stopped");
}
void OnRenamed(object sender, RenamedEventArgs e)
{
string log = string.Format("{0} | Renamed from {1}", e.FullPath, e.OldName);
//LogEvent(log);
Console.WriteLine(log);
}
public static void Main()
{
ServiceBase.Run(new KFolderWatcher());
}
//This method is called when a file is created, changed, or deleted.
private static void OnChanged(object source, FileSystemEventArgs e)
{
//Show that a file has been created, changed, or deleted.
WatcherChangeTypes wct = e.ChangeType;
Console.WriteLine("File {0} {1}", e.FullPath, wct.ToString());
}
protected void FileCreated(object sender, FileSystemEventArgs e)
{
if (e.ChangeType == WatcherChangeTypes.Created)
{
if (Directory.Exists(e.FullPath))
Console.WriteLine("A new folder has been created.");
else
Console.WriteLine("A new file has been created.");
}
}
}
[RunInstaller(true)]
public class KFolderWatcherInstaller : Installer
{
private ServiceProcessInstaller processInstaller;
private ServiceInstaller serviceInstaller;
public KFolderWatcherInstaller()
{
processInstaller = new ServiceProcessInstaller();
serviceInstaller = new ServiceInstaller();
processInstaller.Account = ServiceAccount.LocalSystem;
processInstaller.Username = null;
processInstaller.Password = null;
serviceInstaller.StartType = ServiceStartMode.Manual;
serviceInstaller.ServiceName = "KFolderWatcher";
serviceInstaller.DisplayName = "Kempston Folder Watcher";
serviceInstaller.Description = "Monitor Branch Folder for images to upload.";
Installers.Add(serviceInstaller);
Installers.Add(processInstaller);
}
}
答案 0 :(得分:3)
请避免在服务类中分配服务名称。由于您已经创建了一个分配服务名称的安装程序,因此不需要在服务中写入它。
serviceInstaller.ServiceName = "KFolderWatcher";
public class KFolderWatcher : ServiceBase
{
//public const string MyServiceName = "KFolderWatcher";
private FileSystemWatcher watcher = null;
public KFolderWatcher()
{
// this.ServiceName = "KFolderWatcher";
this.CanStop = true;
this.CanPauseAndContinue = false;
this.AutoLog = true;
}
protected override void OnStart(string[] args)
{
// this.ServiceName = MyServiceName;
.....
答案 1 :(得分:3)
该行
this.ServiceName = MyServiceName;
在OnStart()方法中的导致了问题。