首先,此解决方案是我自己遇到的,不代表普适,只是提供一种思路。我的C语言代码是直接嵌入go代码中的。
先看我的项目文档结构:include文件夹里是openssl的头文件,lib文件夹里是C的.lib文件,service文件里面go代码有C的调用。
service中的C代码调用部分代码如下:/*
#cgo CFLAGS : -I../include
#cgo windows LDFLAGS: -L../lib -llibeay32 -lssleay32 -lWS2_32
#include
#include
#include
#include
#include
#include
#include "openssl/rsa.h"
#include "openssl/crypto.h"
#include "openssl/x509.h"
#include "openssl/pem.h"
#include "openssl/ssl.h"
#include "openssl/err.h"
...
...
*/
import C
可以看到CFLAGS是设置头文件路径,LDFLAGS是设置库文件。在配置这两个变量过程中,注意与自己的文件路径相对应,保证正确。尤其注意c代码注释完后紧跟import C ,不要在中间添加其他东西。这里的import C 实际上是伪包,跟我们经常调用的import不一样,在之后c代码调用过程中,只要在函数前加上C就可以了,具体cgo可以参考官方文档。
来说说我遇见的问题吧:
整个项目在编译时通过了,执行时却提示找不到***.dll文件。重装过mingw64(因为要用到gcc),重装过go ,无济于事。。。
经过摸索,最终解决:
1.检查自己的go的环境变量的系统变量中GOROOT,和GOPATH路径是否正确,包括用户变量,以及Path变量中是否加入"%GOROOT%bin",在安装go的时候有些默认设置会在用户变量中建GOROOT。
2.如果上面正确还解决不了的话,就把.lib文件全放在根目录下试试。
注意:在你自己使用Cgo的时候gcc很重要哦,如果没有mingw64,就安装最新的Git,它本身就带有mingw64,并确保此目录下有gcc(这句话很重要),我自己独立安装的mingw64带有gcc,能编译成功却无法运行提示找不到.lib文件;而Git自带的D:Gitmingw64bin却没有gcc,连编译都通过不了,于是我直接把独立安装的D:mingw64bin下的gcc相关的四个文件直接拷到D:Gitming64bin下,竟然成功了 。我猜是两个版本安装时都或多或少少了个别我们需要的文件吧。
因为一些特殊原因无法将全部代码提供给大家参考,请海涵。也可能你出现的问题跟我的一样,但是原因不一样,在这里也只是给大家能够扩展一下解决思路,希望对你有所帮助。