写过论坛的朋友,特别是把路径放到数据里,然后在服务器端读取数据库里的字段,把路径信息动态的显示在客户端. 如过直接以 就会发现,直接把参数信息显示在Client端了.别有用心的人,可能会对你的服务器进行攻击 如果在Client这样显示. /* using System; //导入自定义的类库 namespace CHONGCHONG.XML RenderingXml=”<?xml version=1.0 encoding=gb2312?>\r\n”; if( sourParameter == null || sourParameter.Equals(“”) ) //开始分析路径里的&字符 destParameter.Append( startString ).Append(“?”).Append( paramName ).Append(“=”).Append( paramValue ) ; } /// <summary> for( int i = 0 ; i <= sourNameValue.Length-1 ; i++ ) //开始对NameValue加密 //存储加密后的路径字符串 //是否最后一个NameValue参数,若不是在路基里添加&参数连接符 return sb.ToString() ; } }
http://xxxx.xxxx.net/ShowForum.aspx?id=2&rootID=0&userName=myUserName
http://xxxx.xxxx.net/ShowForum.aspx?bdefEdGa=DEdscFDW&aHJdIDesk=esOddEsA&dsERsdwS=SdEEsaDY
下面我把这样实现的C#.net代码贴出,如大家要转载,请保留本人的版权。
*Description:加密路径信息后,输出到Client端
*Auther:天很蓝_崇崇
*Email:yc_chongchong@tom.com
*Dates:2005-01-18
*Copyright:ChongChong2008 YiChang HuBei China
*/
using System.Collections;
using System.ComponentModel;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.IO;
using System.Text;
using System.Text.RegularExpressions;
using System.Data.SqlClient;
using System.Configuration;
using _3Layer.DataLayer.DataCommon;
using _3Layer.DataLayer.DataCommon.DataAccess;
using Library.ClassLibrary.Crypt.DES;
public class RenderingXML : System.Web.UI.Page
{
/// <summary>
/// 从数据库预生成XML数据源
/// </summary>
private void PreRenderXML()
{
string strSQL = “select语句略去……………………;
myDataLayer.Open();
RenderingXml+=”<xml>\r\n”;
try
{
System.Data.SqlClient.SqlDataReader myDR = (SqlDataReader)myDataLayer.ExecuteReader( strSQL );
while(myDR.Read())
{
RenderingXml+=”<TreeNode id=”+myDR[“BoardID”]+”>\r\n”;
RenderingXml+=”<NodeText>”+myDR[“BoardName”]+”</NodeText>\r\n”;
RenderingXml+=”<title>”+myDR[“Title”]+”</title>\r\n”;
RenderingXml+=”<NodeUrl>”+EncodeHTML( EncodeParameter( myDR[“Link”].ToString() ) )+”</NodeUrl>\r\n”;
RenderingXml+=”<child>”+myDR[“children”]+”</child>\r\n”;
RenderingXml+=”<target>”+myDR[“Target”]+”</target>\r\n”;
RenderingXml+=”</TreeNode>\r\n”;
}
}
catch(System.Data.SqlClient.SqlException ee)
{
return ;
}
finally
{
myDataLayer.Close() ;
}
RenderingXml+=”</xml>”;
byte[] bytResult = Encoding.Default.GetBytes( RenderingXml ) ;
Response.ContentType = “text/xml” ;
Response.BinaryWrite( bytResult ) ;
}
/// <summary>
/// Description:加密路径参数
/// </summary>
/// <param name=”sourParameter”></param>
/// <returns></returns>
private string EncodeParameter( string sourParameter )
{
string startString = String.Empty ;
string endString = String.Empty ;
StringBuilder destParameter = new StringBuilder() ;
{
destParameter.Append( String.Empty ).ToString() ;
}
else
{
//开始分析路径里的?字符
if( sourParameter.IndexOf(“?”)<0 )
{
destParameter.Append( sourParameter ).ToString() ;
}
else
{
//以?号分割路径
string[] paramPath = sourParameter.Split( new char[]{?} ) ;
startString = paramPath[0].ToString() ;
endString = paramPath[1].ToString() ;
if(sourParameter.IndexOf(“&”)<0)
{
//只有一个参数,用=号分割,直接把NameValue进行Des加密
string[] paramNameValue = endString.Split( new char[]{=} ) ;
string paramName = myDES.Encrypt( paramNameValue[0].ToString() ,myDESKey ) ;
string paramValue = myDES.Encrypt( paramNameValue[1].ToString() ,myDESKey ) ;
}
else
{
//有多个参数,以&号分割?号后面的路径
string[] paramJoin = endString.Split( new char[]{&} ) ;
destParameter.Append( startString ).Append(“?”).Append( EncoderNameValue( paramJoin ) ) .ToString() ;
}
}
}
return destParameter.ToString() ;
/// Description:加密路径里的NameValue参数
/// </summary>
/// <param name=”sourNameValue”></param>
/// <returns></returns>
private string EncoderNameValue( string[] sourNameValue )
{
string[] paramNameValue ;
string paramName ;
string paramValue ;
StringBuilder sb = new StringBuilder() ;
{
//以=号分割每个NameValue参数
paramNameValue = sourNameValue[i].Split( new char[]{=} ) ;
paramName = myDES.Encrypt( paramNameValue[0].ToString() ,myDESKey ) ;
paramValue = myDES.Encrypt( paramNameValue[1].ToString() ,myDESKey ) ;
sb.Append( paramName ).Append(“=”).Append( paramValue ) ;
if( i<sourNameValue.Length )
{
sb.Append(“&”) ;
}
}
c#加密路径里的参数,保护参数隐私安全! _c#应用
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » c#加密路径里的参数,保护参数隐私安全! _c#应用
相关推荐
-      利用c#远程存取access数据库_c#应用
-      c# 3.0新特性系列:隐含类型var_c#教程
-      c#动态生成树型结构的web程序设计_c#应用
-      论c#变得越来越臃肿是不可避免的_c#应用
-      用c#监控并显示cpu状态信息_c#应用
-      c#中实现vb中的createobject方法_c#应用
-      photoshop给花瓶打造彩绘效果_photoshop教程
-      使用c#创建sql server的存储过程_c#应用