推薦:解讀軟件系統(tǒng)與軟件系統(tǒng)之間的集成交互問題可能寫得有些亂,希望能諒解,同時我整理的思想,希望能給您帶來一些啟發(fā)或者幫助。 我們假設(shè)一個國際化的大公司里,有來自多個國家的員工,這些員工又工作在不同的部門里,負責(zé)不同的任務(wù)。 首先: 1. 這些人可能是白人,也可能是黑人,也可能是黃皮膚的我
使用asp.net或vb.net或C#.net均可以實現(xiàn)插件的功能,插件的作用是對系統(tǒng)的后期未知擴展預(yù)留快速升級的空間!插件開發(fā)完成后將以DLL的形式發(fā)布到特定的文件夾中,例如主程序文件夾是D:/myApp/myApp.exe,我們可以在D:/myApp中定義文件夾D:/myApp/Plus目錄來存放插件。
在程序中通過遍歷該文件夾中的所有DLL檢測符合預(yù)定接口的插件來實現(xiàn)動態(tài)裝載相應(yīng)的功能模塊!
下面舉例:
一、定義接口
新建解決方案用于生成此接口
二、編寫繼承自該接口的自定義組件(將編譯成DLL)
該操作您需要新建一個解決方案
Imports System.Data
Imports System.Data.SqlClient
Imports System.Net
Imports System.IO
Imports na7Interface.IPlugin

Public Class recvClass recv
Implements IPlugin '實現(xiàn)此接口
'構(gòu)造屬性變量
Private _MovementID As Integer = 27
Private _MovementName As String = "51麥克瘋"
Private _SpanMinute As Integer = 30
Private _ConnectionString As String = ""
Private Fir As String = "活動:" + MovementName + "(" + MovementID.ToString + ")"

/**/''' <summary>
''' 返回內(nèi)部處理的消息,實現(xiàn)接口中的RaiseLog事件。
''' </summary>
''' <param name="logText"></param>
''' <remarks></remarks>
Public Event RaiseMyEvent(ByVal logText As String) Implements IPlugin.RaiseLog

/**/''' <summary>
''' 調(diào)用此方法!
''' </summary>
''' <remarks></remarks>
Public Sub Init()Sub Init() Implements IPlugin.Init '繼承自接口的Init方法。
'這里放置數(shù)據(jù)抓取及相關(guān)的處理程序。
'實際應(yīng)用中要根據(jù)您的程序何時調(diào)用Init決定,這不是必須的方法
ResultText("處理完成!")
End Sub

Private Sub SaveSetups()Sub SaveSetups(ByVal savedate As String, ByVal UserID As String, ByVal WebId As String, ByVal Setups As String)
'定義該內(nèi)部方法,這個方法不實現(xiàn)任何接口中的方法。因此只在本類內(nèi)部實現(xiàn)。
Dim CmdText As String = ""
End Sub

/**/''' <summary>
''' 返回八位數(shù)字的日期格式
''' </summary>
''' <param name="dt"></param>
''' <returns></returns>
''' <remarks></remarks>
Private Function ClongDate()Function ClongDate(ByVal dt As Date) As String '同上
Dim mm As String = dt.Month.ToString
If mm.Length = 1 Then mm = "0" + mm
Dim dd As String = dt.Day.ToString
If dd.Length = 1 Then dd = "0" + dd
Return dt.Year.ToString + "" + mm + dd
End Function

Private Function ConvDate()Function ConvDate(ByVal dt As Long) As String '同上
Dim YY As String = Mid(dt.ToString, 1, 4)
Dim MM As String = Mid(dt.ToString, 5, 2)
Dim DD As String = Mid(dt.ToString, 7, 2)
Return YY + "-" + MM + "-" + DD + " 00:00:00"
End Function

/**/''' <summary>
''' 獲得此組件處理的活動ID,該屬性實現(xiàn)了接口IPlugin的MovementID屬性。
''' </summary>
''' <value></value>
''' <returns></returns>
''' <remarks></remarks>
Public Property MovementID()Property MovementID() As Integer Implements IPlugin.MovementID
Get
Return _MovementID
End Get
Set(ByVal value As Integer)
_MovementID = value
End Set
End Property

/**/''' <summary>
''' 獲得此組件的活動名稱,同上
''' </summary>
''' <value></value>
''' <returns></returns>
''' <remarks></remarks>
Public Property MovementName()Property MovementName() As String Implements IPlugin.MovementName
Get
Return _MovementName
End Get
Set(ByVal value As String)
_MovementName = value
End Set
End Property

/**/''' <summary>
''' 獲得此組件定時調(diào)用的間隔分鐘數(shù),實現(xiàn)自定義屬生ReTryMinute
''' </summary>
''' <value></value>
''' <returns></returns>
''' <remarks></remarks>
Public Property SpanMinute()Property SpanMinute() As Integer Implements IPlugin.ReTryMinute
Get
Return _SpanMinute
End Get
Set(ByVal value As Integer)
_SpanMinute = value
End Set
End Property

Public Property ConnectionString()Property ConnectionString() As String Implements IPlugin.ConnectionString
Get
Return _ConnectionString
End Get
Set(ByVal value As String)
_ConnectionString = value
End Set
End Property

Public Sub ResultText()Sub ResultText(ByVal txt As String)
'響應(yīng)事件
RaiseEvent RaiseMyEvent(txt)
End Sub
End Class
新聞熱點
疑難解答
圖片精選