Moje standardowe wyłączenie odpowiedzialności: Jestem programistą tego produktu.
Korzystając z produktu (Runtime Intelligence) napisanego przez firmę, w której pracuję (PreEmptive Soltutions), można wstrzykiwać nie tylko raportowanie błędów, ale także śledzić, kiedy użytkownicy korzystają z aplikacji i jakie funkcje wykorzystują przy minimalnym kodowaniu .
Za pomocą aplikacji Dotfuscator do wykonywania wstrzyknięć kodu (lub tkania IL) wstawiamy nowy kod do plików binarnych aplikacji, które wysyłają dane użytkowania z powrotem do serwera hostowanego w naszym obiekcie (lub opcjonalnie do dowolnego dowolnego dowolnego adresu URL). Jeśli prześlesz nam dane, udostępnimy Ci szereg zaawansowanych narzędzi analitycznych i raportów dotyczących użytkowania.
Podstawowa wersja tej funkcji ma być zawarta w Visual Studio 2010, jak również dostęp do bezpłatnego portalu raportowania danych (ale bez umów SLA, gwarancji zatrzymywania danych lub prywatności danych).
Możliwość wysyłania dowolnych danych z powrotem wraz z informacjami o użytkowaniu jest ograniczona do produktu komercyjnego, ale możesz skontaktować się z PreEmptive Soltutions, aby uzyskać w pełni funkcjonalną, czasową wersję próbną.
można osiągnąć raportowanie błędów z przykładowy kod poniżej:
public partial class app : Application {
// field to temporarily store exception data
private Exception exp;
void AppStartup(object sender, StartupEventArgs args) {
// add a handler to catch any unhandled exceptions
this.DispatcherUnhandledException += new DispatcherUnhandledExceptionEventHandler(ErrorHandler);
Window1 mainWindow = new Window1();
mainWindow.ShowDialog();
}
// this will prompt the user if they want to report the exception
void ErrorHandler(object sender, DispatcherUnhandledExceptionEventArgs e) {
this.exp = e.Exception;
if (MessageBox.Show("A " + exp.Message + " exception happened, should I report it?", "Error Occurrend", MessageBoxButton.YesNo) == MessageBoxResult.Yes) {
ErrorHappened();
e.Handled = true;
}
}
// this method is called by the above ErrorHandler method and when run through Dotfuscator additional code will be injected into this method that will send a usage data message back to the server and the data in the dictionary (which will be exception data) returned by the ErrorData method will be included into the message and be stored and reported on the server
[Feature("Exception", EventType = FeatureEventTypes.Tick, ExtendedKeySourceElement = SourceElements.Method, ExtendedKeySourceName = "ErrorData")]
private void ErrorHappened() {
// This is here as a placeholder for the exception feature attribute which will exit the application when executed
AppShutdown(true);
}
// this method takes the exception data from the exp field and returns it as a dictionary of name/value pairs
public Dictionary<string, string> ErrorData() {
var retval = new Dictionary<string,string>();
if (null != exp) {
retval.Add("Error Message",exp.Message);
retval.Add("Stack Trace",exp.StackTrace);
}
return retval;
}
}
Można by nadal mieć problem połowu wyjątki generowane przez innych wątków :) – cwap
A także istnieją nieuchwytny excpetions; np. StackOverflowException;) – Wilhelm
"Jeśli wyjątek rozprzestrzenia się aż do początku mojej aplikacji (co, oczywiście, nigdy się nie wydarzy) ..." Zapomniałeś dodać buźkę, aby dać nam znać, że żartujesz. :) Nie jest przesadą stwierdzenie, że wszystkie aplikacje ulegają awarii. –