Web アプリケーションの急速な開発により、Node.js は開発者にとって推奨されるテクノロジ フレームワークの 1 つになりました。これらのアプリケーションでは、フロントエンド ユーザー インターフェイスを使用する一方で、バックエンドはファイルの読み取り、データベース アクセス、ネットワーク リクエストなどの一部の機能を実行するためのサービスも提供する必要があります。優れた開発者にとって、Node.js は、モジュール式で保守可能な方法でリリースされるカスタム サービスを作成するための良い選択肢となっています。ただし、開発中に、Node.js が他のプログラミング言語と対話する必要があるシナリオがあります。この記事では、Node.js を使用して COM コンポーネントを実装する方法について説明します。
COM (コンポーネント オブジェクト モデル) コンポーネントは、Windows オペレーティング システムを使用するユニバーサル バイナリ インターフェイスであり、これにより、さまざまなプログラミング言語が他のアプリケーションやオブジェクトと対話して統合を向上させることができます。 Windows オペレーティング システムでは、アプリケーションとオブジェクトは、COM コンポーネントを使用したネイティブ コードを通じて相互に通信できます。簡単な例としては、Microsoft Word オブジェクトを使用してドキュメントを自動的に印刷したり、Microsoft Excel オブジェクトを使用してデータをスプレッドシートに自動的に追加したりするなどが挙げられます。
Node.js 自体はスタンドアロンの無料ソフトウェアですが、エコシステムには Windows 関連の実装に使用できるサードパーティ ライブラリが多数あります。タスク 。 Node.js の COM オブジェクトは通常、ActiveXObject クラスを使用してインスタンス化されます。 ActiveXObject は、JavaScript での COM オブジェクトの自動化を可能にするオブジェクトです。
Node.js を使用して COM コンポーネントを実装する前に、まず Node.js をインストールする必要があります。 Node.js 公式 Web サイトにアクセスし、ダウンロードしてプロンプトに従います。
COM コンポーネントの使用を開始する前に、COM オブジェクトをインストールし、Windows レジストリに追加する必要があります。 ADO (ActiveX Data Objects) や CDONTS (.NET で使用可能) などの多くのオブジェクトは、Microsoft の Web サイトからダウンロードしてインストールできます。
Microsoft Excel を例に挙げると、まず Microsoft 公式 Web サイトにアクセスして Excel コンポーネントをダウンロードし、Microsoft Office にインストールする必要があります。インストールが完了したら、Excel コンポーネントを Windows レジストリに追加します。
ActiveXObject クラスを使用すると、Node.js コードから COM コンポーネントを簡単に呼び出すことができます。 JavaScript コードでは、new 演算子を使用して ActiveXObject クラスをインスタンス化し、呼び出す必要がある COM コンポーネントの名前とそのバージョン番号を渡します。
次に、一般的に使用される COM コンポーネントとそれらが属するアプリケーションの例を示します。
'Microsoft Excel var excel = new ActiveXObject('Excel.Application'); 'Microsoft Word var word = new ActiveXObject('Word.Application'); 'Microsoft Access var access = new ActiveXObject('Access.Application'); 'Microsoft PowerPoint var powerpoint = new ActiveXObject('PowerPoint.Application'); 'Microsoft Internet Explorer 和 Windows Media Player等其他应用程序 var ie = new ActiveXObject('InternetExplorer.Application'); var wmp = new ActiveXObject('WMPlayer.OCX');
ActiveXObject をインスタンス化した後、COM コンポーネントが提供するメソッドとプロパティを使用できます。 Excel からワークシート データを読み取る例を次に示します。
var excel = new ActiveXObject('Excel.Application'); excel.Workbooks.Open('D:\test.xlsx'); var sheet = excel.Worksheets(1); // 读取第一行第二列的单元格数据 var data = sheet.Cells(1, 2).Value; console.log('读取到的数据:' + data); excel.Quit();
多くの COM コンポーネントは、ファイル システムへのアクセスを提供します。 Node.js では通常、ファイルやディレクトリを扱うために fs (ファイル システム モジュール) を使用します。ただし、一部の操作では Windows オペレーティング システム固有の方法を使用する必要がある場合があります。この場合、ファイル操作に COM コンポーネントを使用すると便利です。
次に、一般的なファイル操作とその操作で使用される COM コンポーネントを示します。
ファイル プロパティとメタデータへのアクセスに使用される COM コンポーネントは、標準 Windows スクリプトです。ホスト (WSH) オブジェクト。この COM コンポーネントには、ファイルおよびディレクトリのプロパティにアクセスするための多数のメソッドとプロパティを公開する FileSystemObject と呼ばれるオブジェクトが含まれています。
ここでは、WScript.Shell オブジェクト (システムと対話するためのメソッドが含まれています) を使用してファイルを読み取る例をいくつか示します。
var wsh = new ActiveXObject('WScript.Shell'); var fso = new ActiveXObject('Scripting.FileSystemObject'); // 获取文件大小 var size = fso.GetFile('D:\test.docx').Size; // 获取文件路径 var path = wsh.ExpandEnvironmentStrings('%USERPROFILE%') + '\Desktop'; // 获取计算机上的所有驱动器 var drives = fso.Drives; for (var e = new Enumerator(drives); !e.atEnd(); e.moveNext()) { console.log(e.item().DriveLetter); }
データベース COM コンポーネントは ADO と ODBC です。 ADO (ActiveX Data Objects) は、さまざまなデータ ソースに接続するために Microsoft によって開発されたオブジェクト モデルです。 ODBC (Open Database Connectivity) も、異なるデータベース システムを接続するために使用される API です。
データベースからデータを取得する例をいくつか示します:
var connection = new ActiveXObject('ADODB.Connection'); connection.Open('Provider=SQLOLEDB.1;Server=myServerAddress;Database=myDataBase;Uid=myUsername;Pwd=myPassword;'); var recordset = new ActiveXObject('ADODB.Recordset'); recordset.Open('SELECT * FROM Customers', connection); while (!recordset.EOF) { console.log('读取到的数据:' + recordset.Fields(1).Value); recordset.MoveNext(); } recordset.Close(); connection.Close();
COM コンポーネントを使用すると、Node の Windows 環境でサポートされている多くの言語を使用できるようになります。 js 関数だけでなく、エコシステム内で新しいサードパーティのライブラリやコンポーネントを見つけることもできます。この記事では、Node.js プログラムでの COM コンポーネントの実装の基本を紹介します。これが役に立ち、このテクニックを試してより多くの可能性を探求する励みになることを願っています。
以上がNodejs は com コンポーネントを実装しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。