Python 64-битная DLL COM-сервер проблемы с регистрацией в 64-битной Windows 7 - PullRequest
1 голос
/ 06 января 2011

Я пытаюсь создать простой COM-сервер с использованием Python 2.7 в 64-битной Windows 7, но не могу успешно зарегистрировать DLL. Я могу сделать это успешно, используя Python 2.6 на 32-битной Windows XP. Я также могу зарегистрировать свой класс прямо из Python.

Это мой модуль heikki.py, основанный на руководстве pywin32 COM :

class Heikki:
  _reg_clsid_ = '{F4C7D945-BF6B-4BF8-BCBB-EA021FCCE623}'
  _reg_desc_ = "Heikki"
  _reg_progid_ = "Heikki.TestServer"
  _public_methods_ = ['Hello']

  def __init__(self):
      pass

  def Hello(self):
      return 1

if __name__=='__main__':
    from win32com.server import register
    register.UseCommandLine(Heikki)

Я могу успешно зарегистрировать его из командной строки следующим образом (у меня 64-битный Python 2.7.1, pywin32 214, py2exe 0.6.9, c: \ python27 в PATH):

C:\temp> python heikki.py
Registered : Heikki.TestServer

C:\temp> python heikki.py --unregister
Unregistered : Heikki.TestServer

Затем я создал файл setup.py на основе образца py2exe COM-сервера в каталоге c: \ temp:

from distutils.core import setup
import py2exe

class Target:
    def __init__(self, **kw):
        self.__dict__.update(kw)
        # for the version info resources (Properties -- Version)
        self.version = "1.0"
        self.company_name = "My name"
        self.copyright = "(C) 2011, My company"
        self.name = "heikki"

heikki_target = Target(
    description = "my com server desc",
    # use module name for win32com exe/dll server
    modules = ["heikki"],
    # specify which type of com server you want (exe and/or dll)
    create_exe = False,
    create_dll = True
    )

setup(
    version = "1.0",
    zipfile=None,
    description = "my com server",
    name = "heikki",
    author="Heikki",
    com_server = [heikki_target],
    )

Затем я создаю DLL:

c:\temp> python setup.py py2exe

Однако это вызвало сообщение об ошибке:

The following modules appear to be missing
['win32com.gen_py', 'win32com.shell', 'win32com.shell.shell']

Что я частично исправил, добавив в скрипт установки следующее:

import sys

if 1:
 try:
    import py2exe.mf as modulefinder
 except ImportError:
    import modulefinder
 import win32com
 for p in win32com.__path__[1:]:
     modulefinder.AddPackagePath("win32com", p)
 for extra in ["win32com.shell"]:
    __import__(extra)
    m = sys.modules[extra]
    for p in m.__path__[1:]:
        modulefinder.AddPackagePath(extra, p)

но я все равно получаю:

The following modules appear to be missing
['win32com.gen_py']

Я читал, что в некоторых случаях эту ошибку можно игнорировать, поэтому я нажал на. На данный момент мой dist dir выглядит так:

07/13/2009  05:24 PM             3,072 API-MS-Win-Core-ErrorHandling-L1-1-0.dll
07/13/2009  05:24 PM             3,584 API-MS-Win-Core-LibraryLoader-L1-1-0.dll
07/13/2009  05:24 PM             4,096 API-MS-Win-Core-LocalRegistry-L1-1-0.dll
07/13/2009  05:24 PM             3,584 API-MS-Win-Core-Misc-L1-1-0.dll
07/13/2009  05:24 PM             4,608 API-MS-Win-Core-ProcessThreads-L1-1-0.dll
07/13/2009  05:24 PM             3,072 API-MS-Win-Core-Profile-L1-1-0.dll
07/13/2009  05:24 PM             4,096 API-MS-Win-Core-Synch-L1-1-0.dll
07/13/2009  05:24 PM             4,096 API-MS-Win-Core-SysInfo-L1-1-0.dll
07/13/2009  05:24 PM             6,144 API-MS-Win-Security-Base-L1-1-0.dll
11/27/2010  05:19 PM            80,384 bz2.pyd
07/13/2009  05:40 PM           207,360 CFGMGR32.dll
07/13/2009  05:40 PM            93,184 DEVOBJ.dll
01/06/2011  12:07 PM         2,363,665 heikki.dll
07/13/2009  05:41 PM           421,376 KERNELBASE.dll
11/06/2007  03:02 PM         1,671,160 mfc90.dll
07/13/2009  05:41 PM           167,424 POWRPROF.dll
11/27/2010  05:19 PM         2,978,816 python27.dll
07/05/2009  04:56 AM           489,984 pythoncom27.dll
07/05/2009  04:54 AM           138,240 pywintypes27.dll
11/27/2010  05:19 PM            10,752 select.pyd
07/13/2009  05:41 PM         1,899,520 SETUPAPI.dll
11/27/2010  05:19 PM           689,664 unicodedata.pyd
07/05/2009  04:55 AM           125,440 win32api.pyd
07/05/2009  04:58 AM           354,816 win32com.shell.shell.pyd
07/05/2009  04:54 AM            21,504 win32event.pyd
07/05/2009  04:54 AM            44,032 win32process.pyd
07/05/2009  04:54 AM            18,432 win32trace.pyd
07/05/2009  05:00 AM         1,034,752 win32ui.pyd
07/05/2009  04:55 AM           236,544 winxpgui.pyd
11/27/2010  05:22 PM           471,552 _hashlib.pyd
07/05/2009  04:54 AM             9,216 _win32sysloader.pyd

Поэтому я пытаюсь зарегистрировать DLL:

c:\temp\dist> regsvr32 heikki.dll

но появляется диалоговое окно, которое говорит:

The module "heikki.dll" was loaded but the call to
DllRegisterServer failed with error code 0x80040201

Согласно MS KB :

There was an error when regsvr32.exe invoked the entrypoint in the module specified in the command line.

Затем я перехожу к Ходок за зависимостями , который дает мне два предупреждения для heikki.dll:

IEFRAME.DLL
SHLWAPI.DLL

Последний, на который я могу дважды щелкнуть, чтобы получить больше информации, первый говорит:

Error: At least one module has an unresolved import due to a missing export function in an implicitly dependent module.

Затем я использовал Dependency Walker на regsrv32; просто открытие regsvr32 дало предупреждения для тех же файлов. Профилирование heikki.dll дало ошибки для:

<empty string>
ZLIB.PYD

При некоторых попытках я также получил ошибку для ieshims.dll, но я добавил каталог Internet Explorer в PATH, скопировал DLL в dist и избежал этой ошибки. Обходчик зависимости говорит это о <пустой строке> error :

which means GetProcAddress was called with an empty string

Я бы также надеялся, что ошибка zlib.pyd безвредна, потому что больше не нужно zlib.pyd, учитывая, что он должен быть встроен в AFAIK. Я попытался сбросить zlib1.dll как zlib.pyd в моем дистрибутивном каталоге, но хотя это избавляет от ошибки импорта DDL, есть другая ошибка, связанная с тем, что у pyd-файла нет ожидаемой точки входа (initzlib или что-то еще, забыл).

Мне также не удалось избавиться от предупреждения gen_py от py2exe в моих попытках. Я пробовал различные изменения в файле setup.py, а также в модуле heikki.py, но безуспешно.

На данный момент у меня заканчиваются идеи для изучения.

1 Ответ

2 голосов
/ 07 января 2011

Это похоже на копию сборки сервера Com с использованием Python на 64-битной машине с Windows 7 .

Добавьте «import win32traceutil» в начало heikki.py и запустите C: \ Python27 \ Lib \ site-packages \ win32 \ lib \ win32traceutil.py во втором процессе Python, чтобы увидеть трассировку от heikki.dll: 1005 *

Traceback (most recent call last):
  File "boot_com_servers.py", line 37, in <module>
pywintypes.error: (126, 'GetModuleFileName', 'The specified module could not be found.')
Traceback (most recent call last):
  File "<string>", line 1, in <module>
NameError: name 'DllRegisterServer' is not defined

Обновление:

В py2exe есть ошибка на 64-битном Python. Файл sys.frozendllhandle, инициализированный py2exe, недопустим, так что win32api.GetModuleFileName (sys.frozendllhandle) завершается ошибкой.

Возможно, вы захотите попробовать исправленные установщики py2exe на http://www.lfd.uci.edu/~gohlke/pythonlibs/#py2exe

...