Home >Backend Development >PHP Tutorial >After the token verification of WeChat subscription account development, the automatic reply message function is completed, but the message is not returned, and the token automatically replies_PHP tutorial
I believe many people will be like me. After the token is verified, a message is sent to the subscription account, but no message is returned.
The following is the solution I got through hard debugging:
First, token verification:
The token I wrote has always failed to verify. I have been looking for it for a long time, but no bug has been found. There was really no other way, so I used the official sample code. And through debugging the sample code, I found a bug that made me vomit blood (not a bug):
Token verification seems to require character encoding format! ! ! !
The official sample code is uploaded directly to the server, and the token is passed directly!
Changed the official sample code to UTF-8 format, and then uploaded it to overwrite it. Token failed! Failed! fail!
Later, I changed what I wrote to ANSI format and the token still failed! Drunk, drunk! Then you have to use the official sample code. Here, let me say that token is a one-time handshake verification , and it is no longer needed after verification once.
Now, let’s get back to the topic, I seem to have digressed...orz
After the token verification, I directly used the official sample code to quickly test my subscription account. As a result... the message sent out was like water poured out, and nothing was returned...orz
I searched for bugs in various ways, asked in various groups, searched in various ways... After the efforts of this blogger, I finally found out the problem (here it refers to the one I developed myself, not the one I developed myself). Including all, if you have different bugs, welcome to communicate):
1. The most easily overlooked bug is that the official sample code does not call the written responseMsg() function at all!
2. Comment out the previous token code, which is the line of code $wechatObj->valid();. Because there will be an echo $echostr in the toke verification code, the echo $resultStr; (line 56) in the responseMsg() function will be in a confusing xml format, and it will not be recognized when it is input back to the WeChat server (it seems Only xml format and json format can be recognized). (Token verification is a handshake verification. After verifying the developer, it is no longer needed. Let it disappear in our neat code orz...)
3. The most disgusting bug is the character encoding problem! orz...xml requires UTF-8 encoding, so, change the sample code back to UTF-8 encoding! This bug makes me collapse! ! !
The following is my modified code. It can run normally and has no bugs. You can refer to it if needed
<span> 1</span> <?<span>php </span><span> 2</span> <span>/*</span><span>* </span><span> 3</span> <span> * wechat php test </span><span> 4</span> <span>*/</span> <span> 5</span> <span> 6</span> <span>//</span><span>define your token</span> <span> 7</span> <span>define</span>("TOKEN", "codcodog"<span>); </span><span> 8</span> <span> 9</span> <span>$wechatObj</span> = <span>new</span><span> wechatCallbackapiTest(); </span><span>10</span> <span>//</span><span>$wechatObj->valid();</span> <span>11</span> <span>$wechatObj</span>-><span>responseMsg(); </span><span>12</span> <span>13</span> <span>class</span><span> wechatCallbackapiTest </span><span>14</span> <span>{ </span><span>15</span> <span>public</span> <span>function</span><span> valid() </span><span>16</span> <span> { </span><span>17</span> <span>$echoStr</span> = <span>$_GET</span>["echostr"<span>]; </span><span>18</span> <span>19</span> <span>//</span><span>valid signature , option</span> <span>20</span> <span>if</span>(<span>$this</span>-><span>checkSignature()){ </span><span>21</span> <span>header</span>('content-type:text'<span>); </span><span>22</span> <span>echo</span> <span>$echoStr</span><span>; </span><span>23</span> <span>exit</span><span>; </span><span>24</span> <span> } </span><span>25</span> <span> } </span><span>26</span> <span>27</span> <span>public</span> <span>function</span><span> responseMsg() </span><span>28</span> <span> { </span><span>29</span> <span>//</span><span>get post data, May be due to the different environments</span> <span>30</span> <span>$postStr</span> = <span>$GLOBALS</span>["HTTP_RAW_POST_DATA"<span>]; </span><span>31</span> <span>//</span><span>$postStr = file_get_contents("php://input");</span> <span>32</span> <span>file_put_contents</span>("log.txt",<span>$postStr</span>,<span>FILE_APPEND ); </span><span>33</span> <span>//</span><span>extract post data</span> <span>34</span> <span>if</span> (!<span>empty</span>(<span>$postStr</span><span>)){ </span><span>35</span> <span>/*</span><span> libxml_disable_entity_loader is to prevent XML eXternal Entity Injection, </span><span>36</span> <span> the best way is to check the validity of xml by yourself </span><span>*/</span> <span>37</span> libxml_disable_entity_loader(<span>true</span><span>); </span><span>38</span> <span>$postObj</span> = <span>simplexml_load_string</span>(<span>$postStr</span>, 'SimpleXMLElement',<span> LIBXML_NOCDATA); </span><span>39</span> <span>$fromUsername</span> = <span>$postObj</span>->FromUserName; <span>//</span><span>用户</span> <span>40</span> <span>$toUsername</span> = <span>$postObj</span>->ToUserName; <span>//</span><span>公众平台</span> <span>41</span> <span>$keyword</span> = <span>trim</span>(<span>$postObj</span>-><span>Content); </span><span>42</span> <span>$time</span> = <span>time</span><span>(); </span><span>43</span> <span>$textTpl</span> = "<span><xml> </span><span>44</span> <span> <ToUserName><![CDATA[%s]]></ToUserName> </span><span>45</span> <span> <FromUserName><![CDATA[%s]]></FromUserName> </span><span>46</span> <span> <CreateTime>%s</CreateTime> </span><span>47</span> <span> <MsgType><![CDATA[%s]]></MsgType> </span><span>48</span> <span> <Content><![CDATA[%s]]></Content> </span><span>49</span> <span> <FuncFlag>0</FuncFlag> </span><span>50</span> </xml>"<span>; </span><span>51</span> <span>if</span>(!<span>empty</span>( <span>$keyword</span><span> )) </span><span>52</span> <span> { </span><span>53</span> <span>$msgType</span> = "text"<span>; </span><span>54</span> <span>$contentStr</span> = "Welcome to wechat world!"<span>; </span><span>55</span> <span>$resultStr</span> = <span>sprintf</span>(<span>$textTpl</span>, <span>$fromUsername</span>, <span>$toUsername</span>, <span>$time</span>, <span>$msgType</span>, <span>$contentStr</span><span>); </span><span>56</span> <span>echo</span> <span>$resultStr</span><span>; </span><span>57</span> }<span>else</span><span>{ </span><span>58</span> <span>echo</span> "Input something..."<span>; </span><span>59</span> <span> } </span><span>60</span> <span>61</span> }<span>else</span><span> { </span><span>62</span> <span>echo</span> ""<span>; </span><span>63</span> <span>exit</span><span>; </span><span>64</span> <span> } </span><span>65</span> <span> } </span><span>66</span> <span>67</span> <span>private</span> <span>function</span><span> checkSignature() </span><span>68</span> <span> { </span><span>69</span> <span>//</span><span> you must define TOKEN by yourself</span> <span>70</span> <span>if</span> (!<span>defined</span>("TOKEN"<span>)) { </span><span>71</span> <span>throw</span> <span>new</span> <span>Exception</span>('TOKEN is not defined!'<span>); </span><span>72</span> <span> } </span><span>73</span> <span>74</span> <span>$signature</span> = <span>$_GET</span>["signature"<span>]; </span><span>75</span> <span>$timestamp</span> = <span>$_GET</span>["timestamp"<span>]; </span><span>76</span> <span>$nonce</span> = <span>$_GET</span>["nonce"<span>]; </span><span>77</span> <span>78</span> <span>$token</span> =<span> TOKEN; </span><span>79</span> <span>$tmpArr</span> = <span>array</span>(<span>$token</span>, <span>$timestamp</span>, <span>$nonce</span><span>); </span><span>80</span> <span>//</span><span> use SORT_STRING rule</span> <span>81</span> <span>sort</span>(<span>$tmpArr</span>,<span> SORT_STRING); </span><span>82</span> <span>$tmpStr</span> = <span>implode</span>( <span>$tmpArr</span><span> ); </span><span>83</span> <span>$tmpStr</span> = <span>sha1</span>( <span>$tmpStr</span><span> ); </span><span>84</span> <span>85</span> <span>if</span>( <span>$tmpStr</span> == <span>$signature</span><span> ){ </span><span>86</span> <span>return</span> <span>true</span><span>; </span><span>87</span> }<span>else</span><span>{ </span><span>88</span> <span>return</span> <span>false</span><span>; </span><span>89</span> <span> } </span><span>90</span> <span> } </span><span>91</span> <span>} </span><span>92</span> <span>93</span> <span>94</span> ?>