亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

使用C#創建COM對象

2023-05-18 12:33:10
字體:
來源:轉載
供稿:網友

本文中主要討論使用C#創建COM對象的方法,并從VC++客戶端軟件訪問COM的方法。在創建COM對象時要使用COM的Interop特性,而在訪問COM時,客戶端軟件使用了TypeLibrary(.TLB文件)。

 為了簡單和方便開發人員使用、測試起見,我們使用了SQLSERVER數據庫軟件的缺省安裝中的Northwind數據庫。

 ·修改COM對象中SQLServer的名字,與SQLServer連接。

 ·我們已經創建了連接數據庫用的分別為scott、tiger的用戶名和口令,我們可以使用它或者其他現有的用戶名和口令。

 第一部分:用C#創建簡單的COM對象

 COM對象是ClassLibrary類,它生成DLL文件。要在VS開發環境中創建一個簡單的COM對象,我們可以依次選擇“文件”->“新創建”->“工程”->“VisualC#工程”->“類庫”,然后創建一個名字為Database_COMObject的工程。

需要注意的是:在COM中調用VC#對象需要下面的條件:

 ·類必須是public性質。

 ·特性、方法和事件必須是public性質的。

 ·特性和方法必須在類接口中定義。

 ·事件必須在事件接口中定義。

 不是在這些接口中定義的public性質的類成員不能被COM訪問,但它們可以被其他的.NET Framework對象訪問。要讓COM能夠訪問特性和方法,我們必須在類接口中定義它們,使它們具有DispId屬性,并在類中實現這些特性和方法。這些成員定義時的順序也就是它們在COM中順序。要讓COM訪問類中的事件,必須在事件接口中定義這些事件,并賦予它們DispId屬性。事件接口不應當由類完成,類只實現類接口(它可以實現不止一個接口,但第一個接口是缺省接口),應當在缺省接口中實現需要讓COM訪問的方法和特性,方法和特性必須被標識為public性質,并符合在類接口中的定義。需要讓COM訪問的事件也在缺省的類接口中完成,它們也必須被標識為public性質,并符合事件接口中的定義。

 在接口名字之前,每個接口需要一個GUID特性。要生成變個唯一的Guid,需要運行guidgen.exe工具軟件,并選擇“注冊表格式”

下面是一個類界面:

[Guid("694C1820-04B6-4988-928F-FD858B95C880")]

 public interface DBCOM_Interface
 {
[DispId(1)]
void Init(string userid , string password);
[DispId(2)]
bool ExecuteSelectCommand(string selCommand);
[DispId(3)]
bool NextRow();
[DispId(4)]
void ExecuteNonSelectCommand(string insCommand);
[DispId(5)]
string GetColumnData(int pos);
}

COM事件接口:

 // 事件接口Database_COMObjectEvents
[Guid("47C976E0-C208-4740-AC42-41212D3C34F0"),
InterfaceType(ComInterfaceType.InterfaceIsIDispatch)]
public interface DBCOM_Events
{
}

下面是實際的類定義:

[Guid("9E5E5FB2-219D-4ee7-AB27-E4DBED8E123E"),
ClassInterface(ClassInterfaceType.None),
ComSourceInterfaces(typeof(DBCOM_Events))]
public class DBCOM_Class : DBCOM_Interface
{

需要注意的是,在類的前面,需要設置下面的特性:

ClassInterface(ClassInterfaceType.None),
ComSourceInterfaces(typeof(DBCOM_Events))]

ClassInterfaceType.None表示沒有為該類生成類接口,如果沒有明確地實現接口,類只能通過IDispatch提供后期綁定訪問。用戶希望通過明確地由類實現的接口使外部對象能夠訪問類的功能,這也是推薦的ClassInterfaceAttribute的設置。

 ComSourceInterfaces(typeof(DBCOM_Events))]確定許多作為COM事件向外部對象提供的接口。在本文的例子中,我們不對外部對象開放任何事件。

下面是COM對象完整的源代碼:

using System;

using System.Runtime.InteropServices;
using System.IO;
using System.Text;
using System.Data.SqlClient;
using System.Windows.Forms ;

namespace Database_COMObject
{
[Guid("694C1820-04B6-4988-928F-FD858B95C880")]
public interface DBCOM_Interface
{
[DispId(1)]
void Init(string userid , string password);
[DispId(2)]
bool ExecuteSelectCommand(string selCommand);
[DispId(3)]
bool NextRow();
[DispId(4)]
void ExecuteNonSelectCommand(string insCommand);
[DispId(5)]
string GetColumnData(int pos);
}

// 事件接口Database_COMObjectEvents
[Guid("47C976E0-C208-4740-AC42-41212D3C34F0"),
InterfaceType(ComInterfaceType.InterfaceIsIDispatch)]
public interface DBCOM_Events
{
}


[Guid("9E5E5FB2-219D-4ee7-AB27-E4DBED8E123E"),
ClassInterface(ClassInterfaceType.None),
ComSourceInterfaces(typeof(DBCOM_Events))]
public class DBCOM_Class : DBCOM_Interface
{
private SqlConnection myConnection = null ;
SqlDataReader myReader = null ;

public DBCOM_Class()
{
}

public void Init(string userid , string password)
{
try
{
string myConnectString = "user id="+userid+";password="+password+
";Database=NorthWind;Server=SKYWALKER;Connect Timeout=30";
myConnection = new SqlConnection(myConnectString);
myConnection.Open();
MessageBox.Show("CONNECTED");
}
catch(Exception e)
{
MessageBox.Show(e.Message);
}
}

public bool ExecuteSelectCommand(string selCommand)
{
if ( myReader != null )
myReader.Close() ;

SqlCommand myCommand = new SqlCommand(selCommand);
myCommand.Connection = myConnection;
myCommand.ExecuteNonQuery();
myReader = myCommand.ExecuteReader();
return true ;
}

public bool NextRow()
{
if ( ! myReader.Read() )
{
myReader.Close();
return false ;
}
return true ;
}

public string GetColumnData(int pos)
{
Object obj = myReader.GetValue(pos);
if ( obj == null ) return "" ;
return obj.ToString() ;
}

public void ExecuteNonSelectCommand(string insCommand)
{
SqlCommand myCommand = new SqlCommand(insCommand , myConnection);
int retRows = myCommand.ExecuteNonQuery();
}

}
}

在創建COM對象前,我們必須向COM Interop注冊該對象。右擊方案管理器中的工程名字,點擊快捷菜單上的“屬性”選項,然后再點擊“配置”->“創建”,擴展output小節,將Register for COM Interop選項的值設置為true。這樣,一個COM對象就能夠與可管理性應用程序進行交互。

為了使COM對象能夠被外部對象調用,類庫組合必須有一個強名字。創建強名字需要用到SN.EXE名字:
sn -k Database_COM_Key.snk
打開AssemblyInfo.cs,并修改下面一行的內容:
[assembly: AssemblyKeyFile("Database_COM_Key.snk")]

創建對象。創建對象會生成一個可以被導入到可管理性或非可管理性代碼中的類庫。
第二部分:使用Visual C++創建訪問COM對象的客戶端軟件
·使用VC++開發環境創建一個簡單的工程。
·使用#import directive導入類型庫。
·在界面中創建一個Smart Pointer,從接口中執行COM類提供的功能。確保在應用程序加載時添加CoInitialize()調用:
CoInitialize(NULL);

Database_COMObject::DBCOM_InterfacePtr p(__uuidof(Database_COMObject::DBCOM_Class));
db_com_ptr = p ;
db_com_ptr->Init("scott" , "tiger");

下面的代碼對Customers數據庫表執行一個SQLming令,返回給定ID的客戶的信息:
char cmd[1024];
sprintf(cmd , "SELECT COMPANYNAME , CONTACTNAME ,
CONTACTTITLE , ADDRESS FROM CUSTOMERS WHERE CUSTOMERID = '%s'" , m_id );
const char *p ;

bool ret = db_com_ptr->ExecuteSelectCommand(cmd);

if ( ! db_com_ptr->NextRow() ) return ;

_bstr_t mData = db_com_ptr->GetColumnData(3);
p = mData ;
m_address = (CString)p ;

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲综合社区网| 国产精品精品久久久| 国产精品福利在线观看| 国产suv精品一区二区三区88区| 国产精品99久久久久久人| 久久久亚洲影院| 国产精品一区av| 亚洲精品美女免费| 欧美国产极速在线| 久精品免费视频| 亚洲一区二区久久久| 国产亚洲欧美日韩美女| 亚洲香蕉成视频在线观看| 亚洲自拍偷拍色图| 国产成人精品电影| 日韩一区二区欧美| 欧美另类精品xxxx孕妇| 亚洲女性裸体视频| 91在线高清视频| 国产精品白嫩美女在线观看| 久久精品国产亚洲7777| 97在线观看免费| 成人xxxxx| 欧美精品日韩www.p站| 91亚洲国产成人精品性色| 久久综合亚洲社区| 97在线精品视频| 亚洲人成网站色ww在线| 一区二区日韩精品| 久久精品电影一区二区| 久久国产精品影视| 国产精品99蜜臀久久不卡二区| 国产69精品久久久久9999| 成人中文字幕+乱码+中文字幕| 精品一区二区三区四区| 国产精品国产三级国产专播精品人| 成人黄色生活片| 日韩少妇与小伙激情| 欧美亚洲另类制服自拍| 久久久久久久久久久免费| 九九久久久久久久久激情| 中文字幕精品视频| 欧美国产日韩二区| 日韩成人小视频| 欧美国产日本高清在线| 国外成人在线直播| 久久久国产一区二区三区| 亚洲va欧美va国产综合剧情| 精品视频久久久久久久| 欧美一二三视频| 国产精品扒开腿做| 日韩在线观看免费av| 亚洲娇小xxxx欧美娇小| 97色在线观看免费视频| 性亚洲最疯狂xxxx高清| 中文字幕视频一区二区在线有码| 欧美日韩成人精品| 91禁外国网站| 国产精品久久久久久久9999| 欧美在线视频免费观看| 日韩免费视频在线观看| 中文字幕日韩视频| 国产精品久久久久久影视| 欧美黑人xxxx| 欧美性xxxxx极品娇小| 中文字幕亚洲欧美日韩在线不卡| 精品国产一区二区三区久久久| 亚洲第一网站男人都懂| 国产精品美女免费看| 国产成人精品亚洲精品| 久久天天躁狠狠躁夜夜躁2014| 韩国三级电影久久久久久| 亚洲一区二区三区乱码aⅴ蜜桃女| 911国产网站尤物在线观看| 日本成人在线视频网址| 日韩成人小视频| 日韩亚洲成人av在线| 国产在线视频不卡| 亚洲欧美精品suv| 亚洲成人网久久久| 孩xxxx性bbbb欧美| 91系列在线观看| 亚洲精品中文字| 精品亚洲精品福利线在观看| 亚洲国产古装精品网站| xxxxxxxxx欧美| 欧美激情性做爰免费视频| 人人爽久久涩噜噜噜网站| 色偷偷av亚洲男人的天堂| 日韩欧美国产免费播放| 精品中文字幕在线| 日韩av大片免费看| 黄色成人在线播放| 91av在线视频观看| 影音先锋欧美在线资源| 日韩av综合中文字幕| 亚洲xxxxx性| 欧美亚洲另类在线| 亚洲va欧美va国产综合剧情| 17婷婷久久www| 91九色单男在线观看| 成人国产精品久久久久久亚洲| 久久精品国产2020观看福利| 久久国产精品影片| 亚洲欧美激情在线视频| 国产精品专区第二| 成人黄色免费在线观看| 国模gogo一区二区大胆私拍| 欧美猛交ⅹxxx乱大交视频| 欧美日韩亚洲精品一区二区三区| 国产精品日日摸夜夜添夜夜av| 色综合久久天天综线观看| 亚洲第一av网站| 亚洲欧洲午夜一线一品| 日韩精品日韩在线观看| 国产日韩欧美电影在线观看| 亚洲成年人在线播放| 久久久噜久噜久久综合| 91亚洲精品一区二区| 色婷婷**av毛片一区| 亚洲国产精品成人一区二区| 亚洲国内高清视频| 国产视频综合在线| 91麻豆桃色免费看| 欧美精品久久久久久久久久| 日韩av综合网站| 日韩成人中文字幕在线观看| 一本一本久久a久久精品综合小说| 91精品国产91久久久| 国产在线不卡精品| 91精品国产高清自在线| 欧美亚洲成人精品| 亚洲va男人天堂| 亚洲黄色在线看| 久久亚洲国产精品成人av秋霞| 91久久精品国产91久久性色| 久久久国产91| 在线播放国产一区中文字幕剧情欧美| 欧美激情一区二区三区成人| 成人免费网站在线| 亚洲一区二区久久久| 日韩高清人体午夜| 欧美自拍大量在线观看| 国产在线精品一区免费香蕉| 精品电影在线观看| 亚洲国产美女精品久久久久∴| 一区二区三区国产在线观看| 国产精自产拍久久久久久蜜| 久久99精品久久久久久青青91| 日韩美女视频在线观看| 亚洲3p在线观看| 45www国产精品网站| 亚洲一区二区免费在线| 欧美精品xxx| 国产在线高清精品| 国产精品久久视频| 久久久国产在线视频| 日韩在线视频导航| 一本色道久久88综合日韩精品| 国产精品国产自产拍高清av水多| 91av在线视频观看| 亚洲综合中文字幕68页| 亚洲欧美中文日韩v在线观看| 国产午夜精品视频免费不卡69堂|