通行证: 用户 密码
域名空间  下载中心 社区论坛 信息公告 my小屋
联系我们
设为首页
加入收藏
热门:qq挂机,asp,php,jsp,xml
,sql,.net,编程 程序 网页图象
首页>网络编程>asp专区>正文 中国黑客群攻击美政府网站 拿到部   微软计划开放office文件格式 消除   腾讯联合八部门严厉打击挂机网站   神六载人飞行圆满成功   美国会要求nasa彻底完成空间站建   google中国研究院有望落户清华   深度分析:论雅虎中国的夭折和阿   神六可能于10月13日上午11点发射   盖茨继续当全美首富   adobe ceo痛斥微软 称其管理层从   
热 点 排 行
dll文件下载
qq挂机的n种快速方法
长白山天池怪兽再现 一分钟
腾讯qq调整升级条件 不再诱
ape歌曲的播放、转换和刻录
新开放qq免费挂级网站
qq挂级程序,qq免费挂机源程
刘亦菲 变性人、堕胎,自称
photoshop通道抠图:给秀发
免费把qq炫铃设为本机qq的
用通通通作代理在局域网上
用6位qq注意啦,免费领取6位
超级女声总决赛 现场实况(
用nero制作win98多功能启动
亲身体验!让桌面不再粗糙
推 荐 新 闻
中国黑客群攻击美政府网站
bittorrent被好莱坞招安盗
网站建设中,关键词选择技
神六载人飞行圆满成功
国庆长假上网慎防“移动杀
连环起诉google 传统媒体欲
最强秘籍 ie7最新使用技巧
神六完成总装可接航天器 外
adobe ceo痛斥微软 称其管
微软急调张亚勤回中国 千里
微软宣布重大重组方案 将划
腾讯qq 2005 beta3火热发布
腾讯扩张路线图曝光 陈天桥
腾讯拍拍网正式吹响进军c2
第五届“西湖论剑”文字实
相 关 新 闻
首页>网络编程>asp专区>正文

用isapifilter使inc、asa文件安全


http://www.iyit.net  日期:2005-11-24 17:25:57  来源:易特网络技术  点击:
在以前看到老外的一篇文章,现在记不起这个很不错的热情的有如我一般的年轻人了,不过邮箱里还有和他讨论的邮件。
    有不少站点可能都有这样的情况,利用.inc以及.asa包含文件来存储数据库连接信息,特别是.inc的文件,想改掉有需要太多的时间和做大幅度的程序调整,比如我有个客户就是光.inc文件就有几十个,更别说asp文件了,想改是无从下手的。于是我利用那位外国朋友的经验,做了很少的一点改动,形成一个isapi的过滤器,希望能使您的站点的inc以及asa文件安全一点。
    我不想把标准的isapi的接口函数做一一介绍,比较全面的知识您可以利用vc的isapi工程模板来学习。在这里我着重介绍onurlmap以及如何用它来完成我们保护inc和其他文件安全性的过程。
    isapi filter(internet server application program interface (isapi) filter)是绑定在iis系统并监控发生在客户端从webserver读取文件事件的一种基于windows的程序应用。
    由于他可以控制客户端和服务器间的数据交换,我们可以用它来提高wwwserver的应用性能比如扩展http日志功能、实现自己的加密和验证系统。 
onpreprocheaders -- 服务器预处理客户端头文件.
onauthentication -- 客户端验证.
onurlmap -- 服务器映射逻辑url到物理路径. 
onsendrawdata -- 服务器发送未经处理的数据到客户端(之前).
onreadrawdata -- 客户断发送未经处理的数据到服务器(之后,但在服务器处理之前).
onlog -- 写日志到服务器文件. 
onendofnetsession -- 会话结束. 
下面是onurlmap的用法:
dword cjsisapifilter::onurlmap(chttpfiltercontext* pctxt,
phttp_filter_url_map pmapinfo)
{
// todo: react to this notification accordingly and
// return the appropriate status code
dword lenurl = strlen(pmapinfo->pszurl);
dword dwreferer = 250;
const char * szurl = strlwr((char *)pmapinfo->pszurl);
const char * szextension = &szurl[lenurl - 3];
const char * inextension = &szurl[lenurl - 4];
char szreferer[250];
//到服务器的数据已经编码过了
if ( strcmp(szextension, ".js") == 0 || strcmp(inextension,".inc") == 0 || strcmp(inextension,".asa") 
== 0){
pctxt->getservervariable("http_referer", szreferer, &dwreferer);
if ( szreferer[0] != ’h’ ) {
char szredirect[2];
char szcontent[300];
dword dwredirect = 2;
dword dwcontent;
sprintf(szredirect,"");
sprintf(szcontent, "\r\n\r\n<html>\r\n<head><title>安全文件
</title></head>\r\n<body>\r\n<b><center><font size=+2>该文件包含非公开信息,您没有读取该文件的权限。
</font></b><br><br><br><hr><a 
href=mailto:bingb@emount.com.cn>mailto:bingb@emount.com.cn</a><br></center>\r\n</body>\r\n</html>\r\n");
dwcontent = strlen(szcontent);
pctxt->serversupportfunction(sf_req_send_response_header,szredirect,&dwredirect,null);
pctxt->writeclient (szcontent, &dwcontent);
return sf_status_req_finished;
}
}
return sf_status_req_next_notification;
}
编译后将编译完成的dll文件拷贝到winnt\system32\inetsrv\目录下,然后在站点的属性里面的isapi过滤器添加一个过滤器,映射dll到该文件即可。
重新启动w3svc服务,然后访问:http://localhost/xxx.inc可以看到返回信息。
有任何问题可以联系:bingb@emout.com.cn 希望该文章能对您有用。

上一篇:利用asp+jmail进行邮件群发的新思路
下一篇:asp中巧用response属性

[发送给好友] [打印本页] [关闭窗口] [返回顶部] 转载请注明来源:http://www.iyit.net
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
责任编辑: 投稿作者: 易特网络技术
信息来源: 易特网络技术 录入时间: 2005-11-24 17:25:57
浏览次数: 投稿信箱: shtghy@163.com
  友情链接
设置首页 - 版权声明 - 广告服务 - 关于我们 - 联系我们 - 友情连接
copyrights ?2004-2005 iyit.net all rights reserved.
网站合作、广告联系qq:147007642、466949678
易特网络技术 点击这里给我发消息