当前位置: 首页 > 图文教程 > 网络编程 > ASP > 用Asp获取Dll加密新闻内容

ASP
嵌入式Web视频点播系统实现方法
GB与BIG5内码转换COM原代码
金额阿拉伯数字转换为中文的存储过程
利用 WSH 作定时工作流程
用InstallShield 进行 ASP 软件的打包和自动安装
服务器获得客户端时间的方法
关于如何读出图片的高度与长度的总结
按下回车键指向下一个位置的一个函数
一个不错的随机函数
一套加解密字符串的函数
一段加密函数(base64)
一段加密函数
使用asp实现支持附件的邮件系统(三)
使用asp实现支持附件的邮件系统(二)
使用asp实现支持附件的邮件系统(一)
检查当前目录下是否存在指定的文件,如果存在就重新命名
MD5加密的javascript实现例子
如何在服务器端调用winzip命令行对上传的多个文件打包压缩
MD5不可逆加密算法的ASP实现实例
看人家用使用InstallShield制作ASP安装程序(6)

ASP 中的 用Asp获取Dll加密新闻内容


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 100 ::
收藏到网摘: n/a

 

以下是代码:
<%
on error resume next
  Dim objXMLHTTP, xml
  Set xml = Server.CreateObject("Microsoft.XMLHTTP")
  xml.Open "GET", "http://chanye.finance.sina.com.cn/yj/2005-01-05/236914.shtml", False
  xml.Send
  tmpstr= xml.responseText
  ep=clng(instr(1,tmpstr,"meta_data2"))+18
  tmpstr=replace(tmpstr,vbcrlf,"")
  tmpstr=replace(tmpstr,chr(9),"")
  tmpstr=replace(tmpstr,chr(32),"")
  mydata=mid(tmpstr,1,ep)
  recfilen=server.MapPath("tempstr.txt")
  set Astream=Server.CreateObject("Adodb.Stream")
  Astream.type=2
  Astream.Mode = 3
  Astream.open
  Astream.CharSet = "GB2312"
  Astream.Position =0
  Astream.Writetext mydata,1
  Astream.SaveToFile recfilen,2
  Astream.close
  set Astream1=Server.CreateObject("Adodb.Stream")
  Astream1.type=2
  Astream1.Mode = 3
  Astream1.CharSet = "GB2312"
  Astream1.open
  Astream1.LoadFromFile(recfilen)
  Assp=Astream1.size
  crttmpstr=Astream1.ReadText(Assp)
  Astream1.close
  sp1=clng(instr(1,crttmpstr,"meta_data1"))+16
  ep1=clng(instr(sp1,crttmpstr,"NAME=meta_data2"))-7
  lth1=ep1-sp1
  newdata=mid(crttmpstr,sp1,lth1)
%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<style>
body{
 font-size:12px
}
td{
 font-size:12px
}
</style>
<title>用Asp获取Dll加密新闻内容</title>
<table width="540" border="0" align="center" cellpadding="0" cellspacing="0">
  <tr>
    <td>更新时间:<%=now  %>获取内容长度:<%=lth1  %>
      字节
注意要使用http://127.0.0.1/Ip1HtmlView.dll你得先下载这个Dll文件,怎么下不用多说吧?!
      <object id=HtmlIp1View codebase=http://127.0.0.1/Ip1HtmlView.dll#version=1,0,1,14 classid=CLSID:D854FC15-D3EA-496A-B2A0-A772A3DE1D09>
        <param name="meta_data1" value="<%=newdata  %>">
        <param name="meta_data2" value="">
        <param name="meta_data3" value="">
        <param name="meta_data4" value="">
        <param name="meta_data5" value="">
        <param name="meta_data6" value="">
        <param name="meta_data7" value="">
        <param name="meta_data8" value="">
        <param name="baseurl" value="111">
        <param name="random" value="111">
      </object></td>
  </tr>

</table>

</body>
</html>
 
  对代码的说明:之所以要使用Adodb.Stream,是因为直接取得的内容始终达不到想要的效果,ep的位置始终要比预期的长很多,而我试过用instrb,midb等函数同样得到另人迷惑的结果,所以无奈之下出此下策,还望高手指点(哎哟,我怎么感觉酸不溜疚的哦)。当然只针对当前地点有效,其它的适当修改就行,甚至可以直接生成页面,并记录到数据库,成为自己的,用上面的东西加写数据库应该够了吧。
  要防止Dll被下载也不难,对于IIS来是说可以加个.dll的ISAPI扩展,可执行文件随便选个Dll文件动作限制为“空”(什么都行,反正乱输入就可以了。)。要是Dll不为外站工作嘛,就不敢乱说了。防止新闻被窃取对付象这样的窃取方法,检查request.ServerVariables("HTTP_REFERER")不是本站的哄出去就可以了。
  另外,由于本人大学没毕业,又是学打铁的,所以肯定有很多垃圾的地方,请不吝指正,谢谢。