|
请大家注意!这种方法只能应用于输出为C格式的__stdcall调用方式!* P2 c0 f/ T$ _ d4 T6 Z3 J: M6 f
# W' S5 e& h- x2 X' E1. 使用VC++的工具DUMPBIN将DLL中的导出函数表导出到一定义(.DEF)文件$ j9 L9 W9 B' V
EXAMPLE:0 g5 W% Z5 _2 f J) ]1 W3 r2 N% Q; y
DUMPBIN VideoDeCoder.dll /EXPROTS /OUT:VideoDeCoder.def
7 _, N' G+ l; f e) r3 l8 k B . ~& P) @+ ^+ v
2. 将导出的.DEF文件整理为一符合.DEF个数的函数导出文件
5 z" b5 T* B1 M7 N EXAMPLE:
x- d: s/ F2 Q6 d f VideoDeCoder.DEF 文件内容如下3 s! I8 L, x' ]& i# Q3 R0 G/ l
5 T( `/ ^) S; B. p+ l
Dump of file VideoDeCoder.dll
) r5 t2 _! F/ l1 V 9 l# L/ A) h. P8 W
File Type: DLL 9 ^; i# Z) y: ]" T
" p: B7 r6 k4 f0 P, d Section contains the following exports for VideoDeCoder.dll u0 r. U+ Q- f2 b) B$ v
, u3 \* b( |4 \* t/ }; N7 w
0 characteristics 6 b0 Y$ `& u+ F; {
3D49E48F time date stamp Fri Aug 02 09:46:55 2002 " r$ m/ `, C+ W- U6 Q* K) g
0.00 version 8 b- a e! B/ g/ P5 X a$ P
1 ordinal base 3 N: u: b m4 `% j( Z
11 number of functions + A1 n, F( k' r. M1 Q( P; F
11 number of names
" ?( R( _/ Q$ ?- B' T 6 ~0 E9 Z* {; b4 ]
ordinal hint RVA name ) R( B* s8 N; t4 C
& H6 _; C! l; T
1 0 00010F60 _TM_ClearDecoderBuff@4
; T, {% {5 L% H- h7 B 2 1 00010E80 _TM_CloseDecoder@4
: ^1 S: {5 X9 H7 u3 C8 i, u/ V2 z 3 2 00010F00 _TM_DecodePicture@4
) F! f" R' t n) p) ^ 4 3 00010ED0 _TM_DecodePictureHeader@4 0 I( Z2 @/ c& v; z. P+ A& E0 [. Y
5 4 00010FD0 _TM_GetFileEnd@4
1 l9 j) F! Q% j; T 6 5 00011030 _TM_GetUValue@4
: V1 Z+ Q9 l2 x 7 6 00011060 _TM_GetVValue@4 6 F1 i+ u$ s2 k* h7 ]; h
8 7 00011000 _TM_GetYValue@4
; ]* L* [4 f: ?6 k2 z" h* z% q6 l 9 8 00010E10 _TM_OpenDecoder@8
5 l! j, P4 d4 \/ N' \ 10 9 00010F30 _TM_ReturnType@4
: S2 t T9 @; A1 ?0 M 11 A 00010F90 _TM_SetFileEnd@8
4 P. G* k0 T& Q* d6 H 8 s' l! I7 L& U! i/ }0 }& T1 ^9 X
Summary 5 m9 \5 U; n: K/ ? h
6 S. I; ^4 y1 K0 D& s- u0 O# [
2000 .data 5 N- `& ^( K+ y) n3 {+ _0 q/ [
1000 .rdata ! H/ Z8 c( C" s1 }* F& c
1000 .reloc * e2 Z! Q% t8 @ \" I; _
15000 .text : C; v4 C& B' `9 P A& V6 r+ p
按照以下方法整理:# z# ]" f( S) k) K
1>添加LIB说明
: q- f' Z6 F& o+ \, S LIBRARY "VideoDeCoder" ;"xx"为DLL名称! O, K' B3 X8 w
DESCRIPTION "VideoDeCoder library" 8 k4 q8 D$ a z" w& U* [
2>去掉导出函数说明端以外的内容,在LIB说明下添加 "EXPROTS" 说明导出函数3 A- P( Q6 n6 ^& m4 s$ y
LIBRARY "VideoDeCoder"
, @5 |) e& p( C DESCRIPTION "VideoDeCoder library"
% _' F, o' ], B$ ?7 A EXPORTS9 @8 W$ D" q; ]6 C* T, n, \
ordinal hint RVA name * d1 j' O- A% \: a x! P
' a& ~) U. b3 R" M
1 0 00010F60 _TM_ClearDecoderBuff@4
# b/ }) Y: R% k! @. ^% Y6 C 2 1 00010E80 _TM_CloseDecoder@4 0 v3 g. X3 E6 J3 `' _9 X4 z* k* D/ T6 j
3 2 00010F00 _TM_DecodePicture@ ; N; Y8 C* `+ h+ s; _0 y( q' |$ X! D
4 3 00010ED0 _TM_DecodePictureH
) W( y2 l# o$ `8 a, E 5 4 00010FD0 _TM_GetFileEnd@4 5 j* g+ o$ O" l
6 5 00011030 _TM_GetUValue@4
6 Y5 Y* ]& e# f8 j' z; p 7 6 00011060 _TM_GetVValue@4 6 H$ t2 I% D$ W
8 7 00011000 _TM_GetYValue@4
# a4 J& Q% S2 P" s 9 8 00010E10 _TM_OpenDecoder@8 ( w$ @, n( r& N" U- Z- [, N
10 9 00010F30 _TM_ReturnType@4 8 ` z0 {; _7 O
11 A 00010F90 _TM_SetFileEnd@8 / N+ _" z5 Q- G1 I0 Q. C( e8 {
3>将所有的函数放至行首,去掉 "hint" 和 "RVA" 数据,留下函数的序号 "ordinal" ,在序号前加上 "@" 符号
9 ^5 P# ~! e. j( H# t9 ^& _ 形成 "_导出函数名@参数字节和 @序号" 此种格式(__stdcall 方式调用导出的函数符号是 "函数名称@参数字节和").
# k, y. v5 S+ B; Q9 i0 L" ` 最后形成.DEF文件如下:
$ G4 c5 r/ N+ H O4 B8 f# g LIBRARY "VideoDeCoder"
+ R: a( D3 T( ^& h6 s# T( K/ P DESCRIPTION "VideoDeCoder library"' I% w6 ?$ x1 ?+ X/ K7 S
EXPORTS
4 u9 F) G8 B" j, F' E/ S
& ?; ~# u ?% D9 n TM_ClearDecoderBuff@4 @1
1 r6 P7 O0 S6 g! }& S TM_CloseDecoder@4 @2
8 H5 U) M; r0 E) J. V. e TM_DecodePicture@4 @3
& E$ ^" v" X( o0 Q, k! n TM_DecodePictureHeader@4 @4
7 R, ~" Q! a7 j1 }- p TM_GetFileEnd@4 @5
* I& R9 K% m; G. @5 p TM_GetUValue@4 @6 ; ]# C- ?/ |! \5 W6 w }5 r
TM_GetVValue@4 @7
" d3 M5 b I6 O, q: N TM_GetYValue@4 @8 2 f: w. V2 W" x8 {
TM_OpenDecoder@8 @9
1 t- |! `6 k" _ TM_ReturnType@4 @10
. F% B8 t% c Q5 h+ D1 ` TM_SetFileEnd@8 @11
- A" D& y/ m7 z2 t K* R2 h; o0 F! Q3. 使用VC++的LIB工具,带/DEF:(.def文件名) /MACHINE:IX86(80X86机器),就输出符合VC++格式的的LIB文件了.
/ E* {' \' o9 M) ]9 D' N EXAMPLE:1 r. H d. o" d5 C6 Z" d
LIB /DEF:VideoDeCoder.def /MACHINE:IX86
9 o( h4 l6 L0 g1 p9 Y4. 接时带上LIB文件链接;注意的是当有些动态库DUMPBIN的只有函数名,无"@nn"的参数格式,如C++Builder写的DLL,输出就只有函数名符号,链接时就会报错:
! u& C' X i! ^; W' p6 ?6 t error LNK2002:unresolved external symbol "functionname@nn"1 F0 W; E/ i0 F3 B; {- l
提示程序中引入的函数符号无法识别,这时只要将DEF文件中相应的函数名称改为functionname@nn方式,重新建立
; b' ]* x0 R9 o7 N; }) a) C' lLIB,重新链接即可.
* A8 w u6 Q8 a5 u8 j& Q# J* A) W) k, x9 ?7 J1 C7 q/ q
这样就制作成功了符合VC调用方式的LIB了!
4 n# }/ [" z! q9 q2 c参考:MSDN2000+ h/ L& b. Y- i ]" X
要值得一说的是!BORLAND C++BUILDER有一个很好的工具IMPDEF可以直接将DLL中的函数输出到.DEF文件中,只要做一点点修改就可以成为符合VC的DEF文件!
( s; U6 `% N0 d0 SIMPDEF xxx.def xxx.dll
! m6 ]) D6 B" b+ H: L1 \: Y这种方法只能应用于输出为C格式的__stdcall调用方式经过我的论证有些错误!我利用Borland C++和VC++做论证,发现:
3 D! w( I* D3 g: M而在C++BUILDER中!
X' S6 R% P) }4 ^6 f; i1 f__cdecl的函数输出前会带一"_"
% |" G. _8 L4 _* r* y! G; `& k1 F/ x__stdcall无特征,只输出函数名
( f% q6 \8 |' m3 D' X% z__fastcall函数输出前带一"@"
4 x7 j5 L# r; j! |都无"@nn"后缀格式!1 e3 N8 \3 r+ L: ~5 [8 j
在VC中!
5 r9 S; N* Y$ t__cdecl无特征,只输出函数名/ V. h0 A. J2 I3 j. q+ U
__stdcall的函数输出前会带一"_"后缀带"@nn"! _4 {7 z: a6 d; K
__fastcall函数输出前带一"@"后缀带"@nn
& m/ X+ f1 F3 s3 u, _只要将BC的DEF文件中函数申明格式转换为VC识别的格式就可以利用LIB工具生成LIB;要使用C分格输出(extern "C")才是必须的!而且别忘了在DEF文件中的函数申明不要带“_”啊!:)不然会出现error LNK2001的链接错误! |
|