设为首页 收藏本站
查看: 682|回复: 0

[经验分享] c apache module 开发入门(访问mysql)

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-8-3 06:15:13 | 显示全部楼层 |阅读模式
扩展Apache模块开发网上大部分教程都是围绕Perl语言记性,老外的《Writing Apache Modules with Perl and C》可以算是经典之作了,可惜一直都是针对老版本开发,而且主力语言是Perl,C语言部分只是略有介绍。不过相比较而言用Perl来扩展模块功能确实比 C语言来的快速以及便捷多了,也简单容易。我自己也在工作里应用了一部分,主要是在防盗链上面写了两个简单都模块,可以参考我写的另外两篇文章:apache+mod_perl防盗链以及apache+mod_perl实现url rewrite。说了那么多题外话,回到正题,这里只是用C语言实现一个简单的hello模块,模块功能是查询MySQL自带mysql数据库里都user表。

系统环境:
ArchLinux Apache2.2 MySQL 5.0

具体开发步骤:
1.利用Apache自带都apxs建立hello模块:
  [root#localhost] apxs -g -n hello
  apxs为在path to apache. .../apache/bin/apxs.

  如cd /usr/local/apache

  bin/apxs -g -n hello

  在 /usr/local/apache目录创建了hello文件夹。

这样就会在当前目录下新建一个hello模块的文件目录,可以看到里面有:Makefile  mod_hello.c  modules.mk这样的文件,具体apxs路径查询下本机apache/bin目录。

2.预览下mod_hello.c,可以看到里面apxs自动帮你生成一堆代码了,我们需要的只是修改里面的代码部分,先简单都介绍下里面的函数说明。
include 部分就是引入了一些必要都头文件
hello_handler 这个就是hello模块都主体部分,所有的显示、处理请求什么的都在这里。
hello_register_hooks hello_module 这俩个是需要导出的函数所必须的,先可以不管他们,按照生成的不动即可。

3.修改hello_handler函数,里面可以看到request_rec *r,r有很多函数和变量,具体要参见文档了。里面的ap_rputs是输出,可以简单的理解为把字符串输出到r。
static int hello_handler(request_rec *r)
{
if (strcmp(r->handler, "hello")) { // 判断apache配置文件里handler是否等于hello,不是就跳过
return DECLINED;
}
r->content_type = "text/html"; // 设置content-type
if (!r->header_only)
ap_rputs("The sample page from mod_hello.c\n", r); // 输出一段文字
return OK;// 返回 200 OK状态
}

增加#include "mysq.h",查询需要用到这个头文件。
具体代码参见本文结尾部分。

  4.编译模块
  

  [root#localhost] apxs -c -a -i -I/usr/include/mysql/ mod_hello.c
  其他实例:

  cd /usr/local/apache
  bin/apxs -c -a -i -I/usr/local/mysql/include/mysql/ hello/mod_hello.c
  /usr/include/mysql/ 为mysql的头文件位置,实际编译的时候选择自己mysql安装后头文件位置,
可以看到一堆编译指令,加上-I和-l是编译mysql必须的,编译完会自动在httpd.conf加上 LoadModule hello_module modules/mod_hello.so

5.修改httpd.conf

SetHandler hello


6.重启apache,访问http://localhost/hello,看是否成功。

转自http://hi.baidu.com/smallfish_xy/blog/item/1a59fe117afd26f5c2ce79a9.html
=================================================================================

完整代码:
#include "httpd.h"
#include "http_config.h"
#include "http_protocol.h"
#include "ap_config.h"
/* 头文件,本文用到了
ap_rprintf函数 */
#include "apr.h"
#include "apr_lib.h"
#include "apr_strings.h"
#include "apr_want.h"
#include "mysql.h"

/* 定义mysql数据变量 */
const char *host = "localhost";
const char *user = "root";
const char *pass = "smallfish";
const char *db             = "mysql";

/* The sample content handler */
static int hello_handler(request_rec *r)
{
if (strcmp(r->handler, "hello")) {
return DECLINED;
}
r->content_type = "text/html";
/* 定义mysql变量 */
MYSQL mysql;
MYSQL_RES *rs;
MYSQL_ROW row;
mysql_init(&mysql); /* 初始化 */
if (!mysql_real_connect(&mysql, host, user, pass, db, 0, NULL, 0)) {/* 连接数据库 */
ap_rprintf(r, "Error : %d %s\n", mysql_errno(&mysql), mysql_error(&mysql));
return OK;
}
char *sql = "select host,user from user order by rand()";
if (mysql_query(&mysql, sql)!=0) { /* 查询 */
ap_rprintf(r, "Error : %d %s\n", mysql_errno(&mysql), mysql_error(&mysql));
return OK;
}
rs = mysql_store_result(&mysql); /* 获取查询结果 */
while ((row = mysql_fetch_row(rs))) { /* 获取每一行记录 */
ap_rprintf(r, "%s - %s\n", row[0], row[1]);
}
mysql_free_result(rs); /* 释放结果集 */
mysql_close(&mysql); /* 关闭连接 */
return OK;
}

static void hello_register_hooks(apr_pool_t *p)
{
ap_hook_handler(hello_handler, NULL, NULL, APR_HOOK_MIDDLE);
}

/* Dispatch list for API hooks */
module AP_MODULE_DECLARE_DATA hello_module = {
STANDARD20_MODULE_STUFF,
NULL,                            /* create per-dir              config structures */
NULL,                            /* merge  per-dir              config structures */
NULL,                            /* create per-server config structures */
NULL,                            /* merge  per-server config structures */
NULL,                            /* table of config file commands                 */
hello_register_hooks  /* register hooks                                */
   };
  

  经过测试,可以成功运行。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-93415-1-1.html 上篇帖子: Apache Nutch 1.3 学习笔记八(LinkDb) 下篇帖子: 四大开源协议比较:BSD、Apache、GPL、LGPL
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表