国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁(yè) > 編程 > C# > 正文

使用C#創(chuàng)建COM對(duì)象

2023-05-18 12:33:10
字體:
供稿:網(wǎng)友

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

 為了簡(jiǎn)單和方便開發(fā)人員使用、測(cè)試起見,我們使用了SQLSERVER數(shù)據(jù)庫(kù)軟件的缺省安裝中的Northwind數(shù)據(jù)庫(kù)。

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

 ·我們已經(jīng)創(chuàng)建了連接數(shù)據(jù)庫(kù)用的分別為scott、tiger的用戶名和口令,我們可以使用它或者其他現(xiàn)有的用戶名和口令。

 第一部分:用C#創(chuàng)建簡(jiǎn)單的COM對(duì)象

 COM對(duì)象是ClassLibrary類,它生成DLL文件。要在VS開發(fā)環(huán)境中創(chuàng)建一個(gè)簡(jiǎn)單的COM對(duì)象,我們可以依次選擇“文件”->“新創(chuàng)建”->“工程”->“VisualC#工程”->“類庫(kù)”,然后創(chuàng)建一個(gè)名字為Database_COMObject的工程。

需要注意的是:在COM中調(diào)用VC#對(duì)象需要下面的條件:

 ·類必須是public性質(zhì)。

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

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

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

 不是在這些接口中定義的public性質(zhì)的類成員不能被COM訪問,但它們可以被其他的.NET Framework對(duì)象訪問。要讓COM能夠訪問特性和方法,我們必須在類接口中定義它們,使它們具有DispId屬性,并在類中實(shí)現(xiàn)這些特性和方法。這些成員定義時(shí)的順序也就是它們?cè)贑OM中順序。要讓COM訪問類中的事件,必須在事件接口中定義這些事件,并賦予它們DispId屬性。事件接口不應(yīng)當(dāng)由類完成,類只實(shí)現(xiàn)類接口(它可以實(shí)現(xiàn)不止一個(gè)接口,但第一個(gè)接口是缺省接口),應(yīng)當(dāng)在缺省接口中實(shí)現(xiàn)需要讓COM訪問的方法和特性,方法和特性必須被標(biāo)識(shí)為public性質(zhì),并符合在類接口中的定義。需要讓COM訪問的事件也在缺省的類接口中完成,它們也必須被標(biāo)識(shí)為public性質(zhì),并符合事件接口中的定義。

 在接口名字之前,每個(gè)接口需要一個(gè)GUID特性。要生成變個(gè)唯一的Guid,需要運(yùn)行g(shù)uidgen.exe工具軟件,并選擇“注冊(cè)表格式”

下面是一個(gè)類界面:

[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
{
}

下面是實(shí)際的類定義:

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

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

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

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

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

下面是COM對(duì)象完整的源代碼:

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();
}

}
}

在創(chuàng)建COM對(duì)象前,我們必須向COM Interop注冊(cè)該對(duì)象。右擊方案管理器中的工程名字,點(diǎn)擊快捷菜單上的“屬性”選項(xiàng),然后再點(diǎn)擊“配置”->“創(chuàng)建”,擴(kuò)展output小節(jié),將Register for COM Interop選項(xiàng)的值設(shè)置為true。這樣,一個(gè)COM對(duì)象就能夠與可管理性應(yīng)用程序進(jìn)行交互。

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

創(chuàng)建對(duì)象。創(chuàng)建對(duì)象會(huì)生成一個(gè)可以被導(dǎo)入到可管理性或非可管理性代碼中的類庫(kù)。
第二部分:使用Visual C++創(chuàng)建訪問COM對(duì)象的客戶端軟件
·使用VC++開發(fā)環(huán)境創(chuàng)建一個(gè)簡(jiǎn)單的工程。
·使用#import directive導(dǎo)入類型庫(kù)。
·在界面中創(chuàng)建一個(gè)Smart Pointer,從接口中執(zhí)行COM類提供的功能。確保在應(yīng)用程序加載時(shí)添加CoInitialize()調(diào)用:
CoInitialize(NULL);

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

下面的代碼對(duì)Customers數(shù)據(jù)庫(kù)表執(zhí)行一個(gè)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 ;

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
在线观看国产视频| 在线观看中文字幕的网站| 国产精品一区在线看| 中文av字幕| 在线āv视频| 精品资源在线看| 午夜av在线免费观看| 国产日本视频| 亚洲视频在线网| 黄色片免费在线| 国产导航在线| 国产中文在线视频| 国产粉嫩一区二区三区在线观看| 伊人网在线视频| 丁香花在线电影小说观看 | 色综合久久五月天| 免费午夜一级| 国产精品欧美韩国日本久久| 精品176二区| 国产精品一二三区视频| 精品亚洲综合| 日本中文字幕视频| 伊人精品影院| 99热在线观看免费| 日韩黄色成人| 9999在线视频| 中文字幕视频在线免费| 亚洲妇熟xxxx妇色黄| 国产激情在线视频| 欧美性受xxxx免费视频| 国产盗摄一区二区| 国产一级免费黄色片| 久久精品无码一区二区日韩av| 精精国产xxxx视频在线动漫| 国产欧美日韩专区| 国产三级在线看| 丁香婷婷激情| 九九99精品| 久蕉依人在线视频| sese在线视频| 亚洲男人的天堂成人| 国产成人天天5g影院| 国产偷窥老熟盗摄视频| 国内自拍视频在线看免费观看| 国产午夜在线观看| 成人午夜无人区一区二区| 日本黄在线观看| eeuss影院网站免费观看| 99在线免费观看| 精品国产高清自在线一区二区三区| 成人免费一区二区三区视频网站| 啪啪免费视频一区| 激情综合丁香| 中文字幕av中文字幕| 国产美女av在线| 中文字幕在线视频观看| 国产精选在线观看| 国产一二区在线观看| 国产视频青青| 国产香蕉免费精品视频| 国产日本在线| 伊人影院在线视频| 欧美色欧美亚洲另类二区精品| 欧美婷婷久久五月精品三区| 国产裸舞福利在线视频合集| 尤物在线视频| 2021av天天| 国产中文字幕在线| 丁香六月婷婷| 在线观看中文字幕| 国产伦精品一区二区三区高清版禁| 国产美女av在线| 国产成人天天5g影院| eeuss影院在线观看| 欧美另类在线视频| 最新天堂资源在线| www网站在线观看| 国产精品一二三区视频| 在线一区二区三区精品| 国产永久免费| 四虎久久影院| 国产黄色片大全| 国产在线观看a| 91社区在线观看| 国产美女视频一区二区二三区| 精品国产免费观看一区| 2018av男人天堂| 女同一区二区免费aⅴ| 精品女厕厕露p撒尿| 欧美色欧美亚洲另类二区精品| 国产高清在线观看| 中文字幕在线视频不卡| 九色在线网站| 天天插天天射| av在线天堂| 樱花草在线观看www| 在线视频观看亚洲| 国产日韩网站| 国产精品久久久高清免费| 高清视频一区二区三区四区| 四虎网站在线观看| 日本片在线看| 欧美性xxxx交| 国产美女福利在线观看| 精品资源在线看| 黄网在线免费| 国产一区二区影视| 国产精品麻豆一区二区三区| 国产激情视频在线| 精品国产一区二区三区不卡在线| 国产激情视频网址| √8天堂资源地址中文在线| 国产黄a三级三级三级av在线看| 国产在线高潮| 国产一卡2卡3卡四卡网站| 国产黄色大片在线观看| 伊人免费在线| 久久99精品久久久久久野外| 国产美女在线看| 国产激情小视频在线| 国产叼嘿网站免费观看不用充会员| 国产天堂素人系列在线视频| 国产精品第八页| 精品国产99久久久久久| wwwww在线观看免费视频| 高清欧美精品xxxxx在线看 | 国产在线观看a视频| 国产乱xxⅹxx国语对白| 国产黄视频在线观看| 精品99又大又爽又硬少妇毛片 | 精品美女调教视频| 国产第一页在线| 美女网站在线观看| 2018中文字幕在线| 黄色在线视频观看网站| 91资源在线观看| 国内精品一区视频| av色在线观看| 国产一级黄色片免费| 日本动漫理论片在线观看网站| 国产美女在线看| 尤物视频在线观看视频| 88av在线| 国产男女猛烈无遮挡免费视频| 国产成人亚洲欧美电影| 国产卡1卡2卡三卡在线| 国产人成网在线播放va免费| 男女羞羞视频在线观看| 在线观看国产视频| 精品伦理一区二区| 国产午夜视频在线观看| 美女免费视频黄| xxxxx中文字幕| 亚洲尤物在线视频| 国产第一页在线| 国产区高清在线| 大香伊人中文字幕精品| 久久久久久久久免费视频| jlzzjlzz欧美大全| 波多野结衣中文字幕久久| 在线欧美一级视频| 国产情侣高潮对白| 18激情网站| 在线三级中文| sm国产在线调教视频| 四虎影视成人永久免费观看视频| 精品国产一区二区三区四区阿崩| 国产精品666| 在线三级av| 欧美精品se| 国产专区在线播放| 国产丝袜精品丝袜| 精品推荐蜜桃传媒| 在线黄色国产电影| 欧美韩日国产| 国产小视频在线高清播放| **三级三级97片毛片| 国产三级在线免费观看| 在线中文av| 狠狠插狠狠操| 国产福利在线观看| gogo在线高清视频| 国产免费视频在线| 国产成人精品久久一区二区小说| 在线视频三级| 爱福利在线视频| 中文字幕在线视频不卡| 精品久久九九| 狠狠色丁香婷婷| 国产xxxx做受性欧美88| 四虎成人精品在永久免费| 女子免费在线观看视频www| 国产麻豆视频| 99热免费在线| 国产一卡2卡3卡4卡网站免费| 在线国产91| 国产一级黄色| 免费看黄视频网站| 国产h在线观看| 中文字幕有码在线视频|