linux 嵌入式 mysql_嵌入式web服务器BOA+CGI+HTML+MySQL项目实战——Linux

#include #include"cgic.h"#include#include#include#include#include#include#include#include

#define SQL_SIZE 256

int cgiMain(void)

{char username[20];char password[20];char email[40];//回显信息到HTML网页cgiHeaderContentType("text/html");

printf("\n\n");

printf("\n\n");

printf("

\n\n");if(cgiFormString("username", username, sizeof(username)) !=cgiFormSuccess)

{

fprintf(stderr,"cgiFormString function username failed");//exit(-1);

}

printf("用户名:%s\n\n",username);

printf("
\n\n");//password gateway server_ip dns subnet_mask dhcp error

if(cgiFormString("password", password, sizeof(password)) !=cgiFormSuccess)

{

fprintf(stderr,"cgiFormString function password failed");//exit(-1);

}

printf("密码:%s\n\n",password);

printf("
\n\n");/*if(cgiFormString("email", email, sizeof(email)) != cgiFormSuccess)

{

fprintf(stderr, "cgiFormString function email failed");

//exit(-1);

}

printf("电子邮箱:%s\n\n",phone);

printf("
\n\n");*/

/*** 将用户信息写入MySQL数据库中 ***/

//数据存储到数据库

MYSQL*conn;boolisAutoCommit;//初始化 MySQL

conn =mysql_init(NULL);if(NULL ==conn)

{

printf("errno:%d error:%s\n",mysql_errno(conn),mysql_error(conn));

exit(-1);

}char ip[16] = "127.0.0.1";char user[20] = "test";char passwd[20] = "test";char database[20] = "register";int port = 3306;//尝试与运行在主机上的MySQL数据库引擎建立连接

if(NULL == mysql_real_connect(conn,ip,user,passwd,database,port,NULL,0))

{

printf("---errno:%d error:%s\n\n",mysql_errno(conn),mysql_error(conn));

exit(-1);

}

isAutoCommit= true;//根据mysql的autocommit参数设置来决定是否自动提交

mysql_autocommit(conn,isAutoCommit);//设定数据库编码

mysql_query(conn,"SET NAMES 'utf8'");

mysql_query(conn,"SET CHARACTER SET utf8");

mysql_query(conn,"SET CHARACTER_SET_RESULT = utf8");charcmd[SQL_SIZE];//置字节字符串cmd的前SQL_SIZE个字节为零且包括‘\0’

bzero(cmd, SQL_SIZE);//创建user表//strcpy(cmd, "CREATE TABLE user(username varchar(20) PRIMARY KEY,password varchar(20));");//将sql语句写入cmd变量

sprintf(cmd, "INSERT INTO user values('%s', '%s');",username,password);

printf("%s\n\n",cmd);//向与指定的连接标识符关联的服务器中的当前活动数据库发送一条查询

if(mysql_query(conn,cmd) != 0)

{

printf("errno:%d error:%s\n\n",mysql_errno(conn),mysql_error(conn));

printf("

注册失败,请重新注册

\n\n");

sleep(1);

printf("\n");

}//mysql_affected_rows(conn);

printf("

注册成功

\n\n");

printf("
\n\n");

printf("

您的用户名和密码为:

\n\n");

sprintf(cmd,"select * from user;");

MYSQL_RES*res;

MYSQL_ROW row;if(mysql_query(conn,cmd) != 0)

{

printf("errno:%d error:%s\n",mysql_errno(conn),mysql_error(conn));return -1;

}int num_fields =mysql_field_count(conn);if(num_fields == 0)

{

printf("errno:%d error:%s\n",mysql_errno(conn),mysql_error(conn));return -1;

}

res=mysql_store_result(conn);if(NULL ==res)

{

printf("errno:%d error:%s\n",mysql_errno(conn),mysql_error(conn));return -1;

}

printf("
\n\n");

printf("
\n\n");while((row =mysql_fetch_row(res)))

{char arr[1000];int i = 0;for( ; i

{

printf("%s",row[i]);

}

printf("\n\n");

printf("
\n\n");

}

mysql_free_result(res);

sleep(1);

printf("\n");return 0;

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
嵌入web服务器boa框架的基础上, 使用C语言cgi, 或者Python脚本, 结合HTML + javascript + ajax 的嵌入web系统的开发实例 html 中使用javascritp + ajax 从C语言生成的cgi文件的get, set 一些值. boa服务器的相关配置参数说明: http://www.cnblogs.com/liuweiqiang/p/3859130.html boa安装包文件名: boa-for-hi3516a.tar.gz boa.conf 文件的保存路径: cat /etc/boa/boa.conf boa可 执行文件的路径: /usr/local/bin/boa, 可以设置为: 系统启动的时候, 这个进程自动启动 boa.conf 文件的重要参数 保存html文件的目录 DocumentRoot /www 可以将这个目录, 设置为samb共享文件夹的目录, 方便修改调试 修改完成以后, 肯定要重启boa进程的 保存python脚本, 或者C语言cgi文件的目录 ScriptAlias /cgi-bin/ /var/www/cgi-bin/ 说明: cgi-bin/ 后面的斜杠, 一定要加上 可以将这个目录, 设置为samb共享文件夹的目录, 方便修改调试 修改完成以后, 肯定要重启boa进程的 html文件文件中, 调用python脚本的时候, 指定的路径, 需要有: /cgi-bin, 比如: var url = "/cgi-bin/getuser.py"; 这个是python 或者 var url = "/cgi-bin/output.cgi"; 这个是C语言 说明: 如果发现, html文件, 修改了, 可是在浏览器中, 查看html源代码的时候, 这个代码, 还是旧的, 那么可以通过清空"IE浏览器", "360浏览器"的浏览记录 以上, javascript 可以调用python 同样, 也可以调用C语言生成的cgi文件(其实, 就是可执行文件) C语言 + Html 例子 C语言 CGI实例 http://blog.csdn.net/ajrm0925/article/details/8810342 http://blog.csdn.net/liang890319/article/details/6277900 http://blog.csdn.net/gnefniu/article/details/42432657 上传文件: http://blog.csdn.net/yu_xiang/article/details/7996670 查找文件 find . -type f -name "boa.conf" -print -mount find . -type f -name "boa" -print -mount 四、嵌入web服务器boa的配置和使用 嵌入web服务器boa的配置文件为boa.conf, 在boa-0.94.13目录下面,复制该文件到文件 系统的/etc/boa目录下面,打开boa.conf,修改为如下内容: Port 80 User root Group root ErrorLog /dev/console AccessLog /dev/null ServerName SoftEmbed.com DocumentRoot /www DirectoryIndex index.html KeepAliveMax 1000 KeepAliveTimeout 10 MimeTypes /etc/mime.types DefaultType text/plain CGIPath /bin:/usr/bin:/usr/local/bin ScriptAlias /cgi-bin/ /www/cgi-bin/ 几个重要配置参数如下: DocumentRoot: 存放html文档的主目录; DirectoryIndex: 默认返回的html文档; ScriptAlias:cgi脚本虚拟路径对应的实际路径,/www/cgi-bin/为cgi脚本存放的实际路径; 其他配置选项的意义请参考相关资料。 复制boa可执行文件到/usr/sbin目录中, 启动boa进程 重新制作文件系统,系统启动后,在客户端浏览器上输入开发板的ip 地址,例如: http://192.168.0.218, 就可以看到显示的测试网页了,如下图所示 CGI getenv函数的参数详解: http://www.cnblogs.com/ser0632/p/5498228.html s = getenv("环境变量名"); 取得环境变量内容 putenv改变或增加环境变量 int putenv(const char * string); setenv(改变或增加环境变量) http://www.jb51.net/article/71940.htm
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值