Linux下Apache安装及实例(2)

DSO的安装和配置选项
-i
    此选项表示需要执行安装操作, 以安装一个或多个动态共享对象到服务器的modules目录中。
-a
    此选项自动在httpd.conf文件中增加一个LoadModule行,以激活此模块,或者,如果此行已经存在,则启用之。
-A
    与-a选项类似,但是它增加的LoadModule指令由一个井号前缀(#), 即,此模块已经准备就绪,但尚处于禁用状态。
-e
    此选项表示需要执行编辑操作,它可以与-a和-A选项配合使用, 与-i操作类似,修改Apache的httpd.conf配置文件,但是并不安装此模块。


四、具体开发步骤:
1.利用Apache自带都apxs建立hello模块:
  #apxs -g -n hello
这样就会在当前目录下新建一个hello模块的文件目录,可以看到里面有:Makefile mod_hello.c modules.mk这样的文件。
  Creating [DIR]  hello
  Creating [FILE] hello/Makefile
  Creating [FILE] hello/modules.mk
  Creating [FILE] hello/mod_hello.c
  Creating [FILE] hello/.deps

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.编译模块
  #apxs -c -a -i -L/usr/lib64/mysql/ -lmysqlclient mod_hello.c
可以看到一堆编译指令,加上-I和-l是编译mysql必须的,编译完会自动在httpd.conf加上 LoadModule hello_module modules/mod_hello.so

5.修改httpd.conf

  LoadModule hello_module modules/mod_hello.so    #编译完会自动在httpd.conf加上
  <Location /hello>    #中间有空格
      SetHandler hello
  </Location >

6.重启apache,访问,看是否成功。

数据库systeminfo

数据库:test
表:systeminfo

CREATE TABLE `systeminfo` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `ip_info` varchar(50) NOT NULL,   
  `serv_info` varchar(50) NOT NULL,   
  `cpu_info` varchar(50) NOT NULL,   
  `disk_info` varchar(50) NOT NULL,   
  `mem_info` varchar(50) NOT NULL,   
  `load_info` varchar(50) NOT NULL,   
  `mark_info` varchar(50) NOT NULL,   
  PRIMARY KEY (`id`),
  UNIQUE KEY `ip_info` (`ip_info`),
  UNIQUE KEY `ip_info_2` (`ip_info`)
);

systeminfo

代码:

#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 "/usr/include/mysql/mysql.h"

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

/* 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, "<li>Error : %d %s</li>\n", mysql_errno(&mysql), mysql_error(&mysql));
        return OK;
    }
    char *sql = "select ip_info,mark_info from systeminfo order by rand()";
    if (mysql_query(&mysql, sql)!=0) { /* 查询 */
        ap_rprintf(r, "<li>Error : %d %s</li>\n", mysql_errno(&mysql), mysql_error(&mysql));
        return OK;
    }
    rs = mysql_store_result(&mysql); /* 获取查询结果 */
    while ((row = mysql_fetch_row(rs))) { /* 获取每一行记录 */
        ap_rprintf(r, "<li>%s - %s</li>\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);
}

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/8e7be1e59b63a38a5d8d188fa913b18d.html