程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> SqlServer數據庫 >> 關於SqlServer >> 防止SQL注入完整ASP代碼

防止SQL注入完整ASP代碼

編輯:關於SqlServer

<%
Dim Fy_Url,Fy_a,Fy_x,Fy_Cs(),Fy_Cl,Fy_Ts,Fy_Zx
'---定義部份  頭------
Fy_Cl = 1  '處理方式:1=提示信息,2=轉向頁面,3=先提示再轉向
Fy_Zx = "Error.ASP" '出錯時轉向的頁面
'---定義部份  尾------

On Error Resume Next
Fy_Url=Request.ServerVariables("QUERY_STRING")
Fy_a=split(Fy_Url,"&")
redim Fy_Cs(ubound(Fy_a))
On Error Resume Next
for Fy_x=0 to ubound(Fy_a)
 Fy_Cs(Fy_x) = left(Fy_a(Fy_x),instr(Fy_a(Fy_x),"=")-1)
Next
For Fy_x=0 to ubound(Fy_Cs)
 If Fy_Cs(Fy_x)<>"" Then
  If Instr(LCase(Request(Fy_Cs(Fy_x))),"'")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),"and")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),"select")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),"update")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),"chr")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),"delete%20from")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),";")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),"insert")<>0 or Instr(LCase(Request(Fy_Cs(Fy_x))),"mid")<>0 Or Instr(LCase(Request(Fy_Cs(Fy_x))),"master.")<>0 Then
  Select Case Fy_Cl
    Case "1"
  Response.Write "<Script Language=JavaScript>alert('                   出現錯誤!參數 "&Fy_Cs(Fy_x)&" 的值中包含非法字符串!   請不要在參數中出現:;,and,select,update,insert,delete,chr 等非法字符! SQL通用防注入V1.0 ASP版 -- :;window.close();');window.close();</Script>"
    Case "2"
  Response.Write "<Script Language=JavaScript>location.href='"&Fy_Zx&"'</Script>"
    Case "3"
  Response.Write "<Script Language=JavaScript>alert('                   出現錯誤!參數 "&Fy_Cs(Fy_x)&"的值中包含非法字符串!   請不要在參數中出現:;,and,select,update,insert,delete,chr 等非法字符! SQL通用防注入V1.0 ASP版 -- ');location.href='"&Fy_Zx&"';');location.href='"&Fy_Zx&"';</Script>"
  End Select
  Response.End
  End If
 End If
Next
%>

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved