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

歪着看世界 2013-09-30 04:47: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;
}


}




?>

...全文
535 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
歪着看世界 2013-10-17
  • 打赏
  • 举报
回复
感谢上面各位的建议,但对这个问题的解决都没有帮助。 通过自己努力,我建立了php和C#的加密和解密平台。 不管如何,还是见者有份,都把分给散了吧。
歪着看世界 2013-09-30
  • 打赏
  • 举报
回复
引用 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,没想到用了这么多时间。
歪着看世界 2013-09-30
  • 打赏
  • 举报
回复
感谢大神花了这么多时间。谢谢你的建议啊。 大神啊,冤枉。如果没有转换工具,我是准备自己做的。而且,上面的算法是在DES算法基础上,加入了我个人的算法,主要是为了安全性。可能是我的水平过滥,写的不清楚所以你不是看的太懂。不过,其实一些细节,是为了满足DES算法程序调试后出现的bug而设定的,有点繁复,但绝对可靠。 这么一来,我只求一个C#加密程序基础上(版主的回复已经给出)的一个最最简单的demo和一些连接数据库语句的简单示例。我就可以在此基础上修改输入输出。 再次重申,到这里来,碰到热心大神很多,而且确实帮助到我,但我绝对没有想做伸手不动的猿类。
引用 5 楼 qldsrx 的回复:
.net有自己的算法,要转换非常难,必须精通2种语言,即使你给1000元人民币,也不见得有人愿意这么做,更何况这里只是提供免费帮助的论坛,不是外包单位。 我尝试了1个小时研究了你的代码,代码写得是故意不让人看懂,格式化错乱,对字符串处处使用base64编码解码,在.NET里面,只有涉及到字节数组才会考虑到base64。故而放弃,你重新考虑方法吧,建议按照需求写全新的.NET方法会更容易,如果是我,直接放弃转换,非常不值得。
qldsrx 2013-09-30
  • 打赏
  • 举报
回复
数据库操作部分你可以看看ADO.NET,参考:http://msdn.microsoft.com/ZH-CN/library/vstudio/system.data.sqlclient.sqlcommand(v=vs.110).aspx 如果是对MySql操作,还要单独到MySql官网下载.NET连接驱动,而这个操作是异曲同工,你学会了SqlServer的操作,MySql只要更换类名即可,连参数定义都是一样的。
qldsrx 2013-09-30
  • 打赏
  • 举报
回复
.net有自己的算法,要转换非常难,必须精通2种语言,即使你给1000元人民币,也不见得有人愿意这么做,更何况这里只是提供免费帮助的论坛,不是外包单位。 我尝试了1个小时研究了你的代码,代码写得是故意不让人看懂,格式化错乱,对字符串处处使用base64编码解码,在.NET里面,只有涉及到字节数组才会考虑到base64。故而放弃,你重新考虑方法吧,建议按照需求写全新的.NET方法会更容易,如果是我,直接放弃转换,非常不值得。
歪着看世界 2013-09-30
  • 打赏
  • 举报
回复
谢谢版主前来指导。 我也搜到过类似代码。其实吧,一般的算法也没有这么难。但有两个问题能否请大神们具体讲解一下: 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的,就下面这个,应该差不多
  • 打赏
  • 举报
回复
某代码生成器里复制出来的:

	/// <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 


	}
熙风 2013-09-30
  • 打赏
  • 举报
回复
看不懂hph的,就下面这个,应该差不多


  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

    }
}

wangjcltj 2013-09-30
  • 打赏
  • 举报
回复
再自学下C#,重新写一个吧。

110,570

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧