如何php代码转化为C#代码?

时间:2022-02-17 19:16:11
各位大神,小弟入行的月数可以用一个指头算出来,主要熟悉PHP,经验尚浅。 前不久利用DES加密代码写了一个类。现在,出于需求,我需要在短期内把这个类在.net平台上用C#重新写出来。我对.net以及C#毫无所知(当然知道有这么一个东西),请问大神们有什么办法可以把php无差错的转化为C#代码呢?

请大神们救救急,赐教工具、方法甚至代码。感激涕零。这里问问题,好像最多是100分,我就全加上。
下面是php代码:


<?php
require_once ("../basic/db_site.php");

class DES_Class
{
const ConstantKey = 'MMM';
const ConstantIV = 'UUU';

private $key = "";   
private $iv = "";   

function __construct ()     
{

$this->key = $this->stringArrKey(base64_encode(self::ConstantKey));

$this->iv = $this->stringArrIv(self::ConstantIV);                //$this->stringArrIv($iv);

}

private function stringArrKey($inputStr)
{

$stringArray[]=array(); 

$inputStr=ltrim($inputStr);

$inputStr=rtrim($inputStr);

$stringArray=str_split($inputStr);  

$strLength=strlen($inputStr);   
$strOutput[]=array();   

if ($strLength<8)
{

for ($i=0;$i<$strLength;$i++)
{
$strOutput[$i]=$stringArray[$i];

}

for ($i=$strLength;$i<8;$i++)
{
$strOutput[$i]='0';         
}

}
else if ($strLength>8)
{
for ($i=0;$i<8;$i++)
{
$strOutput[$i]=$stringArray[$i];   
}
}

$strOutputFinal=implode("",$strOutput); 

return $strOutputFinal;

}




public function CreateLic($message)
{

$messageArr[] = array();

$messageReplace[] = array();

$messageArr=str_split($message);

for ($i=0;$i<5;$i++)
{
$messageReplace[$i] = $messageArr[5+$i];
}

for ($i=0;$i<5;$i++)
{
$messageReplace[5+$i] = $messageArr[$i];

}
$messageReplace[10] = $messageArr[10];

for ($i=0;$i<5;$i++)
{
$messageReplace[11+$i] = $messageArr[16+$i];

}

for ($i=0;$i<5;$i++)
{
$messageReplace[16+$i] = $messageArr[11+$i];

}

$message=implode("",$messageReplace);


$td = mcrypt_module_open(MCRYPT_3DES, '', MCRYPT_MODE_CBC, '');

$iv = base64_decode($this->iv);

$message = $this->PaddingPKCS7($message);

$key = base64_decode($this->key);

mcrypt_generic_init($td, $key, $iv);

$result  = base64_encode(mcrypt_generic($td, $message));

mcrypt_generic_deinit($td);

mcrypt_module_close($td);

return $result;
}


/***decode part-------public function*/
public function GetMessage ($license)
{

$td = mcrypt_module_open(MCRYPT_3DES, '', MCRYPT_MODE_CBC, '');

$iv = base64_decode($this->iv);

$key = base64_decode($this->key);

mcrypt_generic_init($td, $key, $iv);

$result = trim(mdecrypt_generic($td, base64_decode($license)));

$result = $this->UnPaddingPKCS7($result);

mcrypt_generic_deinit($td);

mcrypt_module_close($td);


$licenseArr[] = array();

$licenseReplace[] = array();

$licenseArr=str_split($result);

for ($i=0;$i<5;$i++)
{
$licenseReplace[$i] = $licenseArr[5+$i];
}

for ($i=0;$i<5;$i++)
{
$licenseReplace[5+$i] = $licenseArr[$i];

}
$licenseReplace[10] = $licenseArr[10];

for ($i=0;$i<5;$i++)
{
$licenseReplace[11+$i] = $licenseArr[16+$i];

}

for ($i=0;$i<5;$i++)
{
$licenseReplace[16+$i] = $licenseArr[11+$i];

}

$result = implode("",$licenseReplace);

return $result;
}


private function PaddingPKCS7 ($data)
{

$block_size = mcrypt_get_block_size('tripledes', 'cbc');

$padding_char = $block_size - (strlen($data) % $block_size);

$data .= str_repeat(chr($padding_char), $padding_char);

return $data;
}

private function UnPaddingPKCS7($text)
{

$pad = ord($text{strlen($text) - 1});

if ($pad > strlen($text))
{

return false;
}

if (strspn($text, chr($pad), strlen($text) - $pad) != $pad)
{
return false;
}

return substr($text, 0, - 1 * $pad);
}



private function stringArrIv($inputStr)
{

$stringArray[]=array();

$inputStr=ltrim($inputStr);

$inputStr=rtrim($inputStr);

$stringArray=str_split($inputStr);  

$strLength=strlen($inputStr);    

$strOutput[]=array();   

if ($strLength<11)
{
for ($i=0;$i<$strLength;$i++)
{
$strOutput[$i]=$stringArray[$i];

}


for ($i=$strLength;$i<11;$i++)
{
$strOutput[$i]='0';
}

}
else if ($strLength>11)
{
for ($i=0;$i<11;$i++)
{
$strOutput[$i]=$stringArray[$i];
}
}

$strOutputFinal = implode("",$strOutput);  

return $strOutputFinal;

}

public function outputPermit($license)
{
$clearMessage = $this->GetMessage($license);

$strArr[]=array();

$strArr=str_split($clearMessage);

$letter = $strArr[0];

return $letter;

}
public function outputUserNum($license)
{
$clearMessage = $this->GetMessage($license);

$strArr[]=array();

$strArr=str_split($clearMessage);

$strNum[]=array();

for ($i=1;$i<5;$i++)
{
$strNum[$i-1]=$strArr[$i];

}

$str_Num = implode("",$strNum);

$num = (int)$str_Num;

return $num;

}

public function outputStartDay($license)
{
$clearMessage = $this->GetMessage($license);

$strArr[] = array();

$strArr = str_split($clearMessage);

$strStartDay[] = array();

$str_Num[] = array();

for ($i=5;$i<13;$i++)
{
$strStartDay[$i-5]=$strArr[$i];

}

for ($i=0;$i<4;$i++)
{
$str_Num[$i] = $strStartDay[$i];
}

$str_Num[4] = "-";

for ($i=5;$i<7;$i++)
{
$str_Num[$i] = $strStartDay[$i-1];
}

$str_Num[7] = "-";

for ($i=8;$i<10;$i++)
{
$str_Num[$i] = $strStartDay[$i-2];
}

$str_Num = implode("",$str_Num);   

return $str_Num;     

}

public function outputEndDay($license)
{
$clearMessage = $this->GetMessage($license);

$strArr[] = array();

$strArr = str_split($clearMessage);

$strEndDay[] = array();

$str_Num[] = array();

for ($i=13;$i<21;$i++)
{
$strEndDay[$i-13]=$strArr[$i];

}

for ($i=0;$i<4;$i++)
{
$str_Num[$i] = $strEndDay[$i];
}

$str_Num[4] = "-";

for ($i=5;$i<7;$i++)
{
$str_Num[$i] = $strEndDay[$i-1];
}

$str_Num[7] = "-";

for ($i=8;$i<10;$i++)
{
$str_Num[$i] = $strEndDay[$i-2];
}


$str_Num = implode("",$str_Num);


return $str_Num;    

}


public function outStartDay_num($license)
{
$clearMessage = $this->GetMessage($license);

$strArr[] = array();

$strArr = str_split($clearMessage);

$strStartDay[] = array();

for ($i=5;$i<13;$i++)
{
$strStartDay[$i-5]=$strArr[$i];

}

$str_Num = implode("",$strStartDay);   

$num = (int)$str_Num;

return $num;     

}


public function outEndDay_num ($license)
{
$clearMessage = $this->GetMessage($license);

$strArr[] = array();

$strArr = str_split($clearMessage);

$strEndDay[] = array();

for ($i=13;$i<21;$i++)
{
$strEndDay[$i-13]=$strArr[$i];

}

$str_Num = implode("",$strEndDay);

$num = (int)$str_Num;

return $num;     
}


function db_connect()
{

$con = mysqli_connect("localhost", "root", "root") or die ("You cannot connect the database!<br>".mysqli_error());

return $con;
}




public function user_count()
{
$con =$this-> db_connect();

$count_sql = "SELECT * FROM transport.user";

$result = mysqli_query($con,$count_sql);

$totalNum =  mysqli_num_rows($result);

mysqli_close($con);

return $totalNum;

}
function getAll($query)
{
$con =$this-> db_connect();

$result = mysqli_query($con,$query);

if ($result)
$count = mysqli_num_rows($result);

$data = array();

for($i=0;$i<$count;$i++)
{
mysqli_data_seek($result,$i);
$data[$i] = mysqli_fetch_assoc($result);
}

mysqli_close($con);
return $data;

}



public function getLicense()
{

$con =$this->db_connect();

$count_sql = "SELECT license FROM transport.license ORDER BY No";

$datas =$this-> getAll($count_sql);

$new_Lic="";

foreach ($datas as $each)
$new_Lic = $each['license'];

mysqli_close($con);

return $new_Lic;


}

public function checkResult()
{
$existed_num = $this->user_count();
$license =  $this->getLicense();
$allowed_num =  $this->outputUserNum($license);

if ($existed_num < $allowed_num)
{
return true;
}
else
{
return false;
}

}


public function inputLic($license)
{
$con = $this->db_connect();

$insert_sql = "INSERT INTO transport.license (license) VALUES ('$license')";

$result = mysqli_query($con,$insert_sql);

mysqli_close($con);

if ($result)
{
return true;
}
else
{
return false;
}

}

public function checkExpiration($license)
{
$start = $this->outStartDay_num($license);

$end = $this-> outEndDay_num($license);

date_default_timezone_set('Europe/Paris');

$nowDay = (int)date("Ymd");

if (($nowDay >= $start) && ($nowDay <= $end))
{
return true;
}
else
{
return false;
}

}




}



function longinCheck()
{
$obj_login = new DES_Class();

$license = $obj_login->getLicense();

$time_period = $obj_login->checkExpiration($license);

if ($time_period)
{
return true;
}
else
{
return false;
}


}




?>

9 个解决方案

#1


再自学下C#,重新写一个吧。

#2


看不懂hph的 如何php代码转化为C#代码?,就下面这个,应该差不多



  public sealed class DESEncryption
    {
        private static readonly string encryptKey = "YJSERVER";
        private static readonly string decryptKey = "YJSERVER";
        
        #region**********Method*******************************

        /// <summary> 
        /// 加密字符串 
        /// 注意:密钥必须为8位 
        /// </summary> 
        /// <param name="strText">字符串</param> 
        /// <param name="encryptKey">密钥</param>
        /// <return>加密后字符串</return>
        public static string DesEncrypt(string strText) 
        {
            string outString="";
            byte[] byKey=null; 
            byte[] IV= {0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF}; 
            try 
            {
                byKey = System.Text.Encoding.UTF8.GetBytes(encryptKey.Substring(0, encryptKey.Length)); 
                DESCryptoServiceProvider des = new DESCryptoServiceProvider();
                byte[] inputByteArray = Encoding.UTF8.GetBytes(strText); 
                MemoryStream ms = new MemoryStream(); 
                CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(byKey, IV), CryptoStreamMode.Write) ; 
                cs.Write(inputByteArray, 0, inputByteArray.Length); 
                cs.FlushFinalBlock();
                outString = Convert.ToBase64String(ms.ToArray()); 
            } 
            catch(System.Exception) 
            {
                outString = ""; 
            }

            return outString;
        } 

        /// <summary> 
        /// 解密字符串 
        /// </summary> 
        /// <param name="strText">加了密的字符串</param> 
        /// <param name="decryptKey">密钥</param> 
        public static string DesDecrypt(string strText) 
        {
            string outString = "";
            byte[] byKey = null; 
            byte[] IV= {0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF};
            byte[] inputByteArray = new Byte[strText.Length]; 
            try 
            {
                byKey = System.Text.Encoding.UTF8.GetBytes(decryptKey.Substring(0, decryptKey.Length)); 
                DESCryptoServiceProvider des = new DESCryptoServiceProvider();
                inputByteArray = Convert.FromBase64String(strText); 
                MemoryStream ms = new MemoryStream(); 
                CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(byKey, IV), CryptoStreamMode.Write); 
                cs.Write(inputByteArray, 0, inputByteArray.Length); 
                cs.FlushFinalBlock(); 
                System.Text.Encoding encoding = new System.Text.UTF8Encoding(); 
                outString = encoding.GetString(ms.ToArray()); 
            } 
            catch(System.Exception) 
            {
                outString = ""; 
            }

            return outString;
        } 

        #endregion

    }
}

#3


某代码生成器里复制出来的:

如何php代码转化为C#代码?


/// <summary>
/// DES加密/解密类。
/// </summary>
public class DESEncrypt
{
public DESEncrypt()
{
}

#region ========加密======== 
 
        /// <summary>
        /// 加密
        /// </summary>
        /// <param name="Text"></param>
        /// <returns></returns>
public static string Encrypt(string Text) 
{
            return Encrypt(Text, "密钥");
}
/// <summary> 
/// 加密数据 
/// </summary> 
/// <param name="Text"></param> 
/// <param name="sKey"></param> 
/// <returns></returns> 
public static string Encrypt(string Text,string sKey) 

DESCryptoServiceProvider des = new DESCryptoServiceProvider(); 
byte[] inputByteArray; 
inputByteArray=Encoding.Default.GetBytes(Text); 
des.Key = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8)); 
des.IV = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8)); 
System.IO.MemoryStream ms=new System.IO.MemoryStream(); 
CryptoStream cs=new CryptoStream(ms,des.CreateEncryptor(),CryptoStreamMode.Write); 
cs.Write(inputByteArray,0,inputByteArray.Length); 
cs.FlushFinalBlock(); 
StringBuilder ret=new StringBuilder(); 
foreach( byte b in ms.ToArray()) 

ret.AppendFormat("{0:X2}",b); 

return ret.ToString(); 


#endregion

#region ========解密======== 
   
 
        /// <summary>
        /// 解密
        /// </summary>
        /// <param name="Text"></param>
        /// <returns></returns>
public static string Decrypt(string Text) 
{
            return Decrypt(Text, "密钥");
}
/// <summary> 
/// 解密数据 
/// </summary> 
/// <param name="Text"></param> 
/// <param name="sKey"></param> 
/// <returns></returns> 
public static string Decrypt(string Text,string sKey) 

DESCryptoServiceProvider des = new DESCryptoServiceProvider(); 
int len; 
len=Text.Length/2; 
byte[] inputByteArray = new byte[len]; 
int x,i; 
for(x=0;x<len;x++) 

i = Convert.ToInt32(Text.Substring(x * 2, 2), 16); 
inputByteArray[x]=(byte)i; 

des.Key = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8)); 
des.IV = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8)); 
System.IO.MemoryStream ms=new System.IO.MemoryStream(); 
CryptoStream cs=new CryptoStream(ms,des.CreateDecryptor(),CryptoStreamMode.Write); 
cs.Write(inputByteArray,0,inputByteArray.Length); 
cs.FlushFinalBlock(); 
return Encoding.Default.GetString(ms.ToArray()); 

 
#endregion 


}

#4


谢谢版主前来指导。

我也搜到过类似代码。其实吧,一般的算法也没有这么难。但有两个问题能否请大神们具体讲解一下:
1. 上面版主已经提供了加密和解密的代码,能否在此基础上弄个最简单的demo,就是输入什么、输出什么。各位大神别见怪,我对C#目前一无所知,有个基本输入输出demo,我就可以在基本输入输出上进行修改了。要知道,今天第一次接触C#,我在visual studio 上搞一个hello world的程序都没成,太多选择项,也不知道新建哪个文件类型。

2.算法描述,我倒不怕,因为照着描述就行。但连接数据库的动作,估计要花好多时间才能学懂会弄。
所以,各位大神,能否就下面最简单的一个连接数据库的几行php代码,写个相应C#代码?万分感谢。

public function inputLic($license)
{
$con = $this->db_connect();
$insert_sql = "INSERT INTO transport.license (license) VALUES ('$license')";
$result = mysqli_query($con,$insert_sql);
mysqli_close($con);
if ($result)
{
return true;
}
else
{
return false;
}
}

另外,还有这个语句:

$count_sql = "SELECT license FROM transport.license ORDER BY No";
$datas =$this-> getAll($count_sql);


谢谢各位大神,感激啊!!!


引用 2 楼 happy09li 的回复:
看不懂hph的 如何php代码转化为C#代码?,就下面这个,应该差不多

#5


.net有自己的算法,要转换非常难,必须精通2种语言,即使你给1000元人民币,也不见得有人愿意这么做,更何况这里只是提供免费帮助的论坛,不是外包单位。
我尝试了1个小时研究了你的代码,代码写得是故意不让人看懂,格式化错乱,对字符串处处使用base64编码解码,在.NET里面,只有涉及到字节数组才会考虑到base64。故而放弃,你重新考虑方法吧,建议按照需求写全新的.NET方法会更容易,如果是我,直接放弃转换,非常不值得。

#6


数据库操作部分你可以看看ADO.NET,参考: http://msdn.microsoft.com/ZH-CN/library/vstudio/system.data.sqlclient.sqlcommand(v=vs.110).aspx
如果是对MySql操作,还要单独到MySql官网下载.NET连接驱动,而这个操作是异曲同工,你学会了SqlServer的操作,MySql只要更换类名即可,连参数定义都是一样的。

#7


感谢大神花了这么多时间。谢谢你的建议啊。

大神啊,冤枉。如果没有转换工具,我是准备自己做的。而且,上面的算法是在DES算法基础上,加入了我个人的算法,主要是为了安全性。可能是我的水平过滥,写的不清楚所以你不是看的太懂。不过,其实一些细节,是为了满足DES算法程序调试后出现的bug而设定的,有点繁复,但绝对可靠。

这么一来,我只求一个C#加密程序基础上(版主的回复已经给出)的一个最最简单的demo和一些连接数据库语句的简单示例。我就可以在此基础上修改输入输出。

再次重申,到这里来,碰到热心大神很多,而且确实帮助到我,但我绝对没有想做伸手不动的猿类。


引用 5 楼 qldsrx 的回复:
.net有自己的算法,要转换非常难,必须精通2种语言,即使你给1000元人民币,也不见得有人愿意这么做,更何况这里只是提供免费帮助的论坛,不是外包单位。
我尝试了1个小时研究了你的代码,代码写得是故意不让人看懂,格式化错乱,对字符串处处使用base64编码解码,在.NET里面,只有涉及到字节数组才会考虑到base64。故而放弃,你重新考虑方法吧,建议按照需求写全新的.NET方法会更容易,如果是我,直接放弃转换,非常不值得。

#8


引用 6 楼 qldsrx 的回复:
数据库操作部分你可以看看ADO.NET,参考: http://msdn.microsoft.com/ZH-CN/library/vstudio/system.data.sqlclient.sqlcommand(v=vs.110).aspx
如果是对MySql操作,还要单独到MySql官网下载.NET连接驱动,而这个操作是异曲同工,你学会了SqlServer的操作,MySql只要更换类名即可,连参数定义都是一样的。



谢谢先,我研究后,就回来结贴。

感谢qldsrx,没想到用了这么多时间。  如何php代码转化为C#代码?

#9


感谢上面各位的建议,但对这个问题的解决都没有帮助。

通过自己努力,我建立了php和C#的加密和解密平台。

不管如何,还是见者有份,都把分给散了吧。

#1


再自学下C#,重新写一个吧。

#2


看不懂hph的 如何php代码转化为C#代码?,就下面这个,应该差不多



  public sealed class DESEncryption
    {
        private static readonly string encryptKey = "YJSERVER";
        private static readonly string decryptKey = "YJSERVER";
        
        #region**********Method*******************************

        /// <summary> 
        /// 加密字符串 
        /// 注意:密钥必须为8位 
        /// </summary> 
        /// <param name="strText">字符串</param> 
        /// <param name="encryptKey">密钥</param>
        /// <return>加密后字符串</return>
        public static string DesEncrypt(string strText) 
        {
            string outString="";
            byte[] byKey=null; 
            byte[] IV= {0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF}; 
            try 
            {
                byKey = System.Text.Encoding.UTF8.GetBytes(encryptKey.Substring(0, encryptKey.Length)); 
                DESCryptoServiceProvider des = new DESCryptoServiceProvider();
                byte[] inputByteArray = Encoding.UTF8.GetBytes(strText); 
                MemoryStream ms = new MemoryStream(); 
                CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(byKey, IV), CryptoStreamMode.Write) ; 
                cs.Write(inputByteArray, 0, inputByteArray.Length); 
                cs.FlushFinalBlock();
                outString = Convert.ToBase64String(ms.ToArray()); 
            } 
            catch(System.Exception) 
            {
                outString = ""; 
            }

            return outString;
        } 

        /// <summary> 
        /// 解密字符串 
        /// </summary> 
        /// <param name="strText">加了密的字符串</param> 
        /// <param name="decryptKey">密钥</param> 
        public static string DesDecrypt(string strText) 
        {
            string outString = "";
            byte[] byKey = null; 
            byte[] IV= {0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF};
            byte[] inputByteArray = new Byte[strText.Length]; 
            try 
            {
                byKey = System.Text.Encoding.UTF8.GetBytes(decryptKey.Substring(0, decryptKey.Length)); 
                DESCryptoServiceProvider des = new DESCryptoServiceProvider();
                inputByteArray = Convert.FromBase64String(strText); 
                MemoryStream ms = new MemoryStream(); 
                CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(byKey, IV), CryptoStreamMode.Write); 
                cs.Write(inputByteArray, 0, inputByteArray.Length); 
                cs.FlushFinalBlock(); 
                System.Text.Encoding encoding = new System.Text.UTF8Encoding(); 
                outString = encoding.GetString(ms.ToArray()); 
            } 
            catch(System.Exception) 
            {
                outString = ""; 
            }

            return outString;
        } 

        #endregion

    }
}

#3


某代码生成器里复制出来的:

如何php代码转化为C#代码?


/// <summary>
/// DES加密/解密类。
/// </summary>
public class DESEncrypt
{
public DESEncrypt()
{
}

#region ========加密======== 
 
        /// <summary>
        /// 加密
        /// </summary>
        /// <param name="Text"></param>
        /// <returns></returns>
public static string Encrypt(string Text) 
{
            return Encrypt(Text, "密钥");
}
/// <summary> 
/// 加密数据 
/// </summary> 
/// <param name="Text"></param> 
/// <param name="sKey"></param> 
/// <returns></returns> 
public static string Encrypt(string Text,string sKey) 

DESCryptoServiceProvider des = new DESCryptoServiceProvider(); 
byte[] inputByteArray; 
inputByteArray=Encoding.Default.GetBytes(Text); 
des.Key = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8)); 
des.IV = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8)); 
System.IO.MemoryStream ms=new System.IO.MemoryStream(); 
CryptoStream cs=new CryptoStream(ms,des.CreateEncryptor(),CryptoStreamMode.Write); 
cs.Write(inputByteArray,0,inputByteArray.Length); 
cs.FlushFinalBlock(); 
StringBuilder ret=new StringBuilder(); 
foreach( byte b in ms.ToArray()) 

ret.AppendFormat("{0:X2}",b); 

return ret.ToString(); 


#endregion

#region ========解密======== 
   
 
        /// <summary>
        /// 解密
        /// </summary>
        /// <param name="Text"></param>
        /// <returns></returns>
public static string Decrypt(string Text) 
{
            return Decrypt(Text, "密钥");
}
/// <summary> 
/// 解密数据 
/// </summary> 
/// <param name="Text"></param> 
/// <param name="sKey"></param> 
/// <returns></returns> 
public static string Decrypt(string Text,string sKey) 

DESCryptoServiceProvider des = new DESCryptoServiceProvider(); 
int len; 
len=Text.Length/2; 
byte[] inputByteArray = new byte[len]; 
int x,i; 
for(x=0;x<len;x++) 

i = Convert.ToInt32(Text.Substring(x * 2, 2), 16); 
inputByteArray[x]=(byte)i; 

des.Key = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8)); 
des.IV = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8)); 
System.IO.MemoryStream ms=new System.IO.MemoryStream(); 
CryptoStream cs=new CryptoStream(ms,des.CreateDecryptor(),CryptoStreamMode.Write); 
cs.Write(inputByteArray,0,inputByteArray.Length); 
cs.FlushFinalBlock(); 
return Encoding.Default.GetString(ms.ToArray()); 

 
#endregion 


}

#4


谢谢版主前来指导。

我也搜到过类似代码。其实吧,一般的算法也没有这么难。但有两个问题能否请大神们具体讲解一下:
1. 上面版主已经提供了加密和解密的代码,能否在此基础上弄个最简单的demo,就是输入什么、输出什么。各位大神别见怪,我对C#目前一无所知,有个基本输入输出demo,我就可以在基本输入输出上进行修改了。要知道,今天第一次接触C#,我在visual studio 上搞一个hello world的程序都没成,太多选择项,也不知道新建哪个文件类型。

2.算法描述,我倒不怕,因为照着描述就行。但连接数据库的动作,估计要花好多时间才能学懂会弄。
所以,各位大神,能否就下面最简单的一个连接数据库的几行php代码,写个相应C#代码?万分感谢。

public function inputLic($license)
{
$con = $this->db_connect();
$insert_sql = "INSERT INTO transport.license (license) VALUES ('$license')";
$result = mysqli_query($con,$insert_sql);
mysqli_close($con);
if ($result)
{
return true;
}
else
{
return false;
}
}

另外,还有这个语句:

$count_sql = "SELECT license FROM transport.license ORDER BY No";
$datas =$this-> getAll($count_sql);


谢谢各位大神,感激啊!!!


引用 2 楼 happy09li 的回复:
看不懂hph的 如何php代码转化为C#代码?,就下面这个,应该差不多

#5


.net有自己的算法,要转换非常难,必须精通2种语言,即使你给1000元人民币,也不见得有人愿意这么做,更何况这里只是提供免费帮助的论坛,不是外包单位。
我尝试了1个小时研究了你的代码,代码写得是故意不让人看懂,格式化错乱,对字符串处处使用base64编码解码,在.NET里面,只有涉及到字节数组才会考虑到base64。故而放弃,你重新考虑方法吧,建议按照需求写全新的.NET方法会更容易,如果是我,直接放弃转换,非常不值得。

#6


数据库操作部分你可以看看ADO.NET,参考: http://msdn.microsoft.com/ZH-CN/library/vstudio/system.data.sqlclient.sqlcommand(v=vs.110).aspx
如果是对MySql操作,还要单独到MySql官网下载.NET连接驱动,而这个操作是异曲同工,你学会了SqlServer的操作,MySql只要更换类名即可,连参数定义都是一样的。

#7


感谢大神花了这么多时间。谢谢你的建议啊。

大神啊,冤枉。如果没有转换工具,我是准备自己做的。而且,上面的算法是在DES算法基础上,加入了我个人的算法,主要是为了安全性。可能是我的水平过滥,写的不清楚所以你不是看的太懂。不过,其实一些细节,是为了满足DES算法程序调试后出现的bug而设定的,有点繁复,但绝对可靠。

这么一来,我只求一个C#加密程序基础上(版主的回复已经给出)的一个最最简单的demo和一些连接数据库语句的简单示例。我就可以在此基础上修改输入输出。

再次重申,到这里来,碰到热心大神很多,而且确实帮助到我,但我绝对没有想做伸手不动的猿类。


引用 5 楼 qldsrx 的回复:
.net有自己的算法,要转换非常难,必须精通2种语言,即使你给1000元人民币,也不见得有人愿意这么做,更何况这里只是提供免费帮助的论坛,不是外包单位。
我尝试了1个小时研究了你的代码,代码写得是故意不让人看懂,格式化错乱,对字符串处处使用base64编码解码,在.NET里面,只有涉及到字节数组才会考虑到base64。故而放弃,你重新考虑方法吧,建议按照需求写全新的.NET方法会更容易,如果是我,直接放弃转换,非常不值得。

#8


引用 6 楼 qldsrx 的回复:
数据库操作部分你可以看看ADO.NET,参考: http://msdn.microsoft.com/ZH-CN/library/vstudio/system.data.sqlclient.sqlcommand(v=vs.110).aspx
如果是对MySql操作,还要单独到MySql官网下载.NET连接驱动,而这个操作是异曲同工,你学会了SqlServer的操作,MySql只要更换类名即可,连参数定义都是一样的。



谢谢先,我研究后,就回来结贴。

感谢qldsrx,没想到用了这么多时间。  如何php代码转化为C#代码?

#9


感谢上面各位的建议,但对这个问题的解决都没有帮助。

通过自己努力,我建立了php和C#的加密和解密平台。

不管如何,还是见者有份,都把分给散了吧。