当前位置:编程学习 > C#/ASP.NET >>

JQ传参数到ASP.NET一般处理程序中

请问下 我用JQ传参数 (这里要传的是一个数据库列名) 到一般处理程序中 用的是MD5 加密的 在一般处理程序那边 有没有办法解密出来呢 然后在数据库中查找  如果MD5无法解密 那么有什么办法 可以解密我JQ 传的参数呢 然后再到一般处理程序程序中解密呢  ASP.NET项目中的
 $.ajax({type:"post",url:"server.ashx",
    data:"{person:+$("#txtLwPerson").val()} 有没有办法加密 person字段的值 然后到 server.ashx解密出来 去查询数据库呢
" --------------------编程问答-------------------- 有加密的必要么? --------------------编程问答-------------------- 最多编码解码下! --------------------编程问答-------------------- MD5是散列算法,可以做单向加密,不能解密
如果确定需要加密的话,可以尝试js调用微软的CAPICOM,是ActiveX控件,浏览器兼容性问题哦 --------------------编程问答-------------------- 传到后台在加密 --------------------编程问答-------------------- MD5 是没有解密的。可以换其它的


using System;
using System.Text;
using System.Security.Cryptography;
using System.IO;

//默认密钥向量
private static byte[] Keys = { 0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF };
/// <summary>
/// DES加密字符串
/// </summary>
/// <param name="encryptString">待加密的字符串</param>
/// <param name="encryptKey">加密密钥,要求为8位</param>
/// <returns>加密成功返回加密后的字符串,失败返回源串</returns>
public static string EncryptDES(string encryptString, string encryptKey)
{
    try
    {
        byte[] rgbKey = Encoding.UTF8.GetBytes(encryptKey.Substring(0, 8));
        byte[] rgbIV = Keys;
        byte[] inputByteArray = Encoding.UTF8.GetBytes(encryptString);
        DESCryptoServiceProvider dCSP = new DESCryptoServiceProvider();
        MemoryStream mStream = new MemoryStream();
        CryptoStream cStream = new CryptoStream(mStream, dCSP.CreateEncryptor(rgbKey, rgbIV), CryptoStreamMode.Write);
        cStream.Write(inputByteArray, 0, inputByteArray.Length);
        cStream.FlushFinalBlock();
        return Convert.ToBase64String(mStream.ToArray());
    }
    catch
    {
        return encryptString;
    }
}

/// <summary>
/// DES解密字符串
/// </summary>
/// <param name="decryptString">待解密的字符串</param>
/// <param name="decryptKey">解密密钥,要求为8位,和加密密钥相同</param>
/// <returns>解密成功返回解密后的字符串,失败返源串</returns>
public static string DecryptDES(string decryptString, string decryptKey)
{
    try
    {
        byte[] rgbKey = Encoding.UTF8.GetBytes(decryptKey);
        byte[] rgbIV = Keys;
        byte[] inputByteArray = Convert.FromBase64String(decryptString);
        DESCryptoServiceProvider DCSP = new DESCryptoServiceProvider();
        MemoryStream mStream = new MemoryStream();
        CryptoStream cStream = new CryptoStream(mStream, DCSP.CreateDecryptor(rgbKey, rgbIV), CryptoStreamMode.Write);
        cStream.Write(inputByteArray, 0, inputByteArray.Length);
        cStream.FlushFinalBlock();
        return Encoding.UTF8.GetString(mStream.ToArray());
    }
    catch
    {
        return decryptString;
    }
}
--------------------编程问答--------------------
引用 5 楼 gdjlc 的回复:
MD5 是没有解密的。可以换其它的

C# code

using System;
using System.Text;
using System.Security.Cryptography;
using System.IO;

//默认密钥向量
private static byte[] Keys = { 0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD,……


JQ不知道怎么调用 这个加密的类 --------------------编程问答-------------------- 我传的是数据的字段啊 当然要加密啦 不然很容易被攻击吧 --------------------编程问答-------------------- js 加密 ,c#解密 ? --------------------编程问答-------------------- 你既然要传 .就必然会在前台显示.都显示了加密个P啊..
要是不显示.
你就这样咯
ID对应1,传值的时候就价格q1=1
userName对应2.传值的时候就q2=2
在ashx中获取QueryString,然后判断是哪个

MD5加密....lz好有才.
可以很容易解密的话就真特么太爽了 --------------------编程问答--------------------
引用 7 楼 bibilian 的回复:
我传的是数据的字段啊 当然要加密啦 不然很容易被攻击吧


那就用编码,没必要加密。编码如:URIencode(字段)
补充:.NET技术 ,  ASP.NET
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,