C#开发ActiveX控件及指纹采集

最近做一个指纹采集和比对的功能,因为公司整个项目是WEB类型的,所以指纹采集的模块要嵌套在网页中,那只有用ActiveX了,以下是一些操作及效果,做个笔记!

新建用户控件,编写CS代码,如下:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Drawing;
using System.Data;
using System.Text;
using System.Runtime.InteropServices;
using System.Windows.Forms;
using System.IO;
using System.Reflection;

namespace FingerTool
{
    [Guid("5136CBA1-59B0-4A96-B2DC-64062A81F377")]
    public partial class FingerToolUC : UserControl,IObjectSafety
    {
        public FingerToolUC()
        {
            InitializeComponent();
        }
        FrmMain fm = null;
        public void ShowSettingForm()
        {
            if (fm == null)
            {
                fm = new FrmMain();
            }

            fm.ShowDialog();
        }

        #region 调用JS接口

        [ComImport, Guid("00000118-0000-0000-C000-000000000046"), InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]
        public interface IOleClientSite
        {
            void SaveObject();

            void GetMoniker(uint dwAssign, uint dwWhichMoniker, object ppmk);

            void GetContainer(out IOleContainer ppContainer);

            void ShowObject();

            void OnShowWindow(bool fShow);

            void RequestNewObjectLayout();

        }

        [ComImport, Guid("0000011B-0000-0000-C000-000000000046"), InterfaceTypeAttribute(ComInterfaceType.InterfaceIsIUnknown)]
        public interface IOleContainer
        {

            void EnumObjects([In, MarshalAs(UnmanagedType.U4)] int grfFlags,

             [Out, MarshalAs(UnmanagedType.LPArray)] object[] ppenum);

            void ParseDisplayName([In, MarshalAs(UnmanagedType.Interface)] object pbc,

             [In, MarshalAs(UnmanagedType.BStr)] string pszDisplayName,

             [Out, MarshalAs(UnmanagedType.LPArray)] int[] pchEaten,

             [Out, MarshalAs(UnmanagedType.LPArray)] object[] ppmkOut);

            void LockContainer([In, MarshalAs(UnmanagedType.I4)] int fLock);

        }

        #endregion

        #region IE 安全接口
        private const string _IID_IDispatch = "{00020400-0000-0000-C000-000000000046}";
        private const string _IID_IDispatchEx = "{a6ef9860-c720-11d0-9337-00a0c90dcaa9}";
        private const string _IID_IPersistStorage = "{0000010A-0000-0000-C000-000000000046}";
        private const string _IID_IPersistStream = "{00000109-0000-0000-C000-000000000046}";
        private const string _IID_IPersistPropertyBag = "{37D84F60-42CB-11CE-8135-00AA004BB851}";

        private const int INTERFACESAFE_FOR_UNTRUSTED_CALLER = 0x00000001;
        private const int INTERFACESAFE_FOR_UNTRUSTED_DATA = 0x00000002;
        private const int S_OK = 0;
        private const int E_FAIL = unchecked((int)0x80004005);
        private const int E_NOINTERFACE = unchecked((int)0x80004002);

        private bool _fSafeForScripting = true;
        private bool _fSafeForInitializing = true;
        public int GetInterfaceSafetyOptions(ref Guid riid, ref int pdwSupportedOptions, ref int pdwEnabledOptions)
        {
            int Rslt = E_FAIL;
            string strGUID = riid.ToString("B");
            pdwSupportedOptions = INTERFACESAFE_FOR_UNTRUSTED_CALLER | INTERFACESAFE_FOR_UNTRUSTED_DATA;
            switch (strGUID)
            {
                case _IID_IDispatch:
                case _IID_IDispatchEx:
                    Rslt = S_OK;
                    pdwEnabledOptions = 0;
                    if (_fSafeForScripting == true)
                        pdwEnabledOptions = INTERFACESAFE_FOR_UNTRUSTED_CALLER;
                    break;
                case _IID_IPersistStorage:
                case _IID_IPersistStream:
                case _IID_IPersistPropertyBag:
                    Rslt = S_OK;
                    pdwEnabledOptions = 0;
                    if (_fSafeForInitializing == true)
                        pdwEnabledOptions = INTERFACESAFE_FOR_UNTRUSTED_DATA;
                    break;
                default:
                    Rslt = E_NOINTERFACE;
                    break;
            }

            return Rslt;
        }

指纹采集关键代码:

private void axZKFPEngX1_OnImageReceived(object sender, AxZKFPEngXControl.IZKFPEngXEvents_OnImageReceivedEvent e)
        {
            if (!e.aImageValid) return;
            if (axZKFPEngX1.IsDisposed) return;
            try
            {
                if (pictureBox1.Image != null)
                {
                    pictureBox1.Image.Dispose();//释放文件资源
                    pictureBox1.Image = null;//清除图片
                }
                if (!System.IO.Directory.Exists(mvPath))
                {
                    System.IO.Directory.CreateDirectory(mvPath);
                }

                string FilePath = mvPath + "\\" + Guid.NewGuid().ToString() + ".bmp";

                axZKFPEngX1.SaveBitmap(FilePath);//保存新文件
                pictureBox1.Image = System.Drawing.Bitmap.FromFile(FilePath);//显示图片
                pictureBox1.Refresh();

                if (this.txtValue.Text.Trim() != "")
                {
                    SetMsg("", "Control");
                }
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }
        }

   private void axZKFPEngX1_OnFeatureInfo(object sender, AxZKFPEngXControl.IZKFPEngXEvents_OnFeatureInfoEvent e)
        {
            string sTemp = "";
            if (axZKFPEngX1.IsRegister)
            {
                sTemp = "登记状态:还需要按压:" + (axZKFPEngX1.EnrollIndex - 1).ToString() + "次指纹 ";
            }

            sTemp = sTemp + "指纹质量";

            if (e.aQuality != 0)
            {
                if (e.aQuality == 1)
                {
                    sTemp = sTemp + "特征点不够";
                }
                else
                {
                    sTemp = sTemp + "其它原因导致不能取到指纹特征";
                }
            }
            else
            {
                sTemp = sTemp + "合格";

            }
            this.lblMessage.Text = sTemp;
        }

指纹校验部分,最后保存起来的指纹是转换之后的BASE64字符串

string Value_Old="";//已经登记的指纹
string Value_Curr="";//当前的指纹

 bool IsOK = false;
            bool bRegChange = false;

            if (axZKFPEngX1.VerFingerFromStr(ref Value_Old, Value_Curr, false, ref bRegChange))
            {
                IsOK = true;
            }
            if (axZKFPEngX1.VerFingerFromStr(ref Value_Old2, Value_Curr, false, ref bRegChange))
            {
                IsOK = true;
            }

            if (IsOK)
            {
                MessageBox.Show("OK");
            }
            else
            {
                MessageBox.Show("NG");

            }

 

设置项目的COM属性

在页面中注册此插件

采集指纹的次数可以自定义,默认为采集三次之后保存,设备是中控的采集器。

 

时间: 2024-11-09 01:01:57

C#开发ActiveX控件及指纹采集的相关文章

C#开发ActiveX控件操作指南

C#开发ActiveX控件在开发Web页面中是十分有用的,下面提供了C#开发ActiveX控件操作指南,供大家学习参考. 0. 前言 ActiveX控件以前也叫做OLE控件或OCX控件,它是一些软件组件或对象,可以将其插入到WEB网页或其它应用程序中.使用ActiveX插件,可以轻松方便的在 Web页中插入多媒体效果.交互式对象以及复杂程序等等. 通常使用C++或VB开发ActiveX控件,本文探讨一下在Visual Studio 2005环境中使用C#开发ActiveX控件的技术实现. 1.

activex-C#开发ActiveX控件调用dll文件时,dll文件放在什么位置,我的出错了

问题描述 C#开发ActiveX控件调用dll文件时,dll文件放在什么位置,我的出错了 通过c#谢了一个很简单的Activex控件,调用dll文件(dll文件是c++写的,并且dll文件不是com组件),在普通的容器中调用动态库都没问题,但是通过activex时就会出错,请问这是问什么,请留言,也可以加我qq:574225218 解决方案 在dll文件中调用VBA的命令 解决方案二: 是在IE中测试出错么?尝试把浏览器的安全等级设置全部调到最低,在客户端安装.net framework并且运行

activex-C#开发ActiveX控件调用动态库DLL

问题描述 C#开发ActiveX控件调用动态库DLL 我想开发一个C# ActiveX控件调用动态库DLL,能够在网页中使用,创建ActiveX控件我已经完成了,但调用DLL动态库没有相应的反馈给我,就像没有做任何操作一样,网上说把动态库DLL放到windows/System32下面,可以调用成功,但我照做了,还是没有反应,我的系统是WIN732位,动态库DLL在C/S程序下调用是没有问题,希望高人帮忙解答下,如果对问题有什么不明白之处,可以留言,谢谢 解决方案 ActiveX控件需要注册(命令

ctivex-MFC中开发ActiveX控件问题

问题描述 MFC中开发ActiveX控件问题 在VS2010中使用VC++的MFC建立ActiveX控件时,控件默认在整个控件区域画了一个椭圆.问:如何改变控件的大小,即使控件有一个自定义的默认大小?求教... 解决方案 MoveWindow等来控制控件大小. 解决方案二: 你可以定义一个属性表示椭圆所在的区域的大小.构造函数给它们默认值画图的代码据此绘出椭圆. 解决方案三: 这个,改变初始值就可以了啊 解决方案四: onwindowsize消息里面做点手脚. 解决方案五: 大小一般是在创建控件

使用VS2010 C#开发ActiveX控件(上)_C#教程

 要开发Web版的读卡程序,大体思路如下: 1.       使用C#对原始的Dll进行封装,这里要封装两部分内容,一部分是串口通信的功能,一部分是对卡读写的功能. 2.       开发ActiveX控件调用封装后的Dll,使用串口通信来对卡进行读写. 3.       打包并发布ActiveX控件. 4.  使用ActiveX控件. 思路1中封装代码有2个类SerialInterfaceHelper,串口通信的帮助类,MifareOneHelper,M1卡的读写帮助类,我们放在了项目Card

使用VS2010 C#开发ActiveX控件(下),完整代码打包下载_C#教程

其实如果我们不进行设置,只是修改了代码,运行程序以后,其出错界面如下图1所示: 开发ActiveX控件(下),完整代码打包下载_C#教程-vs2010使用教程 c"> 图1 抛出异常如下: ************** Exception Text ************** System.MethodAccessException: Attempt by security transparent method 'Rare.Card.Libary.Controls. ReadCardCo

使用VS2010 C#开发ActiveX控件

最近做读卡器的B/S应用程序开发,由于读卡器厂商提供的手册都是C/S版本的,而且只有一个原始的Dll包,并没有web版的,那么就只好自己动手,丰衣足食了 要开发Web版的读卡程序,大体思路如下: 1. 使用C#对原始的Dll进行封装,这里要封装两部分内容,一部分是串口通信的功能,一部分是对卡读写的功能. 2. 开发ActiveX控件调用封装后的Dll,使用串口通信来对卡进行读写. 3. 打包并发布ActiveX控件. 4. 使用ActiveX控件. 思路1中封装代码有2个类SerialInter

C#开发ActiveX控件问题求助,200分奉上!

问题描述 这个地址有介绍用C#开发ActiveX控件的例子http://archive.cnblogs.com/a/2180781/具体如下图,我按照这个方法做的,怎么在网页里显示不出它的内容呢?有没有人给指点一下,一旦解决,另外开贴附送100分. 解决方案 解决方案二:在DLL的工程属性中要公开COM解决方案三:引用1楼dylike的回复: 在DLL的工程属性中要公开COM 这个已经设置过了解决方案四:有没有高手给指点指点解决方案五:贴出你的代码看看啊,你是不是没有生成新的GUID呢?以前写过

使用MFC开发ActiveX控件

摘要: 本文对COM组件中的ActiveX控件的MFC开发方法进行了介绍,讲述了用户自定义和库存属性.方法以及事件的添加方法和属性页的制作过程.使读者能够掌握基本的MFC ActiveX开发方法. 前言 ActiveX控件是一种实现了一系列特定接口而使其在使用和外观上更象一个控件的COM组件.ActiveX控件这种技术涉及到了几乎所有的COM和OLE的技术精华,如可链接对象.统一数据传输.OLE文档.属性页.永久存储以及OLE自动化等. ActiveX控件作为基本的界面单元,必须拥有自己的属性和