本系列文章规划:
1、移植篇
2、 asp
3、action
4、文件上传
5、 cgi
6、登录验证
7、添加源码到自己的应用中进行开发
先附上源码链接:https://www.embedthis.com/goahead/download.html,目前官方最新版本是5.1.1。
官方文档:https://www.embedthis.com/goahead/doc/。
公司之前用的版本很老,很多功能都不是原生支持的,最近刚好有需求可以了解一下更新的版本,以此记录。
如果你之前使用过gpahead3.X及以上的版本,现在想迁移到更高的版本,那么我建议你直接阅读官方的文档,因为3.X及以上的版本和现在的版本差别不是很大,差别比较大的是2.X及之前的版本。
移植前先去官网下载好源码包goahead-5.1.1-src.tgz,解压后进入goahead-5.1.1文件夹,官方推荐的方式是使用MakeMe工具进行配置,我不想安装额外的工具,所以直接使用make,make完成后会在build文件夹里面生成与你当前主机对应的可执行文件和其它需要的文件,如图1图2所示:
图1
图2
*.crt和*.key文件 | SSL相关的 |
*.a文件 | SSL相关的库文件(重要) |
libgo.so文件 | 以库的方式添加goahead到你的应用中时需要 |
goahead | 没有任何添加的应用程序 |
goahead-test | 添加了官方提供的一些例程 |
gopass | 生成用户登录验证的密码 |
这里注意我make完成后,并没有按照官方的做法进行安装(install)或者部署(deploy),因为我并不是要将服务器搭建到我的开发机上,如果你要将服务器搭建到你的开发机上,可以按照官方的步骤来做。
大多数情况我们都是需要将goahead嵌入到我们自己的应用中,而不是单独使用,官方提供了两种方式可以将goahead嵌入到你的应用中,一种是将配置好后编译生成的libgo.so库加一个你自己的主程序,另一种是使用源码,直接在提供的goahead.c文件中添加你的内容;如果直接用官方提供的文件结构模板及Makefile来开发,在测试的时候发现SSL的配置项就算更改了也没有起作用(估计是一个BUG,已通过邮件反馈给官方,当然如果你不需要关闭SSL的话可以直接使用官方的),经过综合对比及测试,我最终选择使用源码加自己写的Makefile来进行开发。
交叉编译:我们主要需要指定ARCH,OS,CC这三个参数就行了,可配置的选项可以在提供的Makefile中找到,图3截取了部分的配置项。
图3