让Apache支持cgi、SSI、shtml的配置方法

softyun3年前云服务器35

1.首先明确,只能够指定某个确定的目录,支持cgi,即运行该目录执行cgi程序;否则不太安全。
寻找:

复制代码 代码如下:

    #
    # "C:/Program Files/Apache Group/Apache/cgi-bin" should be changed to whatever your ScriptAliased
    # CGI directory exists, if you have that configured.
    #
    <Directory "E:/Website_Field/cgi">
        AllowOverride all
        Options all
        Order allow,deny
        Allow from all
    </Directory>

 

设置Directory为可以执行cgi的目录

2.
寻找:

复制代码 代码如下:

    #
    # ScriptAlias: This controls which directories contain server scripts.
    # ScriptAliases are essentially the same as Aliases, except that
    # documents in the realname directory are treated as applications and
    # run by the server when requested rather than as documents sent to the client.
    # The same rules about trailing "/" apply to ScriptAlias directives as to
    # Alias.
    #
    ScriptAlias /cgi-bin/ "E:/Website_Field/cgi"

 

将之后的目录改成和上面的相同。

3.
设置cgi脚本的后缀,寻找:

复制代码 代码如下:

   #
    # AddHandler allows you to map certain file extensions to "handlers",
    # actions unrelated to filetype. These can be either built into the server
    # or added with the Action command (see below)
    #
    # If you want to use server side includes, or CGI outside
    # ScriptAliased directories, uncomment the following lines.
    #
    # To use CGI scripts:
    #
    AddHandler cgi-script .cgi .pl

 

设置后缀如.cgi, .pl等等,任意可以想到的,但是避免使用已有的如, .asp, .php等

注意:设置支持cgi的目录之后,该目录下的内容及子目录的内容都可以执行。

配置Apache支持SSI,即服务器端解析的server-parsed html(shtml)
关于什么是SSI以及什么是shtml,请参看本站的其他两篇文章。
使用SSI可以实现html的动态嵌入内容,可以为一下SSI的命令,甚至是系统返回结果,以及比较常用的调用Perl程序(尤其是perl的cgi返回结果)

1. 配置Apache:
1)首先找到:

 

复制代码 代码如下:

   #
    # To use server-parsed HTML files
    #
    AddType text/html .shtml
    AddHandler server-parsed .shtml
 

 

去掉后两行之前的#号;
2)同时需要指定那个在哪个目录内支持这种解析,寻找:

复制代码 代码如下:

  #
    # "C:/Program Files/Apache Group/Apache/cgi-bin" should be changed to whatever your ScriptAliased
    # CGI directory exists, if you have that configured.
    #
    <Directory "E:/Website_Field/shtml">
        AllowOverride all
        Options all
        Order allow,deny
        Allow from all
    </Directory>


从Directory开始进行修改:
首先指定到自己的目录,这里是"E:/Website_Field/shtml";
然后设置各个选项如上:

 

 

复制代码 代码如下:

AllowOverride all
Options all
Order allow,deny
Allow from all


完后重启Apache应该就可以了。

 

2. 关于Apache支持的SSI指令,可以参考如下介绍:
zzvips/tools/onlinetools/apache-chs/howto/ssi

3. 一个使用SSI的shtml页面实例:
1)、index.shtml

 

复制代码 代码如下:

<html>
<head>
   <title>shtml</title>
</head>
<body>
<!--#config timefmt="%D" -->
  This file last modified <!--#echo var="LAST_MODIFIED" --><br />
  <!--#config timefmt="%A %B %d, %Y" -->
  Today is <!--#echo var="DATE_LOCAL" --><br />
 <!--#include virtual="embed" --><br />
 <!--#exec cmd="test.pl" --><br />
 <!--#exec cmd="dir" --><br />
</body>
</html>

 

2)、embed

 

复制代码 代码如下:

<html>
<head>
    <title>embed html</title>
</head>
<body>
This is the content from embed
</body>
</html>

 

3)、test.pl
 

复制代码 代码如下:


#!C:\perl\bin\perl -w
use strict;

 

sub print_header()
{
    print "This is Header function! ";  
}

sub print_footer()
{
    print "This is Footer function! ";  
}

print_header();
print_footer();


 

总结:
设置Apache支持cgi和支持SSI的时候有个相同的部分,设置目录Directory,而且需要设置为相同的。
因此,如果单使用ssi的话,可以按照ssi的设置进行配置,将shtml等放置到设置的目录下;
如果已设置Apache支持cgi,只需要打开ssi,同时将shtml等文件放置到cgi的目录中即可。

免责声明:本文内容来自用户上传并发布,站点仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。请核实广告和内容真实性,谨慎使用。

相关文章

购买国外专用服务器怎么维护

购买国外专用服务器维护的方法:1、日常检查服务器的硬件和运行环境,包括温度、湿度、灰尘、电源、消防、监控等,以保证服务器的稳定性;2、及时下载更新操作软件和应用程序的安全补丁,保证能及时修复可能出现的...

服务器租用托管如何选择一家可靠的IDC服务商

经常会看到有朋友在百度知道里求助哪个公司的服务器托管和租用怎么样之类的问题,而经常问的那些公司都是没听说过的,所以这里为有需要服务器租用和服务器托管的朋友介绍如何选择一家可靠的IDC服务商。相关阅读:...

访问国外网站的速度怎么测试

访问国外网站速度测试的方法:1、对服务器分别进行在线浏览、下载、上传、在线听音乐、在线看电影等操作测试,能全面测试出服务器在不同操作下的表现;2、使用不同的线路进行测试服务器,能测试出不同线路的访问速...

国内企业租用香港服务器有什么好处

国内企业租用香港服务器的好处:1. 租用香港服务器无需备案,内容限制少,节省时间成本。2. 香港服务器对大中华地区市场的访问速度都非常快,线路稳定,不存在内地的电信网通南北不互通的问题。3. 香港机房...

德阳服务器租用价格多少钱一个月?

德阳服务器位于四川易通德阳数据中心,2006年最先被评为"四星级机房"。机房目前建设面积320平方米,可容纳机架160多个。该机房按照国际标准精心设计,配备CISCO高端网络设备和先进完善的机房设施(...

美国cn2服务器租用不可以做什么

美国cn2服务器租用不可以做:1、侵犯他人网站版权,包括盗版和假冒行为;2、黑客行为,包括入侵他人网站、频繁扫描外部端口、非法探测或直接参与对其它服务器的攻击行为等;3、以任何方式获取第三方系统用户的...