TestSecurity.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: stanley-king
  5. * Date: 2018/12/12
  6. * Time: 11:01 AM
  7. */
  8. define('BASE_ROOT_PATH',str_replace('/test','',dirname(__FILE__)));
  9. require_once(BASE_ROOT_PATH . '/fooder.php');
  10. require_once(BASE_ROOT_PATH . '/helper/event_looper.php');
  11. require_once(BASE_ROOT_PATH . '/helper/search/processor.php');
  12. require_once(BASE_ROOT_PATH . '/helper/search/tcp_client.php');
  13. require_once(BASE_ROOT_PATH . '/helper/search/util.php');
  14. require_once(BASE_ROOT_PATH . '/helper/category_helper.php');
  15. require_once(BASE_ROOT_PATH . '/helper/search/searcher.php');
  16. require_once(BASE_ROOT_PATH . '/helper/brand_helper.php');
  17. require_once(BASE_ROOT_PATH . '/helper/algorithm.php');
  18. require_once(BASE_ROOT_PATH . '/helper/special_helper.php');
  19. define('MOBILE_SERVER',true);
  20. define('TIME_STAMP',time());
  21. class TestSecurity extends PHPUnit_Framework_TestCase
  22. {
  23. public static function setUpBeforeClass()
  24. {
  25. Base::run_util();
  26. }
  27. public function testPay()
  28. {
  29. $pri_key = BASE_DATA_PATH .'/api/alipay/key/rsa_private_key.pem';
  30. $pub_key = BASE_DATA_PATH.'/api/alipay/key/alipay_public_key.pem';
  31. $key = file_get_contents($pri_key);
  32. $pri = openssl_get_privatekey($key);
  33. $err = openssl_error_string();
  34. //
  35. $key = file_get_contents($pub_key);
  36. $pub = openssl_get_publickey($key);
  37. $err = openssl_error_string();
  38. $body = 'discount=0.00&payment_type=1&subject=%E5%AE%9E%E7%89%A9%E8%AE%A2%E5%8D%95_580507223514222365&trade_no=2016012721001004800042946454&buyer_email=13911129867&gmt_create=2016-01-27+15%3A25%3A29&notify_type=trade_status_sync&quantity=1&out_trade_no=580507223514222365&seller_id=2088121219613123&notify_time=2016-01-27+15%3A25%3A29&body=%E5%95%86%E5%93%81%E8%AF%A6%E6%83%85&trade_status=WAIT_BUYER_PAY&is_total_fee_adjust=Y&total_fee=8.00&seller_email=napheir.ao%40lrlz.com&price=8.00&buyer_id=2088202332994802&notify_id=66af3b99b765d046d2d533eaf6558fcm68&use_coupon=N';
  39. $body = 'discount=0.00&payment_type=1&subject=%E5%AE%9E%E7%89%A9%E8%AE%A2%E5%8D%95_280507226197761365&trade_no=2016012721001004800047345139&buyer_email=13911129867&gmt_create=2016-01-27+16%3A10%3A55&notify_type=trade_status_sync&quantity=1&out_trade_no=280507226197761365&seller_id=2088121219613123&notify_time=2016-01-27+16%3A10%3A55&body=%E5%95%86%E5%93%81%E8%AF%A6%E6%83%85&trade_status=WAIT_BUYER_PAY&is_total_fee_adjust=Y&total_fee=8.00&seller_email=napheir.ao%40lrlz.com&price=8.00&buyer_id=2088202332994802&notify_id=44d5cc359f27f5cb6e31fb10f480fb0m68&use_coupon=N';
  40. openssl_sign($body, $signed, $pri);
  41. $res = openssl_verify($body, $signed, $pub);
  42. $err = openssl_error_string();
  43. $s = base64_encode($signed);
  44. $s = urlencode($s);
  45. $sign='lnxpRmnHsaeUoPgtCrGm%2FtWohi3ORJk85q9Ic6X4c10q9O%2FASMXA2Z%2BzAH9%2BgPZAwsMywUA9O4HQ3ZCCrSpPhzJ8hEQ8Dc2SsMnvmeY6UqA7Zi6MZBTSeU1AuV3IV0tN4DTpnuk9ceetwQhNEwCiRo9vjrC%2B0TTHGfXb94OfJuM%3D';
  46. $signx = urldecode($sign);
  47. $signy = base64_decode($signx);
  48. $res = openssl_verify($body, $signy, $pub);
  49. $err = openssl_error_string();
  50. // openssl_encrypt()
  51. //
  52. //
  53. // $signed = base64_encode($signed);
  54. // $signed = urlencode($signed);
  55. //
  56. // $body = 'body=%E5%95%86%E5%93%81%E8%AF%A6%E6%83%85&buyer_email=bestcoolbear%40163.com&buyer_id=2088402949754402&discount=0.00&gmt_create=2015-12-31+14%3A51%3A41&gmt_payment=2015-12-31+14%3A51%3A41&is_total_fee_adjust=N&notify_id=35ceee6a4348f21bb27838770223ad0j34&notify_time=2015-12-31+14%3A51%3A41&notify_type=trade_status_sync&out_trade_no=150504888692984277&payment_type=1&price=0.01&quantity=1&seller_email=napheir.ao%40lrlz.com&seller_id=2088121219613123&subject=%E5%AE%9E%E7%89%A9%E8%AE%A2%E5%8D%95_150504888692984277&total_fee=0.01&trade_no=2015123121001004400035472261&trade_status=TRADE_SUCCESS&use_coupon=N';
  57. // $data = 'gNvKQd0GXULuvr%2F1FKjQrKVI%2BeT%2B8qz2ohSohfkzn%2Fx5ajMUdDD1zBXsxbv9%2FJZbaLq7KihhJmlb28E02S6hI9OlG7f7%2BTJ%2FTtrh8Xy2%2FYiU2KNpjtowS%2FM3io23lgfyQgIEQ0xIpyMZg4NRdaoW6thnrgQzs%2B9rY57iFgdG%2B24%3D';
  58. // openssl_sign($body, $sig, $pri);
  59. // $sig64 = base64_encode($sig);
  60. // $res = openssl_verify($body, $sig, $pub);
  61. // $err = openssl_error_string();
  62. }
  63. public static function zero_iv($ivlen) {
  64. $result = '';
  65. for ($i = 0; $i < $ivlen; ++$i) {
  66. $result .= chr(0);
  67. }
  68. return $result;
  69. }
  70. public function testEncrypt()
  71. {
  72. $plaintext = "message to be encrypted";
  73. $cipher="AES-128-CBC";
  74. $ivlen = openssl_cipher_iv_length($cipher);
  75. // $iv = openssl_random_pseudo_bytes($ivlen);
  76. $iv = self::zero_iv($ivlen);
  77. $key = '55668899';
  78. $ciphertext = openssl_encrypt($plaintext, $cipher, $key, 0, $iv);
  79. $original_plaintext = openssl_decrypt($ciphertext, $cipher, $key, 0, $iv);
  80. }
  81. public function testDecrypt()
  82. {
  83. $ciphers = openssl_get_cipher_methods();
  84. $cipher_text = 'pvmi16xnV6C3/1O8637DUKMTuNuZruETPg5TXE8rs78=';
  85. $cipher="AES-128-CBC";
  86. $ivlen = openssl_cipher_iv_length($cipher);
  87. $iv = self::zero_iv($ivlen);
  88. $key = '55668899';
  89. $plaintext = openssl_decrypt($cipher_text, $cipher, $key, 0, $iv);;
  90. }
  91. public function testSign()
  92. {
  93. //$body= 'body=order_sn=8000000000295701&buyer_email=13911129867&buyer_id=2088202332994802&discount=0.00&gmt_create=2016-10-29 20:51:36&gmt_payment=2016-10-29 20:51:37&is_total_fee_adjust=N&notify_id=0960c111697dbcdfbedad9ed94625adm6a&notify_time=2016-10-29 20:51:38&notify_type=trade_status_sync&out_trade_no=650531089488891490&payment_type=1&price=1.80&quantity=1&seller_email=napheir.ao@lrlz.com&seller_id=2088121219613123&subject=实物订单_650531089488891490&total_fee=1.80&trade_no=2016102921001004800260656982&trade_status=TRADE_SUCCESS&use_coupon=N';
  94. $body = "xxxxffff";
  95. $pri_key = BASE_DATA_PATH .'/api/alipay/key/rsa_private_key.pem';
  96. $pub_key = BASE_DATA_PATH.'/api/alipay/key/alipay_public_key.pem';
  97. $key = file_get_contents($pri_key);
  98. $pri = openssl_get_privatekey($key);
  99. openssl_sign($body, $signed, $pri);
  100. $sign = base64_encode($signed);
  101. $key = file_get_contents($pub_key);
  102. $pub = openssl_get_publickey($key);
  103. $res = openssl_verify($body, $signed, $pub);
  104. }
  105. public function testB64()
  106. {
  107. $pub_key = BASE_DATA_PATH.'/api/alipay/key/alipay_public_key.pem';
  108. $key = file_get_contents($pub_key);
  109. $pub = openssl_get_publickey($key);
  110. $err = openssl_error_string();
  111. $data = 'MIICdgIBADANBgkqhkiG9w0BAQEFAASCAmAwggJcAgEAAoGBAL+I5/3VVhfpc3TmsUjuwc8mrZycavjuE4MV9Z+EXDvPy55PAYjDvKfMtRMCsJYgO4R0fyyb1OhvglyXUKLFajxOhUm/4K2hnI1E/+8zPbY0CU5Osr4C9sxWHtY66ugTx+O4W3e4CxYTfHn+C6EuiYJ2DWJig+Obphd8CPFYFzLxAgMBAAECgYA+og9zEytXIHEv/ixlNCZOjlBhkUjt5DSfPjQXGNpseLQWLbHLvm5X1Po1oECMpzevRcU8mizSYXyYuKaWw8XMJ7/CC6A8fSBdlUeLEfTfisurEnzeUsal2K/n+WAAFj+TUncnqYtEqCCT+9c4jVkfik7FNxjbcio9p27QKDzYwQJBAOlWs593knByuSFOVnIiphhKlZy+6MUxquxhP+3NlXVaTCHHbBl8xt3fLqLmrXPUHvAt39wJ8fAvLDuNUQgP2gkCQQDSIt7bZi2hmzqfXK9rqVyJ16o0Hwqa8Z6PYhodSSsf61h3+wxdEpDFxIV9JnPWBPhCxcX+d1VddyLZacXbKuupAkBpwFesID8II5Zv19cp5zYrsDHaVlOce4QhmXmlxxTDmOcEMCN38asXhzzVq4JVCn/zDnd0fDVgS6DaZJOi+bwxAkAJg2iheCvCsDtkMZcDgcRdvTTIbUtWnm+2QBO8la5tIIN90xDJOejx+yar9syxuMHgjAGdtptXwugB/cbmWDgZAkEAiRoMv6p7WKNU34kZqpvXMIhN6hUihquVFZDJ7wiBr1tCLw/kW3uhciCViM68FgLStuefTfssgr9+oHVw/o4GjA==';
  112. $pem = "-----BEGIN PUBLIC KEY-----\n" . $data . "-----END PUBLIC KEY-----\n";
  113. $x = openssl_pkey_get_private($pem);
  114. $y = openssl_error_string();
  115. }
  116. public function testLocalSign()
  117. {
  118. // $pri_key = BASE_DATA_PATH.'/api/alipay/key/rsa_private_key.pem';
  119. // $pub_key = BASE_DATA_PATH.'/api/alipay/key/rsa_public_key.pem';
  120. $body ='body=order_sn=8000000000295404&buyer_email=13911129867&buyer_id=2088202332994802&discount=0.00&gmt_create=2016-10-29 20:24:18&gmt_payment=2016-10-29 20:24:18&is_total_fee_adjust=N&notify_id=f29b67caf1da662d7210f04b3675f3am6a&notify_time=2016-10-29 23:52:32&notify_type=trade_status_sync&out_trade_no=850531087853085490&payment_type=1&price=0.76&quantity=1&seller_email=napheir.ao@lrlz.com&seller_id=2088121219613123&subject=实物订单_850531087853085490&total_fee=0.76&trade_no=2016102921001004800260616422&trade_status=TRADE_SUCCESS&use_coupon=N';
  121. $sign ='WG+9QtqYOlmxVRzTVyso2toN1wOxXz4aBUS7ZRL7nzvDCdXaZRU3I2bN8EZ2pcag8DiU6eUXI99YY0MaTjnAJgGGESzd5S1KHDSg0ZNdsZueaLhmYQNGpap7jyRxBSDNIR+tEPU5FzgDivU4uK4f5PWu0FiOd9jOfXLIkGneRxg=';
  122. $pub_key = '/Users/stanley-king/Desktop/payment/alipay/key/alipay_public_key.pem';
  123. // $pri_key = '/Users/stanley-king/.ssh/rsa_private_key.pem';
  124. // $pub_key = '/Users/stanley-king/.ssh/rsa_public_key.pem';
  125. // $pri_key = '/Users/stanley-king/work/PHPProject/rsa_private_key.pem';
  126. // $pub_key = '/Users/stanley-king/work/PHPProject/rsa_public_key.pem';
  127. // $key = file_get_contents($pri_key);
  128. // $pri = openssl_get_privatekey($key);
  129. // openssl_sign($body, $signed, $pri);
  130. // $sign = base64_encode($signed);
  131. $key = file_get_contents($pub_key);
  132. $pub = openssl_get_publickey($key);
  133. $signed = base64_decode($sign);
  134. $res = openssl_verify($body, $signed, $pub);
  135. }
  136. public function testCmbpay()
  137. {
  138. $x = 'BranchID=0021&CoNo=006438&BillNo=5320089577&Amount=2.05&Date=20161030&ExpireTimeSpan=30&MerchantUrl=http%3A%2F%2F121.43.114.153%2Fmobile%2Fcmbpay_notify.php&MerchantPara=pay_sn%3A610531141658503490%7Corder_sn%3A8000000000298701%7Cmember_id%3A36490&MerchantCode=%7C4xKshccAHleC65HWnU828KX1n5MtZAcd1Ma4XfVTwPibT3QJLqgRwZhxSclZyyV8WE%2Fkv8jT01eYd1y%2Aed6SsJHw2BuxSoIqGeXL4b0HMTqYaZ%2AcGEyJ4n8nVYW7vDn%2AM%2FvnDRoCuahqmft0i2suJlgZP07w36WzDPmN9SKRd60%2A4HCG2GdSy0gJ1f8tcW9C7qW6ltC7XzWlZ9yJnuKeDSJ4JHzSy24invATyz8qOuehypiWCCRLYouNCJorAqFETHZgB5kfEEJzH%2AODIf24Fywe%2Amuib96thBMGwJ1A%2AuLl4FqlchHx6QYCUyxxRNcmnF7YPkfcQs43g4ekaiHKudxmAZ%2AwJMKxPRen3g9TUyXvqSW%2FpxyPELKlKJQYUGodBn6kZN0yQ7Pw%7C4fd51f4fe55b76e5e17538d7969b2fdd8f0b8e67&MerchantRetUrl=http%3A%2F%2F121.43.114.153%2Fmobile%2Findex.php&MerchantRetPara=act%3Dpay_return%26op%3Dcmbpay%26pay_sn%3D610531141658503490%26order_sn%3D8000000000298701%26member_id%3D36490';
  139. $y = urldecode($x);
  140. }
  141. public function testPubkey()
  142. {
  143. $file = fopen('/Users/stanley-king/work/PHPProject/public.key','r');
  144. $data = fread($file,1024);
  145. fclose($file);
  146. $base64 = base64_encode($data);
  147. }
  148. public function testPublicKey()
  149. {
  150. $CMPPAY_ONLINE = true;
  151. if($CMPPAY_ONLINE == true) {
  152. $pub_key = 'MIGJAoGBALKsktbh7j9O9pM0p7qnxxImgODqxjpiT7Xl2bvZCywJtwsNI6CchqAagOYGJjG0NZsnjFunTw5YM9TD5KxsUOILAL6IaNMH/fWREhVjkUDJ4CYtLWlKozElvXRp1iZxf66yHHhN4t7TE5S9NWpEBSn37TEfFLU99Go1WReI1XN1AgMBAAE=';
  153. } else {
  154. $pub_key = 'MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBALuUIwMGhvbpCwYzKCMzvSMQiLAAj5y74cN09N1TXVONPWhvLWkuzEPSd1ogPJLWiVyEG7gEIBT3zTlCV+NMou0CAwEAAQ==';
  155. }
  156. $pk = chunk_split($pub_key, 64, "\n");
  157. $pk = "-----BEGIN PUBLIC KEY-----\n{$pk}-----END PUBLIC KEY-----\n";
  158. $pkid = openssl_pkey_get_public($pub_key);
  159. }
  160. }