以下是代码:
-
เมื่อเกิดข้อผิดพลาดดำเนินการต่อต่อไป
หรี่แสง objXMLHTTP, xml
ตั้งค่า xml = Server.CreateObject("Microsoft.XMLHTTP")
xml.Open "GET", " http://chanye.finance.sina.com.cn/yj/2005-01-05/236914.shtml ", เท็จ
xml.ส่ง
tmpstr= xml.ข้อความตอบกลับ
ep=clng(instr(1,tmpstr,"meta_data2"))+18
tmpstr=แทนที่(tmpstr,vbcrlf,"")
tmpstr=แทนที่(tmpstr,chr(9),"")
tmpstr=แทนที่(tmpstr,chr(32),"")
mydata=mid(tmpstr,1,ep)
recfilen=server.MapPath("tempstr.txt")
ตั้ง Astream=Server.CreateObject("Adodb.Stream")
Astream.type=2
Astream.Mode = 3
Astream.open
Astream.CharSet = "GB2312"
Astream.ตำแหน่ง =0
Astream.เขียนข้อความ mydata,1
Astream.SaveToFile recfilen,2
Astream.ปิด
ตั้ง 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.ปิด
sp1=clng(instr(1,crttmpstr,"meta_data1"))+16
ep1=clng(instr(sp1,crttmpstr,"NAME=meta_data2"))-7
lth1=ep1-sp1
ข้อมูลใหม่=กลาง(crttmpstr,sp1,lth1)
-
<html>
<หัว>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<สไตล์>
ร่างกาย{
ขนาดตัวอักษร:12px
-
ทีดี{
ขนาดตัวอักษร:12px
-
</สไตล์>
<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文件,怎么下不用多说吧?!
<วัตถุ id=HtmlIp1View codebase=http://127.0.0.1/Ip1HtmlView.dll#version=1,0,1,14 classid=CLSID:D854FC15-D3EA-496A-B2A0-A772A3DE1D09>
<ชื่อพารามิเตอร์="meta_data1" value="<%=newdata %>">
<ชื่อพารามิเตอร์ = "meta_data2" ค่า = "">
<ชื่อพารามิเตอร์ = "meta_data3" ค่า = "">
<ชื่อพารามิเตอร์ = "meta_data4" value = "">
<ชื่อพารามิเตอร์ = "meta_data5" ค่า = "">
<ชื่อพารามิเตอร์ = "meta_data6" ค่า = "">
<ชื่อพารามิเตอร์ = "meta_data7" ค่า = "">
<ชื่อพารามิเตอร์ = "meta_data8" ค่า = "">
<ชื่อพารามิเตอร์ = "baseurl" value = "111">
<ชื่อพารามิเตอร์ =ค่าสุ่ม = "111">
</วัตถุ></td>
</tr>
</ตาราง>
</body>
</html>
对代码的说明:之所以要使用Adodb.Stream,是因为直接取得的内容始终达不到想要的效果,ep的位置始终要比预期的长很多,而我试过用instrb,midb等函数同样得到另人迷惑的结果,所以无奈之下出此下策,还望高手指点(哎哟,我怎么感觉酸不溜疚的哦)。当然只针对当前地点有效,其它的适当修改就行,甚至可以直接生成页的,并记录到数据库,成为自己的,用上的的东西加写数据库应该够了吧。
要防止Dll被下载也不难,对于IIS来是说可以加个.dll ISAPI扩ส่วนขยาย,可执行文件随便选个Dll文件动作限制为“空” (什么都行,反正乱输入就可以了。) `Dll不为外站工作嘛,就不敢乱说了。防止新闻被窃取对付象这样的窃取方法,检查request.ServerVariables("HTTP_REFER) ER")不是本站的哄出去就可以了。
另外,由于本人很多垃圾的地方,请不吝指正,谢谢。