嵌入式Web Service gSOAP的移植与应用(一)

简介:
一.实验目的
(1)        了解GoAhead WebServer的移植方法
(2)        学习如何使用GoAhead Web服务器
二.基础知识
(1)     C语言基础
(2)     掌握Linux环境下vi编译器的使用方法
(3)     掌握Makefile的编写和使用方法
(4)     了解Linux下的程序编译与交叉编译过程
三.实验环境
为了完成本实验,以下硬件条件是必须的:
(1)        UP-NETARM2410-S嵌入式实验平台
(2)        PCPentium500以上,硬盘40GB以上,内存128MB以上
为了完成本实验,以下软件条件是必须的:
(1)        PC机操作系统RedHat Linux 9.0
(2)        ARM-Linux开发环境
(3)        Web218.tar.gz压缩包
四.情景描述
下载web218.tar.gz压缩包并且解压,之后对LINUX目录下的main.c程序和Makefile进行改造,并且通过交叉编译器进行编译。将生成的webs程序在开发板上执行并测试。
五.完成实验所需时间:约60分钟
六.实验内容
新建一个目录,将这个实验所需要用到的压缩包复制到该目录并压缩
从网站www.goahead.com下载压缩包webs218.tar.gz,并且解压。
[root@localhost root]# cp /mnt/hgfs/linux/webs218.tar.gz /arm2410cl/
//将共享目录/mnt/hgfs/linux/webs218.tar.gzwebs文件包拷贝到/arm2410cl目录下
[root@localhost root]# cd /arm2410cl/
//切换到/arm2410cl目录
[root@localhost arm2410cl]# ls
//显示该目录下的文件
webs218.tar.gz
[root@localhost arm2410cl]# tar -zxvf webs218.tar.gz
//解压后的文件是ws031202
[root@localhost arm2410cl]# ls
// 显示目录下解压后的文件夹
webs218.tar.gz  ws031202
[root@localhost arm2410cl]# cd ws031202/LINUX
// 切换到 ws031202/LINUX 目录下
[root@localhost LINUX]# ls
// 可以查看到有 main.c Makefile 文件
main.c  Makefile
[root@localhost LINUX]# make
// 执行 make, 编译文件
[root@localhost LINUX]# ls
// 编译后生成目标文件和执行文件 webs
libwebs.a  main.c  main.o  Makefile  webs
[root@localhost LINUX]# ./webs
// 执行 ./webs
在浏览器的地址栏输入: http://localhost/home.asp http://10.88.221.60/home.asp  ,见到下面的页面说明成功了。
[root@localhost LINUX]# make clean
// 如果想重新编译清除目标文件和可执行文件就可以了
[root@localhost LINUX]# vi Makefile
// 打开编辑 Makefile 文件,使得编译后的文件可以在开发板上运行
CC = armv 4l -unknown-linux-gcc
//CC 说明用什么编译器,这里使 armv 4l -unknown-linux-gcc 编译,可以在开发板上运行                                                                              
AR = armv 4l -unknown-linux-ar
//AR 建立或修改备存文件,或是从备存文件中抽取文件, 这里用 armv 4l -unknown-linux-ar
之后将文件末尾的 cc 更改为 $(CC)
修改 LINUX 目录下的 main.c 文件
由于该开发板本身没有 hostname ,在开发板下输入如下命令: hostname
可以看到 none ,说明开发板不存在 hostname
因此在 main.c 下的 initWeb() 函数中使用 gethostbyname 函数无用。所以把如下内容屏蔽,并在之后直接将 IP 地址写入 intaddr.
注释内容:
/*
        if (gethostname(host, sizeof(host)) < 0) {
                error(E_L, E_LOG, T("Can't get hostname"));
                return -1;
        }
        if ((hp = gethostbyname(host)) == NULL) {
                error(E_L, E_LOG, T("Can't get host address"));
                return -1;
        }
        memcpy((char *) &intaddr, (char *) hp->h_addr_list[0],
                (size_t) hp->h_length);
                                                                               
                                                                                
*/
添加以下内容:
Intaddr.s_addr = inet_addr(“10.88. 221.61” );
注意:括号内的内容为开发板的 IP 地址,此处实验台的 IP 地址为 10.88.221.61
完成如上操作之后,准备在 LINUX 目录下进行编译:
[root@localhost LINUX]# make
之后可以看到如下内容:
[root@localhost LINUX]# ls
// 查看生成的目标文件和可执行文件
[/mnt/yaffs]ifconfig eth0 10.88.221.61 netmask 255.255.255.0
//修改IP地址及子网掩码,
[/mnt/yaffs]ifconfig eth0
//查看网卡绑定的IP地址
[/mnt/yaffs]ping 10.88.221.60
//ping 网络是否连通
[/mnt/yaffs]mount -t nfs 10.88.221.60:/arm2410cl /mnt/nfs
// /arm2410cl 目录挂载到目标板的 /mnt/nfs 挂载点上
[/mnt/yaffs]cd /mnt/nfs
// 切换到 /mnt/nfs 目录
[/mnt/nfs]ls
// 查看当前目录下的文件
gsoap_linux_ 2.7.9 e.tar.gz  ws031202
webs218.tar.gz
[/mnt/nfs]cd ws031202/LINUX/
// 切换到 ws031202/LINUX/ 目录
[/mnt/nfs/ws031202/LINUX]ls
// 查看是否是刚才编译生成的目标文件和执行文件
Makefile   libwebs.a  main.c     main.o     webs
[/mnt/nfs/ws031202/LINUX]./webs
// 执行 webs ,如果在执行 webs 是在后面加上 & 参数表示该程序在后台持续执行
 
在宿主机浏览器的地址栏上输入: http://10.88.221.61/home.asp   
// 如果看下面的界面说明成功









本文转自 chen138 51CTO博客,原文链接:http://blog.51cto.com/chenboqiang/303977,如需转载请自行联系原作者

目录
相关文章
|
3月前
|
存储 监控 安全
如何在Python Web开发中确保应用的安全性?
如何在Python Web开发中确保应用的安全性?
|
3月前
|
前端开发 JavaScript 安全
前端性能调优:HTTP/2与HTTPS在Web加速中的应用
【10月更文挑战第27天】本文介绍了HTTP/2和HTTPS在前端性能调优中的应用。通过多路复用、服务器推送和头部压缩等特性,HTTP/2显著提升了Web性能。同时,HTTPS确保了数据传输的安全性。文章提供了示例代码,展示了如何使用Node.js创建一个HTTP/2服务器。
98 3
|
3月前
|
前端开发 JavaScript
探索现代Web应用的微前端架构
【10月更文挑战第40天】在数字时代的浪潮中,Web应用的发展日益复杂多变。微前端架构作为一种新兴的设计理念,正逐步改变着传统的单一前端开发模式。本文将深入探讨微前端的核心概念、实现原理及其在实际项目中的应用,同时通过一个简单的代码示例,揭示如何将一个庞大的前端工程拆分成小而美的模块,进而提升项目的可维护性、可扩展性和开发效率。
|
1月前
|
Web App开发 编解码 vr&ar
使用Web浏览器访问UE应用的最佳实践
在3D/XR应用开发中,尤其是基于UE(虚幻引擎)开发的高精度场景,传统终端因硬件局限难以流畅运行高帧率、复杂效果的三维应用。实时云渲染技术,将渲染任务转移至云端服务器,降低终端硬件要求,确保用户获得流畅体验。具备弹性扩展、优化传输协议、跨平台支持和安全性等优势,适用于多种终端和场景,特别集成像素流送技术,帮助UE开发者实现低代码上云操作,简化部署流程,保留UE引擎的强大开发能力,确保画面精美且终端轻量化。
使用Web浏览器访问UE应用的最佳实践
|
3月前
|
监控 安全 测试技术
如何在实际项目中应用Python Web开发的安全测试知识?
如何在实际项目中应用Python Web开发的安全测试知识?
118 61
|
2月前
|
弹性计算 Java 关系型数据库
Web应用上云经典架构实践教学
Web应用上云经典架构实践教学
Web应用上云经典架构实践教学
|
2月前
|
Kubernetes 安全 Devops
有效抵御网络应用及API威胁,聊聊F5 BIG-IP Next Web应用防火墙
有效抵御网络应用及API威胁,聊聊F5 BIG-IP Next Web应用防火墙
97 10
有效抵御网络应用及API威胁,聊聊F5 BIG-IP Next Web应用防火墙
|
2月前
|
弹性计算 Java 数据库
Web应用上云经典架构实战
本课程详细介绍了Web应用上云的经典架构实战,涵盖前期准备、配置ALB、创建服务器组和监听、验证ECS公网能力、环境配置(JDK、Maven、Node、Git)、下载并运行若依框架、操作第二台ECS以及验证高可用性。通过具体步骤和命令,帮助学员快速掌握云上部署的全流程。
|
3月前
|
前端开发 JavaScript UED
在数字化时代,Web 应用性能优化尤为重要。本文探讨了CSS与HTML在提升Web性能中的关键作用及未来趋势
在数字化时代,Web 应用性能优化尤为重要。本文探讨了CSS与HTML在提升Web性能中的关键作用及未来趋势,包括样式表优化、DOM操作减少、图像优化等技术,并分析了电商网站的具体案例,强调了技术演进对Web性能的深远影响。
58 5
|
3月前
|
机器学习/深度学习 人工智能 JavaScript
JavaScript和TypeScript的未来发展趋势及其在Web开发中的应用前景
本文探讨了JavaScript和TypeScript的未来发展趋势及其在Web开发中的应用前景。JavaScript将注重性能优化、跨平台开发、AI融合及WebAssembly整合;TypeScript则强调与框架整合、强类型检查、前端工程化及WebAssembly的深度结合。两者结合发展,特别是在Vue 3.0中完全采用TypeScript编写,预示着未来的Web开发将更加高效、可靠。
98 4

热门文章

最新文章