Demo.php 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. <?php
  2. namespace app\api\controller;
  3. use app\common\controller\Api;
  4. use app\common\library\RsaUtil;
  5. /**
  6. * 示例接口
  7. */
  8. class Demo extends Api
  9. {
  10. //如果$noNeedLogin为空表示所有接口都需要登录才能请求
  11. //如果$noNeedRight为空表示所有接口都需要验证权限才能请求
  12. //如果接口已经设置无需登录,那也就无需鉴权了
  13. //
  14. // 无需登录的接口,*表示全部
  15. protected $noNeedLogin = ['*'];
  16. // 无需鉴权的接口,*表示全部
  17. protected $noNeedRight = ['*'];
  18. /**
  19. * 测试方法
  20. *
  21. * @ApiTitle (测试名称)
  22. * @ApiSummary (测试描述信息)
  23. * @ApiMethod (POST)
  24. * @ApiRoute (/api/demo/test/id/{id}/name/{name})
  25. * @ApiHeaders (name=token, type=string, required=true, description="请求的Token")
  26. * @ApiParams (name="id", type="integer", required=true, description="会员ID")
  27. * @ApiParams (name="name", type="string", required=true, description="用户名")
  28. * @ApiParams (name="data", type="object", sample="{'user_id':'int','user_name':'string','profile':{'email':'string','age':'integer'}}", description="扩展数据")
  29. * @ApiReturnParams (name="code", type="integer", required=true, sample="0")
  30. * @ApiReturnParams (name="msg", type="string", required=true, sample="返回成功")
  31. * @ApiReturnParams (name="data", type="object", sample="{'user_id':'int','user_name':'string','profile':{'email':'string','age':'integer'}}", description="扩展数据返回")
  32. * @ApiReturn ({
  33. 'code':'1',
  34. 'msg':'返回成功'
  35. })
  36. */
  37. public function test()
  38. {
  39. $this->success('success');
  40. }
  41. /**
  42. * 无需登录的接口
  43. *
  44. */
  45. public function test1()
  46. {
  47. $this->success('返回成功', ['action' => 'test1']);
  48. }
  49. /**
  50. * 需要登录的接口
  51. *
  52. */
  53. public function test2()
  54. {
  55. $this->success('返回成功', ['action' => 'test2']);
  56. }
  57. /**
  58. * 需要登录且需要验证有相应组的权限
  59. *
  60. */
  61. public function test3()
  62. {
  63. $this->send_score(1, 1);
  64. }
  65. public function send_score($score, $grade_id)
  66. {
  67. $url = 'http://apip-gateway-nrouter-saas-gn-C.month.sdc.cs.icbc:8081/api/mybank/farm/farmplatf/updateVillagerIntegral/V1';
  68. $biz_content = [
  69. 'fSeqNo' => createUniqueNo('fseq', $grade_id),
  70. 'corpCode' => 'xingfulishequ',
  71. 'mobilePhone' => $this->auth->mobile,
  72. 'integralValue' => $score,
  73. 'integralType' => '',
  74. /* 'remark1' => '',
  75. 'remark2' => '',
  76. 'remark3' => '',
  77. 'remark4' => '',
  78. 'remark5' => '',
  79. 'remark6' => '',
  80. 'remark7' => '',*/
  81. ];
  82. $public_key = APP_PATH.'/common/certs/icbc/public_key.pem';
  83. $private_key = APP_PATH.'/common/certs/icbc/private_key.pem';
  84. $rsautil = new RsaUtil($public_key,$private_key);
  85. $sign = $rsautil->publicEncrypt(json_encode($biz_content));
  86. dump($sign);
  87. $data = [
  88. 'app_id' => '10000000000004096993',
  89. 'msg_id' => createUniqueNo('msg', $grade_id),
  90. 'format' => 'json',
  91. 'charset' => 'UTF-8',
  92. // 'encrypt_type'=> 'AES',
  93. 'sign_type' => 'RSA',
  94. 'sign' => $sign,
  95. 'timestamp' => date('Y-m-d H:i:s'),
  96. // 'ca' => '',
  97. 'biz_content' => $biz_content,
  98. ];
  99. $rs = curl_post($url, json_encode($data, JSON_UNESCAPED_UNICODE));
  100. //dump($rs);
  101. }
  102. }