我们都知道dede可以利用idlist='1'调用文章id为1的文章,但是很多朋友知道dede默认的 idlist='' 只能手动填写,不能后台调用。我们利用{dede:arclist idlist='自定义字段'}这种形式的调用方法是不可以实现的。
今天我就整理了一下如何利用 {dede:arclist idlist='自定义字段'} 随机调用自定义文章。实现了这个功能后,栏目可以随意调用任意文章,只需要在后台栏目相应位置填写一下你要调用的文章id号即可。
言归正传
首先我们需要在栏目里创建一个类似于相关文章的字段(这里方便你以后填写想要调用的文章id)
![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAA4QAAAHsCAIAAAAFFPRyAAAgAElEQVR4nO3dXW8cVd7v/X4JI80bmMxEjGbmeKQ5Q5o5Q0KXOIhyAJYYiY3gYCNvaW5pazS6rjtxIEJINzDShmw0gwhYDjiEDMmVBNuNQ3Ac7HRs5wFn0knI4yROwHGw28/dnboPimmqa631X6uqq7r64fvRX6Xu6lWr1qrquH6utuOcBwAAAGQkl/UAAAAA0L0IowAAAMgMYRQAAACZ6a4w+uhRVV3jr/QfxK5KddNfaqtc2fCX7rVZXgs+dqz1zZV4tbq+WFv6D9xrZe372gOhllcX5Fpa+a72QK7F5fuLy/drD4R6WJpzrIXFO/5SqPnvbwUf1Ja1+u77m/7yu+9vfvvwur90r3sPrkaqu98VY9ft+1/fvv917UGkujF3NrgU6vrdGW1du3MmuDTVN/86rdbV25NXbk9cvT3pPxCqeHPcWv+88aW/NNXstS+s9fU3nweXtbrwTd5fhur81eFQnbvymb/U1szlo441demQv4xak7MHgssYderCh8GlY42d7Q8+GDvb71InZt4LPjgx855cx6f+Hqnyhf/rL91rePL/BJdyffbVX/2lUEdPveEvtXVk/P+z1uGTr5nq07FX5frHid1yffLFLmt9PLqj9sC9Psr/xV8GH7jXwPD/Dj4YGP7fjtX/2f/jL93r/aP/y1/Gq/f++3/6y0j190MvBpfx6p1//A9/2Ui9/cmzwQdvf/Js8EHU6q4wCgAAgJZCGAUAAEBmCKMAAADIDGEUAAAAmSGMAgAAIDOEUQAAAGSGMAoAAIDMEEYBAACQGcIoAAAAMkMYBQAAQGaihdH19fV//vOfM13g1q1bjx49Ck1/Y3Pt0s0zpy8Onzx3qCPr9MXhSzfPbGyuqae+m+cOAADSEy2MXr16dXpmWk1pHaZarU5NF+bn54MrK5XN2WsTX3197PvVuaX1ucX1O4trHVTrd5bW575fnfvq62Oz1ybKlU3mDgAAmiBaGJ2enqpWq4+6wOLi4vGTB4Nzvzt/7fLtqYXVW98tF++XZu+Vvu6wul+a/W65uLB66/LtqTvffcPcAQBAE0QLozMzM1mnxCZZXV09OTFcN/fiFwulf323cvleJ6axf9fsdyuXF5bvTBePM3cAANAEkcNotTusrKyEwuj4+f9eXJu7t3xxrvR1B9e90sXFtbvj5w8zdwAA0ASEUT01jJ48d+j79X/Nlb6eK13o7Pp+/V8nzx1i7gAAoAkih9FKXLlczvRA2ybI2t60R5XjaJeXlzVhdO323NKFGJXL5SK9VFupvip05b+qijra79dua8JoxLlrpxAaTKTRukwkxmStcwcAAKlqUhjVxg41IGpzp9BAG0+Fbt01GEbl+ar5TGgTeqDmLaHbpAJZI2FUHrl7mjS95HicCaMAALSmyGG0HJ0fC4RXa22CQg1Cj4X2QjP3MZdKJTWMPly7fXfpfIKVy+W0T4PrgytDTNua2jjWQ10YdZ+7OoDgUpi+9oCYBBuYjl6M6atzBwAAqWpGGA1mRDkdBkNkaCk00+5IbZBJGBUSpCk8aSOUNWBpG2QSRtXxCEdAeFWYi0uKjTFxwigAAM0XOYxuNiCXywlPg2v8B8Gl/6C2RsuxHxdLS0u6MHrr7tK5SJXL5UxPA/Gr7tXgytpj05TVnmvt1b071sO1W7owGm3uLrtW28iHSziM2seJzB0AAKQqchjdaICapeSXgstas9Dj4Bq1makfK1MYvbN01rFM8dFXaxPaRF2vPg5tpd1WaGktUxiNMXdrM3mNdlKORyBeEUYBAGiypobRUFIUXuqMMCq/pIanDgujwcfaeCrEdPnIaPtxPPiEUQAAWkrkMLoel+keodrG9NRfE3pcW6PdUF06Wlxc1ITR1Zt3FmccK5fL+cu6pKV7KbSytgyuV9uoL6k9BBu418PVm5ow6jx3912rbUJrTEcjeAS0xzl0bBuZOwAASFXkMLoWVy6XCz0wPfYfqEvTg5raU3XX6krZ999/r4bRhdWb/1qccaxcLldbBteEVqotta+GHtTUnqp7V1c61oIujLrPXZ243FJYY5qFy4ZJzR0AAKQqchhdjSuXywUf1OKU2kDbOLRh7P06evjwoS6M3vjX4rRj5XI5f1mfHTUv1dYEX1JbRt118EGkWli9oQujEebuuOucjksn6nrHDWPMHQAApKp5YVRNh6bIGEqltTWhNiq1z9BK9zyaVBg1xS+1ZWi9mkqt0U3tJF4sSzCMymOOkSnliQtHhjAKAEBrihxGV7rDwsKCIYxOdXyZw2j2Y2v+3AEAQKoih9Hl7vDgwQM1jD5YvXF7ccqlTDcys+I4bL8e6MJo184dAACkKnIYLXUHQxi9fvv7Mx1fD1av68Jol84dAACkijCqRxhl7gAAoAkih9Gl7jA/P68Lo9dufV/o+Hqwek0XRrt07gAAIFWRw+hid/juu+8MYfR0x5c5jGY/tubPHQAApIowqkcYZe4AAKAJIodRAAAAICmRw2ik9gAAAICAMAoAAIDMEEYBAACQGcIoAAAAMkMYBQAAQGYIowAAAMgMYRRO5h4sDY7O9PT1b92+q6evf3B0Zu7BUtaDSlLHTxAAgNZEGIVFtfpopFDcsm3nc6/s3XfsxOWrl/cPn3rh1YEt23aOFIrV6qOsB9io2gSf3/3B/uHx6zevfzI68eJr+zpmggAAtLK0wmhOIbxkahncRNiRtWVtpbAXdZAOs+wKI4Xitj+/M3Dk+I0bV27dunbnzq179+7Mz98/dGLq6R17RwrFrAfYqJFCcftf/vbR0NidOzfn5m5/++3d+fn7Dx/OHx6beWbH+x0wQQAAWlmKYVR46viSto22ZznUBsOotsNae8dw3D3mHixt2bZTTaIPH84vLj48cvLslm075Y+zm/+9RyT+BNUkurj4sFRaPDp+3jpBeYTCS13+1gIAwJfBnVFTM3lztTfttkI/niGMmtbIU3Ns3O4GR2eee2WvNomWSosrK8svvf7x4Gi0H96wHj35hHqJfs8wODrz/O4P/CR66961j64OPHn8iffOv3tv4e7KSmltbfWlNw5EmmAzBw8AQAfI7M6oNiAKmTX2jjxdBg0lBlPGNfXWPemhp69/37ETpiS6trY6NDHb09fv3qFwSAWecpqE3qJOcP/wuH9P9KOrA9tmn/rD2OO/+vCxd87sWVtb3dhYH568KE8ww8EDANABMvuZ0eDT0IZCJ+r1W73Ym6766o60wyAuBG3dvuvy1cumJLqxsb60vLJ1+y73Dl0OqdBGeLfEs3X7rus3r/ufzj95/Infjz3+u6Hfbtm75bG3frGxsb65uVFaWU1qgokPHgCADpD9b9PLl2Tr9VtNqEIbaz52ib9dpaevf//wKVMSLZc384VL7ndGg8fZ9Grj33tEneAnoxP+7N47/+6vP/zlz9//2U//+pM9E29vbm5UKuV8oegywUwGDwBAB0g4jGovtNqLruMlOWe+TxncytRbqGdTb9YA0bUGR2deeHXAlESr1Urvmwcdf6QyVx9Dradb20Y9Rw2eoMHRmRdf2+fP7t7C3XfO7Nn61tY9k28vlB5UKuVqtRp1gs0cPAAAHSCVO6Ny4DC9ZGocCjHWV+WeTe1Dy2CcVXvrngzh/7L5oRNT2iSaP1N0/GVz6/cD1lddvveIPcHDYzOl0qL/G0v+p/N+EnWfYCaDBwCgA6QVRrXX3VAbdSuhQ+tLQgKWd60No6GldnZdYqRQfHrH3iMnz6pJ9NmXB6z/DWfocDm+DRr53iOqkULxmR3vHx0/ryZRlwnKw5Nf7ao3EgAAWsmH0WAolEOky/2hUK4Vdue4RoiYwWVwv6YpdInaHyh66fWPhyZml5ZX8oVLvW8ejPcHilyOZ4Pfe0T14wTfODA8ebG0spovFNOYYBqDBwCg3SX/M6Ohp6a4aY2M2vQZiolqn8Ia7UuhvWvHL0+5SyT1p9vl45nI9x7xND7BDAcPAED7SuVjesBEuP/d+PcemWjrwQMAkDnCKAAAADJDGAUAAEBmCKMAAADIDGEUAAAAmSGMAgAAIDOEUQAAAGSGMAoAAIDMEEYBAACQmThhNJ/Ps+zUZeYDYMmSJUuWLFl21ZI7owAAAMgMYRQAAACZIYwCAAAgM4RRAAAAZIYwCgAAgMwQRgEAAJAZwiiczD1YGhyd6enr37p9V09f/+DozNyDpawHlaSOnyAAAK2JMAqLavXRSKG4ZdvO53d/sH94/PrN65+MTrz42r4t23aOFIrV6qOsB9io2gSfe2XvvmMnLl+9vH/41AuvDnTMBAEAaGVphdGcQnhJbaluGOxBuzuhjbaTUGPTSDBSKG7/y98+Ghq7c+fm3Nztb7+9Oz9//+HD+cNjM8/seH+kUMx6gI0aKRS3/fmdgSPHb9y4cuvWtTt3bt27d2d+/v6hE1NP79jbARMEAKCVpRhGhafWl0LxUZsRXUKtugtTbHVZ04XmHixt2bZTTaKLiw9LpcWj4+e3bNvp8nF2vKzfhFPgT1BNov4cj5w8a51gst84AQDQbTK4M2pqFlrv6e5oCv2YNgztovEw6hikOsPg6Mzzuz/wk+ite9c+ujrw5PEn3jv/7r2FuysrpbW11ZfeODA4an9XWA+vyzcVaRgcnXnulb3aJFoqLa6sLL/0+sfyBNX3njaeylKdIwAArSyzO6OhdOjVh7xQcDRd4LWvqhd4IROExuMSEboqPfT09e8fHvfviX50dWDb7FN/GHv8Vx8+9s6ZPWtrqxsb68OTF3v6+q39tGwC6+nr33fshCmJrq2tDk3MyhNU38ahB9r26oYAAHSnzH5mNPg0tKEnXqfVZKl91brS2oaU4Hne1u27rt+87n86/+TxJ34/9vjvhn67Ze+Wx976xcbG+ubmRmlldev2XdZ+Wvbwbt2+6/LVy6YkurGxvrS8Ik8wl+g3TgAAdJvsf5veMXGartzqZT7Up+P1vmXTUrZ6+vo/GZ3wU9p759/99Ye//Pn7P/vpX3+yZ+Ltzc2NSqWcLxQbvzMqpLS0s1pPX//+4VOmJFoub+YLlyLdGVVf8qJ84wQAQLdJOIy6pwrrq6EH2pdqW+UCkdTThVHtTq0jj3BoOtTg6MyLr+3zU9q9hbvvnNmz9a2teybfXig9qFTK1Wq1982DLj8zGkkzj/zg6MwLrw6Ykmi1WrFO0PTuMqXP0Ku8zQAAXS6VO6NClFTbaNeEruXaC7waQ7VJVB6G43hC67snQPi/bH54bKZUWvR/Y8n/dN5PovkzRZffpteeMs98zF3eP0nxJ3joxJQ2ibpM0Dodz/kbJwAAulBaYVS9CaS9S2RaowZTz5Bp3JfWMVvXhMbTJUYKxWd2vH90/LyaRJ99ecDxv+HUng7TW8L0TkjJSKH49I69R06eVZOoywST+sYJAIDulHwYDV2VhWYqbSeekk60cTN0jY8aaOTxdLPaHyh66Y0Dw5MXSyur+UKx982Dkf5AkfU7BOF8pX0ifpzg6x8PTcwuLa/kC5fcJyi8OT3zxIVDAQBAV0n+Z0ZDT61xU7tGvZa7dGJ6SdtJpPEgkT/drv1WwbOlz+aciNgT1ObO2hpt9Ay+/fi2BwDQ5VL5mB6o0X4PoP1+INg4q9HGkOw3TgAAdBvCKAAAADJDGAUAAEBmCKMAAADIDGEUAAAAmSGMAgAAIDOEUQAAAGSGMAoAAIDMEEYBAACQmThhNJ/Ps+zUZeYDYMmSJUuWLFl21ZI7owAAAMgMYRQAAACZIYyizn/9fYiiEq+s39cAgNZFGEUdcgMSx5sKACAgjKIOuQFWdxcq525UT1/aOHlh7fjZ9eNn1z+fXhs+s/xZYfXY6ZVjp1eOTKwd/mrl4Pjy1bsbHm8qAICIMIo65AZYnbtRvfnto8t3H319s3LuRvXcjerZbyrTV6qni9WJS+WJS+Xxi5UvL1Ty05tDkyWPNxUAQEQYRR1yA6xOX9q4fPfRpduVc9eq01eqfgydvFQZn62MX6iMX6h8eaEyeraSn94cPrPs8aYCAIgIo6hDboAVYRQAkKCUw2jOoX+hjf9SLqepWgN1peN+oWPNDbnAsc3VH+fa05yO3JXjHmN3ggSdvLDmf0A/daUyeemHmpgtj56tjExXa5Wf3syf4WN6AIBFRmFUmy/lTFkLptpdBOOpsF/YCLlBGzFDQVN97B4lQ4+t+1K3QnMcP7t+9pvK9DfV08XqxMVyrUamq8NTleGpytBU2X9AGAUAWKUQRq0pM/RY+yC0lSmtelHCqLotFHIYDT4IPVXbaEOkkDLVrGmKqqY2sVkTs+nmbncijAIAEpROGLU+1q4RGmj7ESIvYTQuOTcEY6h841MIrOoaNYPGC6yO4sVKwmjN59NrU1cq/mf0T/7xZf9j+pHp6tBUeWiq/OQfXz42VfEfE0YBAFYZhVHrjVJtmwbvjMKBKTe4BET5DqjaofaxsNKxmRVhtEGfFVYnL1VOX6o++ceX/TpxoXziQvnodLm2xs+j/AITAMAqzTCqjYly49BL2judchgV9gUHDeaG0K3QeHdGayutiVbdVg3E2pWhvWuHpzbTtlGH1PFqYTSUR2uPj06XCaMAAEfph1HPnBeFBKkGWe2dUestVURk/ZheDojud0Y9JbBqX5XXeIZQq+bRSD1rM7RLmy5x7PRK7edEgxm0lkR/qKnyUIGP6QEAFqmFUWuy9JSIqd4Kle93Rr0bSkh14PIzo8Ia9zujahv11dh3Rl326zILlx0RRkP3RAmjAIBI0gmj8ifypjWmBqbAanpJGED35YaoErwzGly63/6M2sZ6Z9Slw3hhVBhVZ/vvidXx2Uqonvzjy59fKPvlh9EjU5tH+HOgAACbND+mt653DKPBx0IC6OJwkKBG7ozKdzrVDU1RVRt5rfFX2FbYe3ATbT9qn9o2XeXTr1a/vFAZv/hjjc1Wv5ytDH9dOTRTrtWnhc3DEyseYRQAIGpKGDXdrbTezgzeGQ1tpd3cenMUNo3cGVXjndrSFODk4CgPyXFqSAphFACQoBTCKNpZ2+UGwmjzHRhbHT1b+fJC5csLlS9nf6zhryvHLlSOXagcPlc5OFU+WNg8NMFv0wMALAijqENugNWBsdXhqcro2cqJ8+XRsxW/Pr9QPnahcvRc+ei58qGZ8sGp8oHJjU9P8TOjAAALwijqkBtgRRgFACSIMIo65AZY7T+xfKywMTRdzk9v1mpopnx0qnxoqnxoqvxpYfPA5MYnE2v/GF/yeFMBAESEUdQhN8Dqyu31Y6cWP5tcGpos1eqzyaXDEyt+HZpY/vRU6R/jS8Xbqx5vKgCAiDCKOuQGJI43FQBAQBhFnf/6+xBFJV5Zv68BAK2LMAoAAIDMEEYBAACQmThhNJ/Ps+zUZeYDYMmSJUuWLFl21ZI7owAAAMgMYRQAAACZIYyiTi+QqKzf0QCAVkcYRZ3e3t77QEKmp6ezfkcDAFodYRR1ent7l4CEEEYBAFaEUdTp7e1dBxJCGAUAWBFGUYcf8kOCCKMAACvCKOoQRpEgwigAwCqdMJrLhR+EHvtP1ZJ7E3bnt7G2hI0QRnO5XGhpelWQU6idROoQrYwwCgCwSjmM1h6rkcJlTW29NrOqEZbg0rBQGFVTo/pAu94lbqpPtf2TR9sXYRQAYJV0GFVTY4NhVL2fampgvc8q3HzFv5nujMrRUE2i6ku1p8KdUaEZkbQdEUYBAFbpf0xvCoguH9PLNz61qdfUWO0NOsKdUSEgClE16p3R4H7lNmh9hFEAgFX6H9O7tzGlSfnnQUOvElwaE+POqBwc3e+M1p6qH/RzZ7RNEUYBAFYphFH5t5GCzaxrrC+FfoTUsyVX2Mhh1JQ73cOozLFPtAvCKADAKrUwGnysjacuH9ObWqoveYTRZGjDaPDeZHAZbBB6EHop6sf9cp9oF4RRAIBVCr/A5LllQZc7o6YfJNXuy/p5PT8z6kD7M6Oe+DtJnkMYtTbTNuZj+nZHGAUAWLVqGDX9WpJnSJ9qBiWMxuLyM6NqpnQPo9obpaHGofhLDG1fhFEAgFWmv8Dk8jG99QaqexiFAyGMqjE0UhjVxlntXkJ75M5o+yKMAgCs0gyjctx0+Zje2kloK+59NkwNo6YsKN8iDW0Y2twlaJI+OwBhFABglU4YRdvib9MjQYRRAIAVYRR1CKNIEGEUAGBFGEUdwigSRBgFAFgRRlGHMIoEEUYBAFaEUdQhjCJBhFEAgBVhFHUIo0gQYRQAYEUYRZ1pIFFZv6MBAK2OMAoAAIDMEEYBAACQmThhNJ/P/7+5HEVRVNrlf8FhyZIlS5YdvIx5ZzTzSxRFUd1Qkb5AAQDaEWGUoqjWrRS+6AEAWkujYTSFISFLvUCi4r0P+QoDAN2DMIo6vb2994GExP6vnfgKAwDdgzCKOr29vUtAQgijAAArwijq9Pb2rgMJIYwCAKwIo6gT+4f8ABVhFABgRRhFHcIoEkQYBQBYpRJGc26XkFAz01bxekM8hFEkiDAKALBKPYzm6playlEy1KGpc2FHcEQYRYIIowAAq2aEUfWxNUQKDdSsadodYtCGUY4q4iGMAgCsEg6jamS0JsV490TVfXFzNBFqGOVgIjbCKADAKuOP6b0GwqhpJcmpEdwZRYIIowAAq+TDaCh3pndnNLQ77okmgjCKBBFGAQBWaYVR798JRvvBfaSP14O9aXdnXQN3hFEkiDAKALBK/mdGPfPtzKhB06UNd0aTRRhFggijAACrLMOo9SN4x1fd28CKMIoEEUYBAFaZ/QKT48froQ/31ZfcP+6HC9Nv03M8EQNhFABglcH/Myokm1D01AZW0+akpUTwn94jQYRRAIAVf5sedQijSBBhFABgRRhFHcIoEkQYBQBYEUZRhzCKBBFGAQBWhFHUIYwiQYRRAIAVYRR1CKNIEGEUAGBFGEUdwigSRBgFAFgRRlFnGkhUvPchX2EAoHsQRgG0HL7CAED3IIwCaDl8hQGA7hEnjObz+dqlIp/P+2tYdsYy8wGwZOnVh9FWGA9LlixZskxv2eidUYqiqPQq0hcoAEA7IoxSFNW6lcIXPQBAayGMUhTVupXCFz0AQGuJGUbRqXp7e++3sNj/VRAAAGhNhFHU6e3tXWphhFEAADoMYRR1ent711sYYRQAgA5DGEWdFv9zoIRRAAA6DGEUdbokjObMvxmjvpTL5YT2aY8HAIDOlkoYDV5Z/cfu1/7a0+CGOYW1H8TTAWHUJTta35Dym81lDC6DFKiNYwwDAIDWl0EYlS+92jCqdit01UiGQLuHUcdTb3pfhd5+XgPf5CT7DuQtDQDoVAmHUVMoFEJn6Kk2jJqCZqTLM5dzF2oYbalwL4dReZwu37okGEYdt3X/Jqp1zgIAAAnK7GN6Na2Gtg2FUW3/clTV7tFl/N0sFEbVU5mtBsOo/FhIpbHnbt3Q9N7WtmyFUwAAQLLSCqPWa7mpgRBG5btWDYYG+Lo5jHpKMHX/Jkdo47ihSz+tcAoAAEhW8mG0dskMXlZDl1ghrcYOo+pTxNDZYdSa/Kzvsajk8UR6iTAKAOhIyf/MqKdLMKbrvXDtdwyjke4twaqzw6j740TCqLxt6Ps07T+HUPtWOAUAACQrxY/pg9dXU0BsPIzKvamjchl/N2vrMOqJZzlGGNW+/RxZ28vfp6mNW+H4AwCQuLTCaOixKR2qj7VpoLbGlD61T9XdcTm3avcw6plPdNQwKr/3rGNwbONyZ5S3LgCgg2UWRuXbV9Y7ppH6hLu2/q+dZDmzYJvgAyEgNs6UmFvnaAMA0ATJ/8yo9upuvckUSgZye1MbLuGNa/f/9B4AALSXVO6Mon0RRgEAQDMRRlGHMAoAAJqJMIo6hFEAANBMhFHUIYwCAIBmIoyiDmEUAAA0E2EUdQijAACgmQijqDPd8rI+QgAAIEmEUQAAAGSGMAoAAIDMxAmj+XyeZacuMx8AS5YsWbJkybKrltwZBQAAQGYIowAAAMgMYRR1/uvvQ91WWR9yAAC6GmEUdbotnHXbfAEAaDWEUdRp93B2d6Fy7kb19KWNkxfWjp9dP352/fPpteEzy58VVo+dXjl2euXIxNrhr1YOji9fvbvhtf98AQBod4RR1Gn3cHbuRvXmt48u33309c3KuRvVczeqZ7+pTF+pni5WJy6VJy6Vxy9WvrxQyU9vDk2WvPafLwAA7Y4wijrtHs5OX9q4fPfRpduVc9eq01eqfgydvFQZn62MX6iMX6h8eaEyeraSn94cPrPstf98AQBod4RR1Gn3cEYYBQCgvSQfRnO5XOiB6SWhpby+9mpN6Km8IQQxwlnoaMtPvUTfIaqTF9b8D+inrlQmL/1QE7Pl0bOVkelqrfLTm/kzkT+mT/ANqe0quFI7d/XYqoRROY5HmKb1CMiN+eIAAFClcmdUvZBoLzDBp9pLhdzA1Jtnu1BBIIQzU6xRL/DWc5HUO0R1/Oz62W8q099UTxerExfLtRqZrg5PVYanKkNTZf+BexhVR9XIGzL4quNx0zaOukY4KfJTYRfaDU0HxLQywy8O8kwBAM2R1sf02gu24+XHtHmwsXZzbftQnxFm25Ws4UzOItqTrj0pDb5DTBIPo+p81YloHwhvYNPETRuaph9pjekfkXC+tGtM4xemow7JNEd1K7UT7ebxzoV2eACAJks4jJquhcIFRnstCT0Vrjdym1BvXHisGgmj6hpTOFDbxHuHqD6fXpu6UvE/o3/yjy/7H9OPTFeHpspDU+Un//jysamK/9gljKoZyDpHlzetqRPTJkL2El4V2giDdPn3qL5kOhQu75bMvzjwZQEAspVwGPWcLy1Og0s0jMJF42E0GHdcQk8j7xDVZ4XVyUuV05eqT/7xZb9OXCifuFA+Ol2urfHzqMsvMFnfbNZ5qe21udCaveThuawR/hEFxyb05hhGrdm31b448OUCALKVVhj1dFca9cqnvWKFGqi9mXZk6gruTEWMZRMAACAASURBVOFMe75MaUN9YE0MMd4hWrUwGsqjtcdHp8sxwqg8O9O8hJFrew724DJfa7fqMEznSx2DaZDWHQnjTOrUa2eR1LkAADRZimHUM1x7tC95uiuf9Yqldm7qDY6S+pje5dQ7Not0To+dXqn9nGgwg9aS6A81VR4qRPuYXju8GG9IbcxSG5vah8YjhzbtAITBCJuYZi2vdxyD/JLac7JfHPhaAQDZaokwanpVvmYIl3Pt1UV7qUZI4mFUbZbIO8QkFEZD90QTDKPapy5vSG0wcnwPy8OTtzL9o1AfNxhGczrW3WX4xYEvCwCQrYTDqHrhcbkku1yPhStW6Knp0kIYdZHGndHQJom8Q0z+e2J1fLYSqif/+PLnF8p++WH0yNTmEYc/ByokHvXt5PiG1IZR05Rl1lylzYXWdCiskQcm/NPzkjv1iX9x4MsCAGQr4TDqOVxr1aemNnID4RrP1SW2xu8UBuOONXJpX1Kfypkp6NOvVr+8UBm/+GONzVa/nK0Mf105NFOu1aeFzcMTK9b5mnbtPnhr0rK++eWxmVKmPBFTD/ImwdMaKdVpM6jX2KlP6osDXysAIHOphFHtVS10JQtdQrRXRPkaabpSBtsgKvkXmNSVMZ4m+A5RJR5G1ZELEU27Xj4app5Dh8L0D8Q0VNO2oX60vYV2ZDrsMcZs7Ufbp2nupt5Mh1c7Uw8AkLXkwyjaWrv/rfYDY6ujZytfXqh8eaHy5eyPNfx15diFyrELlcPnKgenygcLm4cm+Nv0AABkjzCKOu0ezg6MrQ5PVUbPVk6cL4+erfj1+YXysQuVo+fKR8+VD82UD06VD0xufHoq8t+mBwAAiSOMok67hzPCKAAA7YUwijrtHs72n1g+VtgYmi7npzdrNTRTPjpVPjRVPjRV/rSweWBy45OJtX+ML3ntP18AANodYRR12j2cXbm9fuzU4meTS0OTpVp9Nrl0eGLFr0MTy5+eKv1jfKl4e9Vr//kCANDuCKOo023hrNvmCwBAqyGMos5//X2o2yrrQw4AQFcjjAIAACAzhFEAAABkJk4YzefzLDt1mfkAWLJkyZIlS5ZdteTOKAAAADJDGAUAAEBmCKOo0wughWX9FQIAkkcYRZ3e3t77AFrS9PR01l8hACB5hFHU6e3tXQLQkgijADoSYRR1ent71wG0JMIogI5EGEUdfigNaFmEUQAdiTCKOoRRoGURRgF0pBTDaC4ndR56VdvYX5lTxNiX3Im2gdxnpyKMAi2LMAqgI6V7ZzSY57Tps7ZSDqPaPk0JUo2SaucuQZMwGtQ66VwYSTNH2CJHA12FMAqgIyUcRqMGxFAY1SZIUxi1rhRe1a5xvDPaOrEsDUIYbfJIPPOhjvoeSPyUdfAbAK2MMAqgI6V1Z9TxxqQQAYU2am9yG/egaZqC2pt18zaVeRiN/b1H1G9I4o2nwd6ARhBGAXSkDMJoLcy5tPHqU6m2pbBrlzXaqBoptnYSwmjj+wJSQhgF0JEyvjPa4Bp1pWN0ENbII+942jAq3I326tO82kBoU1uv7da0Rjsk0wjlfoJrQkOVt/KALBBGAXSk1H+bXkiHyi3Iugu/YxuhWXB3wqvaUZlG3vFc7oyq58hTTrd69NSXtI1NyU9o47JVvAcu+wKahjAKoCNlGUYjrVETpLb/2LsL7UUIHKYs2xkihdHgU/W4qd8SaLsyNZO3Mo3N1HNSYbSDTz1aH2EUQEdKMYx6YuaLtCZ0z1LYsJHsa723F2rZkRIMo6HG6d0ZbXCnhFG0C8IogI6UVhgNZrsY90E9c0SQw4F8kyxIHaraQ2fnTi3HX2AKHkZtGFUPtXrktc085c2jvpGinnR57+7jMe0LaA7CKICOlHAY1V7y1fXaBto12phoWmnKji67k3voHun9p/dJHVg1KSbSreOum7YvQEUYBdCR0v2YHm0npT8HStAHGkcYBdCRCKOow9+mB1oWYRRARyKMog5hFGhZhFEAHYkwijqEUaBlEUYBdCTCKOoQRoGWRRgF0JEIo6hDGAVaFmEUQEcijKLONIAWlvVXCABIHmEUAAAAmSGMAgAAIDNxwmg+n2fZqcvMB8CSJUuWLFmy7Kold0YBAACQGcIoAAAAMkMYBQAAQGYIowAAAMgMYRQAAACZIYzCydyDpcHRmZ6+/q3bd/X09Q+Ozsw9WMp6UO2BQ5c5TgEAtDLCKCyq1UcjheKWbTuf3/3B/uHx6zevfzI68eJr+7Zs2zlSKFarj7IeYOuqHbrnXtm779iJy1cv7x8+9cKrAxy6puEUAEDrSyWM5nK50IPQY/+pytqh9mmklcJeoo6qS4wUitv/8rePhsbu3Lk5N3f722/vzs/ff/hw/vDYzDM73h8pFLMeYOsaKRS3/fmdgSPHb9y4cuvWtTt3bt27d2d+/v6hE1NP79jLoWsCTgEAtL50w2jtsUsoDG0lhMJan7JQt8JITLvA3IOlLdt2qkl0cfFhqbR4dPz8lm07rZ94On5LIH/LEeMt4b53l31p9yvwD50ag/yjd+Tk2ZY6dJE6FFa6by5rnVOgTkF7UmKMM8ariRwWAGg1CYdR9StjcBlqGXVNzhwvTCtDWwlfuE3NTHPU7qvzDI7OPL/7Az+J3rp37aOrA08ef+K98+/eW7i7slJaW1t96Y0Dg6P2d0XwgekIa18VzpS6MviuU3cqdCKf0Hine3B05rlX9mpjUKm0uLKy/NLrH7faoYvRv9o+tEYYj7sMT4HncIjUYxV6bN3KtFO5ZezjCQAtJfWP6YXLm/Cq2sZTLsymTkxdhR64NNA2buSa2nZ6+vr3D4/790Q/ujqwbfapP4w9/qsPH3vnzJ61tdWNjfXhyYs9ff1yJ9bLsOlEa1t6hneCdqk+FboVhm16Xwl6+vr3HTthikFra6tDE7Otc+iETdT1LitNu4ukFU6BOnjhy4vw2KVbmdzSOgsAaFnphtFIbYQ1Lhc208rattav7+q++BK/dfuu6zev+5/OP3n8id+PPf67od9u2bvlsbd+sbGxvrm5UVpZ3bp9l9CDepBNx9bU0qWBfJatF2zHd1Sk98PW7bsuX71sikEbG+tLyyutc+hqj4PHSm3jcmxjHH+XI2BaI2j8FNSmY5pXsE3Ut5zQLGc40aaDEOPYAkDrSD6MOl54rF9PQ1/rPeXSKFwA1G21/Wj3HmzDl/ievv5PRif8C/l759/99Ye//Pn7P/vpX3+yZ+Ltzc2NSqWcLxTle0vq+8F0bOVLftSzLDx1vJarnUd6P/T09e8fPmWKQeXyZr5wqWUPXWhH8vGRpxC7vXYAzT8FnvloWN9+wQba8yLP2jTfBg8LALSatMJo8LF6TVVf0l501d5CD4JPrdcDbUvtHuWWXWVwdObF1/b5F/J7C3ffObNn61tb90y+vVB6UKmUq9Vq75sHHX/w0ZSNgs1cLq5yeFJ7VrtyWaN2Lo9KNTg688KrA6YYVK1WWurQaTuRD6/p328jDdR5mR64SOQUmI6GaVSmx8JTdRP5hDZ4WACg1SQcRkNfta0t5TWh9aav3aYrqLaxtR91qY6ne770+7+PfHhsplRa9H9jyf903k+i+TNF6+8jBxOGcM0OthHSiakTOQG4ZILEL/n+oTt0Ykobg1rt0AWfWiduHZL2cQyZn4LgToXDq30pdPyFgxbs3zR9+W3f4HEGgGy1ehh1+RIsX/y0W6mXcHUr0yyElzrSSKH4zI73j46fV5Posy8PuPxPjfI1W9ss9EC7rdrS1MB0jQ9tKwxbu6HVSKH49I69R06eVWNQqx0694kHd206vALrlN1H4qLxU6DuXThipsfuJ8szR0/3HgCgvSQcRn/o1C2MWi9Upn60V1Ph637UqyBf4oNqf8PmpTcODE9eLK2s5gvF3jcPuv8NG+1ZkC+xpqu+53CxN/WpjsfUm3bw2v5lPx661z8emphdWl7JFy61+KFziU3Wg6ZtKTSWZXsKPOc3ifBY/UInHOcmvDMBoKWkGEbluClHT1M21cZWYY3pYqDtx9SVy5Q7XiN/3Tt4OkwZSF2jPUGe4W0QuorLl3NtA+uQTOOxaotDZ+o5uD40AJfxBAcf7+hlfgo888TVEaoDdm8j9y/3wJcpAG0tlTAKBKnZJZSKTI+9wIXWFGhC26q7Cw3D9DQ0VCHPRZt8Y5p56IQG6qEzrQm9FPtwtc4p0A5GfdeFhucyfvV8hdbL+zV1CwBthzAKAACAzBBGAQAAkBnCKAAAADJDGAUAAEBmCKMAAADIDGEUAAAAmSGMAgAAIDOEUQAAAGSGMAoAAIDMEEZRpxctLOt3BwAAySOMok5vb+99tKTp6ems3x0AACSPMIo6vb29S2hJhFEAQEcijKJOb2/vOloSYRQA0JEIo6jDDya2LMIoAKAjEUZRhzDasgijAICOlHAYzdWrrVSbyWtyNqZt1Z5dXgru1KVlByOMtizCKACgI6USRoMPvH9nOyFBqk/Vbh1fkluasnIo4BJG0YIIowCAjpR8GPWU9Bk7jMr3RNX1jndPtbtTs6m2H68+Z3cebRh1nG+DRybe5qbT1HkIowCAjpTux/TWYBfc0GWl6f6lmnfV2GrqVk201jF0cPRp8M5og0fG8W2Q+H7bAmEUANCRUvkFJutdSTllqivVB+pj005DD0ypJfRqN4QbLcJoyyKMAgA6Uov+AlNopUsYFV6VV3r1WTbYVTdEnBA1jKr3lbX3udWVoaNaO6TyDXLT7qx7jzTNdkQYBQB0pCbdGbXeK1VXeg5hVAi+2t60m3j1iYcwqq40nb4YD+RDajrRocdqV91wpgijAICOlPqdUW0ESSqMure0di4/VeeoTL1DJBhGtaFf3jthVEAYBQB0pFTujNbtwBwvHCOFNaoKr4YysTAwUwYljHqN3RkNbcWd0dgIowCAjpT8nVHPEAG1tyrlO6amrYJP1dtv2q4cG7iEqs5m+plR9ZanV39G1HOhbRlqYNqR9lx7niaMym+DTkIYBQB0pLTCqOec/0w9mLKFNspoA1BoK5VpMB0fawT8p/ctizAKAOhIqX9Mj/ZCGG1ZhFEAQEcijKIOYbRlEUYBAB2JMIo6hNGWRRgFAHQkwijqEEZbFmEUANCRCKOoQxhtWYRRAEBHIoyiDmG0ZRFGAQAdiTCKOtNoYVm/OwAASB5hFAAAAJkhjAIAACAzccJoPp9n2anLzAfAkiVLlixZsuyqJXdGAQAAkBnCKAAAADJDGAUAAEBmCKNwMvdgaXB0pqevf+v2XT19/YOjM3MPlrIeFAAAaHuEUVhUq49GCsUt23Y+98refcdOXL56ef/wqRdeHdiybedIoVitPsp6gAAAoI0RRmExUihu+/M7A0eO37hx5data3fu3Lp37878/P1DJ6ae3rF3pFDMeoAAAKCNEUYhmXuwtGXbTjWJPnw4v7j48MjJs1u27XT5vD6no7bRPjZ1KDy1dlJ7Sdipy5jduQxGbubYwH13icxd21uMMcttXE63I/euIh1q6/FpcDCOjRs5MgCQFcIoJIOjM8+9slebREulxZWV5Zde/3hw1P6ukKOn9mkoA8nxqBYIZNrdmcKEy5rQgE2verbQJgdE93lphyoc6thzlwfsuG3UMas7jZe9YpyL2L15Dcwr2fd8rbHLpACgmQijkPT09e87dsKURNfWVocmZnv6+q39uFxWPeXa7NlyjGOqEEai3alpcyFtyNd4xzSmDi/qGORQkuDc5SMfbzzWNqEBm3ZtYt2XMLXQ42bOy/RUO33rMQlNFgBaAWEUkq3bd12+etmURDc21peWV7Zu32XtR73+aa/uni1taC/hoQdCAlD3LjSzdhJs5jJ3l67UgxOpgdrSfTzucxcOsnyoXUbrcmSsx1wg78tlXqYJRt2X5zav0ADUYTieiFCHpjEDQPMRRiHp6evfP3zKlETL5c184ZJ8Z9Q9uLhc49WLt0vjSC8JbUx7kXfkkiS8KMHFOn5rFhG2NbWJeoTVwQghyXHu7nlLHo+wL5eDbHqjpjSvpN7zwTYxjhsApIcwCsng6MwLrw6Ykmi1Wul982CknxmVL/Cm625tpXxh1l7U1Qu8Y46Rs4V2VNau5ADhGEpM/QRf0h5AL525a0cbbBDqQe480phjhCphX/JTdTzaN6Hjvjy3eakHUH0qM41fOzUAyARhFBL/t+kPnZjSJtH8mWIjv00fuuIGL66hDT3x8uwZYoQpCmh3rV6hE7y0m8ZpWqldkzOED3lH2klpJ6g2c5m7vC+XIWkbW9ebupJPk8DaUt1pcGzyCOPNK3SmtHsXOhQ6N70EAJkgjMJipFB8esfeIyfPqkn02ZcHHP+fUe0VVLgiytdL+cKsXrnVnbpcjE0BItJQhXG678gxZ5gaCEfDOmCXNdpuhXMkDF4ObXJGrLWXJ+j4DhRedZyROn7Tesd5CTuV3/NqV4RRAC2FMAqL2l9geun1j4cmZpeWV/KFS71vHoz0F5hCF13PcHk2BRrTStMVWggciYdR7chNGzpmxEhZM9SJNtaoS5nL3B1TnXt0c+nEZVRNCKOhIylPrfF5Nfie1w4eAFoHYRROYv9telMqMt3XMa2prTftxTNfnt1jpWnkwSkIjYWxCY+103fvx7pT95eCbeS5q4O3njKhmXsn8npr0nI5zo471b7ZTONpZF5JveeFYQBAtgijaKrg5TBSdBBCjDYqyWuCEcEUubS7s07QZRjaMVt3pB1t1JTjJTH3nDlgCfMSTp91vcuYZaYdafcrHGd1E3UXSc1L7kQ7eOuUAaAFEUYBAACQGcIoAAAAMkMYBQAAQGYIowAAAMgMYRQAAACZIYwCAAAgM4RRAAAAZIYwCgAAgMwQRuEk9l9gAgAAEKQSRmt/9kP9WyPBp/IfU5H/Doq2T+0aNKj2t+mf3/3B/uHx6zevfzI68eJr+yL9bXoAAACtdMOoF/h7d0Ib7RpTrNSGUW38RSJGCsXtf/nbR0Njd+7cnJu7/e23d+fn7z98OH94bOaZHe+PFIpZDxAAALSxhMOo9s8re3HDqPud0dADbSTlLzXHMPdgacu2nWoSXVx8WCotHh0/v2XbTsfP62unxvQmCTZzfBpaKbxnYpx97Xc4Lu9Sa4dRG0Sdl+MY3MfTyKSsbVxOMQCgg6X+Mb3pqmm9plovUcGtHK/QXOeiGhydeX73B34SvXXv2kdXB548/sR759+9t3B3ZaW0trb60hsHBkft36J4UVKmkIG0Z1DIcPLAPPFdoQ7JZTzxgqDLG9hxL554AE2vWo+/40F2P5ihp+pOtYdI2zkAoK2l/jG9exvTJcp0kQ49dt813PX09e8fHvfviX50dWDb7FN/GHv8Vx8+9s6ZPWtrqxsb68OTF3v6+uVOgqfSU85pqKXpjAtZTY5c8sBM26p71/YprzFNx2UKwvjlqamHVGipHY/6wLqhy/mS23j1B1m769BBAwB0huTDqHqhNTWT14SuSdoLpHrd4lqVrK3bd12/ed3/dP7J40/8fuzx3w39dsveLY+99YuNjfXNzY3SyurW7bvkTkyn0hPjjnW9KUjJASi0uXXY2j5NY5D7lF9Kqh9th3JL60iEY+g+JFOzUCfWuctnDQDQdtIKo8HHpsuYy3VObmbaEVespPT09X8yOuH/nOh759/99Ye//Pn7P/vpX3+yZ+Ltzc2NSqWcLxTlO6OmUxNaCqdSXu8Z4o7wINihPHLr8VHbmLaS35ZR+zFtoh5hT/ln4hmOmOMATHs0TdC6r+B7QO7KczhrAIC2k3AYNV0mTS2FNfJTx05CL3EZi2pwdObF1/b5v7F0b+HuO2f2bH1r657JtxdKDyqVcrVa7X3zoPVnRj3z/WyXyGjt0xRGQ5kmUhiVs6MwPDlvCQ3cg51pRqGV1lfl3bkMxnr6PMPZUfciDNW0UwBAZ2j1MCpfpB2jQO0lLmNR+b9Nf3hsplRa9H9jyf903k+i+TNFl9+mrx1509ITQ1KoK/WpNu5Yc5L8fgi9zdwTm/CejPS+denHvVmkHQXXC0dP+6qwU9Ou5QGoK/lXDAAdJuEw+kOnDX/AJ1/kIl3U0aCRQvGZHe8fHT+vJtFnXx6w/j+jcgx1iYy1B+q7RQ6jofeVNkdax+wyO2GNKTgK89L+cxACqHDEYgxY24l1F42HUfkIBDfh3zgAdJgUw6j1+qrdKvQ41JVXfzUSdsQVKym1v8D00hsHhicvllZW84Vi75sHo/4FJvX8ms64cB6tAStSThISj2lfwq5NgzG9OeW5CHuXB6btQf0nI/dmbWDal6lxjOm4ny8AQFtLJYyi8zT4t+lN4SaYjRzDnxpSY4dRT8w3Ucdj/S7IGiKjRkD5JSHry72pjeXU7gXOoJAgrZ3I60miANCpCKNIVzBDmJJQqIE23glBJ5S6BFFHbuow1EbdSujQfQox+tH2HKk369F2HJJpv6Zj2Pj5AgC0KcIoAAAAMkMYBQAAQGYIowAAAMgMYRQAAACZIYwCAAAgM4RRAAAAZIYwCgAAgMwQRuGkwf/0HgAAQIswCovanwN97pW9+46duHz18v7hUy+8OhD1z4ECAACoCKOwGCkUt/35nYEjx2/cuHLr1rU7d27du3dnfv7+oRNTT+/YO1IoZj1AAADQxgijkMw9WNqybaeaRB8+nF9cfHjk5Nkt23a6fF6v/ZuT1mbyS46dNPhXJeNtLm/lMkLTH8mMsS+5E20Dl1m7z0JoY9p7cAwubRzHAwBoQYRRSAZHZ557Za82iZZKiysryy+9/vHgqP1dIQcFOW0EQ4nQONS53Ca0a+1K9wBk6lmefmhe2s1Nxy3qCE0DMzFtZZ2UaSvTCE2Dkafg0kzo2eUIAACahjAKSU9f/75jJ0xJdG1tdWhitqev39pPKIXICcmU1awBRdiL0N46cvml2AExNC/taN0Dn/v4tWuE0WpH6DmcU+v4rZFUaGY9xfKJI48CQOsgjEKydfuuy1cvm5Loxsb60vLK1u275E7kDGF6ySXiWAOQ3Il7EnUZsDAAU5+mCCi00c5CzpHWToSJCzNVz1Ro4sHdNTKLYCemZWhf6mi1e7QeBwBAExBGIenp698/fMqURMvlzXzhkvXOaE4JZ0Jw0QaL0CZyutKmH20za17RPrYSNlTnJbTx6qevbSns2mWN6chrj5g8R3mE8sF0ORHaHoSV8iysZx8A0DSEUUgGR2deeHXAlESr1UrvmwflnxnVJhVtcBE2DK5R26grtWFFaCYMwNpP1A2TWqOudGkjr3GfsikumzoRMq712MYOo3KfhFEAaBGEUUj836Y/dGJKm0TzZ4qOv03viTf8PF1YkVOOdk1oc5VpPMJo5U6EzbUDDr4kjNCxjctMrcdB3aNp5NrZ5cxnx/Sq9kRYp6Ddr7ZbxynIDQAATUMYhcVIofj0jr1HTp5Vk+izLw+4/z+jQhzRvqrmGJeIJmyo7tEUR4Sg40jIQ/LctWvUoWr7j7270F7cJ2s9RME+5TTs2LOQOAmjANCmCKOwqP0Fppde/3hoYnZpeSVfuNT75sFIf4HJGpu0YdSUSoV+Qu3lXCInkkbCqLzTSGtCR0PYsJHsaz3UWsIhMn2H4CknSCX3LAwguK28FUkUAFoHYRROGvnb9O55SI0j8u0ul/hlTZwuqTFSdglOIWr0DK2JNH3T0dCmvdBQ1R6siS00R+EwymMQOhfmpR1DaKUwHnnvAIBmIowiXS550dOFD1PSEsKN6bEXK4KYdmRNXfJ6ee6mI6DdXD0m2lFZ18g9mBprNzcdAesAhGG4DzjS+QIAtAjCKAAAADJDGAUAAEBmCKMAAADIDGEUAAAAmSGMAgAAIDNxwmg+n2fZqcvMB8CSJUuWLFmy7Kold0Z/cO72yvX7q+dur/h1+uvbfh047fq/aQIAACAqwugPvi39+JeEltertTp3e2X3kQcZDgwAAKCDEUZ/cP3+qheIod+WHvk1eqn8H+8t/cd73B8FAABIHmH0B9fvr4aS6PX7q/7ywOml3UcevPvhVNZjBAAA6DSE0R/4YfTb0qMDp5f+472l3Uce+DdERy+V/fujhFEAAIDEEUZ/4IfRWgA9cHrJT6W/eeqD0UtlwigAAEAaUgmjuVwu9CD02H+qsnaorjdxGWfQ9furu488+M1TH5y7vfLCK2O/eeqDF14ZO3d7pZZHCaMAAACJSzeM1h6r6VBeI6TMUNbU9h8jjJ67vfKbpz7YfeTBt6VHfvr8zVMf/Ofbp6/fX/XXE0YBAAASl3AYVSNjvDCqXSk30N6OVcdmGvnpr2//5qkPTn992/O85fWq/9T/T0b9u6T9g1+ZtgUAAEA8qX9ML9zRtH62HimwJhtG/duiy+tV799hlDujAAAAiUv9Y3r3NtqP2qN+4h/jA3qfH0b/8+3Tnuctr1f9D+hr63cfecCdUQAAgMQlH0Ydf4XIMVM6Bk3rbVGr01/f/s+3T/s3R/07o7UH/uf1XX5ndO7B0uDoTE9f/9btu3r6+gdHZ+YetPEfAuiw6XQzTiUAtLu0wmjwsTaeunxM70UMo7GTqOd5/l+i96Pnf759+oVXxvxs6t8W7ebfpq9WH40Uilu27Xx+9wf7h8ev37z+yejEi6/t27Jt50ihWK0+snfRSmrTee6VvfuOnbh89fL+4VMvvDrQptPpZpxKAOgMyf8Ck5fQx/RR+3RpIP/M6PX7q7X/16lW/YNf+f/taNeG0ZFCcftf/vbR0NidOzfn5m5/++3d+fn7Dx/OHx6beWbH+yOFYtYDjGakUNz253cGjhy/cePKrVvX7ty5de/enfn5+4dOTD29Y2/bTaebcSoBoDO0QRh16dBlv3IYPXB6yf/P7f3/7r5/8KvQmu4Mo3MPlrZs26km0cXFh6XS4tHx81u27ZQ/FdXeAne/He7YVaTpqPHFn9GRk2et03EcaqSWph8ycZxmpMNr/TeiNrOOymVqLjuNJPFTFolUZAAACvRJREFU6dVPLeqYTSfRcXP3No7nOvFT6c46wuADeQyOIxTmKI8z5gwBJC3LX2By/CqT+3fQlBton7p798Op/sGvTOW/GqPbdjc4OvP87g/8JHrr3rWPrg48efyJ986/e2/h7spKaW1t9aU3DgyORvu7XOoJEq5e6vlVe3A/44OjM8+9slcbX0qlxZWV5Zde/9hlOvI4TStjTDn0QDgmpnFaR25qrz3UjmusL7nMXdb4qXTcr+M4tacsp3xpErqSG+Qi/iuwtndcE4m6I5fH1g6tI5R7djmqDU4cQINSDKMuX0/VrWqPQ+3V9doGwWYuQ4Wsp69///C4f0/0o6sD22af+sPY47/68LF3zuxZW1vd2FgfnrzY09fv3qF8XqyXK/XiEelE9/T17zt2whRf1tZWhyZmXaZjvSJGelWYS+glbUvhKhspr2i3lf+dmrq1XviF8+h4QpM6lcK8HNuox02doPwVST4vQnuX94MX91Rq+wnNTh6Vy2PTm8RlhO5rhJHIKwE0RyphFB1j6/Zd129e9z+df/L4E78fe/x3Q7/dsnfLY2/9YmNjfXNzo7SyunX7LvcO3S/JpsahK2ukS8jW7bsuX71sii8bG+tLyysu04l6MTNlMnUr9amaKjyHK6u2WaSUY4oI6kvCFOQ9WpOHIJFTqZ2LOiOXEZrekFEjTlL/ChI5lcJ05JPuflTlwxVjhNo16gjVBsJ6AGkjjELS09f/yeiEf7F/7/y7v/7wlz9//2c//etP9ky8vbm5UamU84Wi+/2n2rXEdP1QLxjylSbqxaOnr3//8ClTfCmXN/OFS453RoXLpHa99iquvRJrG1g7MY1E7kedl8vc5TWmCYYehw6X+wB8SZ1K0yyitpHPvnZ9qIFnfgPIx1w7qkROpbrGdKYcT3rtgUs/LtzfydYjFmPvAJJCGIVkcHTmxdf2+Rf7ewt33zmzZ+tbW/dMvr1QelCplKvVau+bBx1/ZtQlk7lcMEztHafzwqsDpvhSrVYcp+Ny+bdexWuXZCGghNYIB8p6POXBB/eln7N5c3mmjoPJ6lSaZhG1jcuhk/tJ8F9BUqdSXZNIGA31Y33nm/6ByP98hFfV3ZmmD6A5CKOQ+L+zfHhsplRa9H9jyf903k+i+TNFx99ZdrzQRroMx7hy+NM5dGJKG19iTEcevOnq69VfKYVuTVupbYR9hRqbLsbBp/IF2/GKrh28dnem0QoaP5WRYoowwlD7SEfGNDB5j8GXhCG5jMc6a8cp5JQ3kty5th/3Yy43s/Zj6tNxXwASRxiFxUih+MyO94+On1eT6LMvD1j/N0fTRUj71BMvsfKGjkYKxad37D1y8qwaX1ymU9u7cK2VL7qhB/I1stam1r+1jTASIWo4HnZhAOp4TGuCc5EjiyyRUynMK1Ibl3QVOgLCfBv5V5DgqVTXaKfpmWft/tg0YMe3h/zvyKWBsB5A2gijsKj9nZuX3jgwPHmxtLKaLxR73zwY7+/cNHjJDzaId+X4cTqvfzw0Mbu0vJIvXIo6Hflqp1475WRmmpS2B/V6bNpF8CXTERP27j53dTzWNGDa0Lr3oEROZaS9O4ZRU3ISTkSM8cjntC3CqBo0hbhpGqE8GOtIrBsCaALCKJwk9RfArVeaUH4yNdA+ddfgdOSrneN1OrjGeqU0RVhTe+tIHBto+5TTg/uVvsEw6mvOO9PaxnpqQmlV3kvj/woaP5XqetMZD+7R5c2vbenIZabx3mnxxgMgEamEUeuXWu1K+Uuh/HVQ25WwifZLpOOAo34hC30JNvUZdZptyvHsq+uFY9L8w+X+zgyefe073HO+mpreh+6H1Drm4KE2NbOOVj6P8njUiTSBfPpk6ubaGVnnLgxDbSPMIvjUNP5Qm1An8rGSqcNznJpphGpLYXcubYKjktcAaKYUw6j1i6D1q4/1saf7AmT9QmPqIRe4ckQavEv70LbyCF2mCQAA0AHSDaPqSvWx+lRub93WMRqqg7RmVsfRmkai3akwC8e9AAAAtK/kw2goeAXXa1uagqPLTUdTt8IaUzSUh+fpwmjUEQrNrJ2YpgYAANDWEg6jQm4LtrEGSnUTU2NrpDOFP/cBmCZl7cH6ktCGMAoAALpBih/Tax+o613yYqQcKadGzxAu1W7lMOoYfNV5CUOS1wgzAgAAaFPphlHPHPXUluqG1hucag/ChqFXvfrEGXwaauwyZnXK2h6EWcjTNE0WAACgraUeRtWnnnMYtT5271yIcabkZ+pNyJranbokSGEW1pUAAADtqxl3RuW8aLod2GAYDd0BVdtY+zHt15o+1ZGoPQs7chwPAABAB8jgZ0ZdIprjHVP1JTWDqhlX7SFS8guNX/vUpR91DKZcHqkrAACANpJWGBUyn3Bb1HQvU73ZKe8rtEfPnDhDuxAam2KidU1o8Np+rBFWmCYAAED7SiWMAgAAAC4IowAAAMgMYRQAAACZIYyiTj6fZ8mSJUuWLFmybNoychgFAAAAkhI5jG5UHlIURVEURVFUIkUYpSiKoiiKojIrwihFURRFURSVWRFGKYqiKIqiqMyKMEpRFEVRFEVlVoRRiqIoiqIoKrMijFIURVEURVGZFWGUoiiKoiiKyqwIoxRFURRFUVRmlUoYXWs3X3zxRXqHOOvJRZbq0aAoiqIoigpWKmF0od3s3bs3vUOc9eQiS/VoUBRFURRFBYswurCwsLB79+70DnHWk4ss1aNBURRFURQVrFTC6N1286c//Sm9Q5z15CJL9WhQFEVRFEUFizB69+7du88//3x6hzjryUWW6tGgKIqiKIoKVkuH0VwuF/vVSFozjGonmPu3BqZrQRilKIqiKKpp1UJhNBdgWqNuEjNw1WvNMFqboHAccqIWPBoURVEURVHBaqEwGoxfd+uDpjaetkv8auRoqIcikZdkhFGKoiiKoppWrRtGtWtS+uC+9cOoKXYTRimKoiiKautqrTAayp2J3PV00YJhNDhrIaBr7xmHXoqKMEpRFEVRVNOq5cJoKIGFolW3fUyvPRTqYZEfREUYpSiKoiiqaZVKGL0Wi58m/Qe1p0HaTeLtKyTV+NXIwIIHRH2qvqR9EBVhlKIoiqKoplULhdFQ2NLmsKTyVki7hNFrypSDhyKU2gmjFEVRFEW1frV0GDXdGdUmsEaCabuEUWs2VbeNgTBKURRFUVTTquXCqPphvRqtuurOaOwjQBilKIqiKKr1q+XCqHapPlDvETaiNcOoyxzV+8eN3yomjFIURVEU1bRqrTAazFhq5Lqm3B1si/jV+BEQZsqdUYqiKIqi2rpSCaPFdpNq/Mp6cpERRimKoiiKaloRRotFwmg9wihFURRFUU0rwmixSBitRxilKIqiKKppRRgtFgmj9QijFEVRFEU1rVIJowsLC8Vi8Ysvvti7d+/u3bv/9Kc/Pd/y0jvEHA2KoiiKoihTpRJGKYqiKIqiKMqlCKMURVEURVFUZkUYpSiKoiiKojIrwihFURRFURSVWRFGKYqiKIqiqMwqchgF0Ez//Ods1kMAusvlK//MeghAd4kWRgEAAIAEEUYBAACQGcIoAAAAMkMYBQAAQGYIowAAAMgMYRQAAACZIYwCAAAgM4RRAAAAZIYwCgAAgMwQRgEAAJAZwigAAAAyQxgFAABAZgijAAAAyAxhFAAAAJkhjAIAACAzhFEAAABkhjAKAACAzBBGAQAAkBnCKAAAADJDGAUAAEBmCKMAAADIDGEUAAAAmfn/AQDOjBS+F1JMAAAAAElFTkSuQmCC)
这个很简单:我们可以参考https://blog.csdn.net/langyu1021/article/details/52460660
下面是关键:
下面要实现的是让{dede:arclist idlist='自定义字段'}生效,我们需要修改include\taglib下的arclist.lib.php文件
修改后的代码为(
或直接联系QQ286601999,索要arclist.lib.php文件,替换即可)
<?php if(!defined('DEDEINC')) exit('Request Error!');
/**
* 文章列表调用标记
*
* 9:19 2010年7月13日:修正对isweight属性的支持
*
* @version $Id: arclist.lib.php 3 9:19 2010年7月13日Z tianya $
* @package DedeCMS.Taglib
* @copyright Copyright (c) 2007 - 2010, DesDev, Inc.
* @license http://help.dedecms.com/usersguide/license.html
* @link http://www.dedecms.com
*/
/**
* arclist解析标签
*
* @access public
* @param object $ctag 解析标签
* @param object $refObj 引用对象
* @return string 成功后返回解析后的标签内容
*/
/*>>dede>>
<name>文档列表</name>
<type>全局标记</type>
<for>V55,V56,V57</for>
<description>获取指定文档列表</description>
<demo>
{dede:arclist flag='h' typeid='' row='' col='' titlelen='' infolen='' imgwidth='' imgheight='' listtype='' orderby='' keyword='' limit='0,1'}
<a href='[field:arcurl/]'>[field:title/]</a>
{/dede:arclist}
</demo>
<attributes>
<iterm>col:分多少列显示(默认为单列),5.3版中本属性可以通过多种方式进行多行显示</iterm>
<iterm>row:返回文档列表总数</iterm>
<iterm>typeid:栏目ID,在列表模板和档案模板中一般不需要指定,在首页模板中允许用","分开表示多个栏目</iterm>
<iterm>getall:在没有指定这属性的情况下,在栏目页、文章页模板,不会获取以","分开的多个栏目的下级子类</iterm>
<iterm>titlelen:标题长度 等同于titlelength</iterm>
<iterm>infolen:表示内容简介长度 等同于infolength</iterm>
<iterm>imgwidth:缩略图宽度</iterm>
<iterm>imgheight:缩略图高度</iterm>
<iterm>listtype: 栏目类型 image含有缩略图 commend推荐</iterm>
<iterm>orderby:文档排序方式</iterm>
<iterm>keyword:含有指定关键字的文档列表,多个关键字用","分</iterm>
<iterm>innertext:单条记录样式</iterm>
<iterm>aid:指定文档ID</iterm>
<iterm>idlist:提取特定文档(文档ID</iterm>
<iterm>channelid:频道ID</iterm>
<iterm>limit:(起始ID从0开始)表示限定的记录范围(如:limit='1,2' 表示从ID为1的记录开始,取2条记录</iterm>
<iterm>flag:自定义属性值:头条[h]推荐[c]图片[p]幻灯[f]滚动[s]跳转[j]图文[a]加粗[b]</iterm>
<iterm>noflag:同flag,但这里是表示不包含这些属性</iterm>
<iterm>orderway:值为 desc 或 asc ,指定排序方式是降序还是顺向排序,默认为降序</iterm>
<iterm>subday:表示在多少天以内的文档</iterm>
</attributes>
>>dede>>*/
function lib_arclist( &$ctag, &$refObj )
{
global $envs;
$autopartid = 0;
$tagid = '';
$tagname = $ctag->GetTagName();
$channelid = $ctag->GetAtt('channelid');
//增加对分页内容的处理
$pagesize = $ctag->GetAtt('pagesize');
if($pagesize == '')
{
$multi = 0;
} else {
$tagid = $ctag->GetAtt('tagid');
}
// arclist是否需要weight排序,默认为"N",如果需要排序则设置为"Y"
$isweight = $ctag->GetAtt('isweight');
if($tagname=='imglist' || $tagname=='imginfolist') {
$listtype = 'image';
}
else if($tagname=='specart') {
$channelid = -1;
$listtype='';
}
else if($tagname=='coolart') {
$listtype = 'commend';
}
else if($tagname=='autolist') {
$autopartid = $ctag->GetAtt('partsort');
}
else {
$listtype = $ctag->GetAtt('type');
}
//排序
if($ctag->GetAtt('sort')!='') $orderby = $ctag->GetAtt('sort');
else if($tagname=='hotart') $orderby = 'click';
else $orderby = $ctag->GetAtt('orderby');
//对相应的标记使用不同的默认innertext
if(trim($ctag->GetInnerText()) != '') $innertext = $ctag->GetInnerText();
else if($tagname=='imglist') $innertext = GetSysTemplets('part_imglist.htm');
else if($tagname=='imginfolist') $innertext = GetSysTemplets('part_imginfolist.htm');
else $innertext = GetSysTemplets("part_arclist.htm");
//兼容titlelength
if($ctag->GetAtt('titlelength')!='') $titlelen = $ctag->GetAtt('titlelength');
else $titlelen = $ctag->GetAtt('titlelen');
//兼容infolength
if($ctag->GetAtt('infolength')!='') $infolen = $ctag->GetAtt('infolength');
else $infolen = $ctag->GetAtt('infolen');
$typeid = trim($ctag->GetAtt('typeid'));
if(empty($typeid)) {
$typeid = ( isset($refObj->Fields['typeid']) ? $refObj->Fields['typeid'] : $envs['typeid'] );
}
$idlist = $ctag->GetAtt('idlist');
if(!empty($idlist)){
if($idlist == 'typesnews'){
$idlist = isset($refObj->Fields['typesnews']) ? $refObj->Fields['typesnews'] : '';
if(empty($idlist)){
$idlist = '0';
}
}
}
if($listtype=='autolist') {
$typeid = lib_GetAutoChannelID($ctag->GetAtt('partsort'),$typeid);
}
if($ctag->GetAtt('att')=='') {
$flag = $ctag->GetAtt('flag');
}
else {
$flag = $ctag->GetAtt('att');
}
return lib_arclistDone
(
$refObj, $ctag, $typeid, $ctag->GetAtt('row'), $ctag->GetAtt('col'), $titlelen, $infolen,
$ctag->GetAtt('imgwidth'), $ctag->GetAtt('imgheight'), $listtype, $orderby,
$ctag->GetAtt('keyword'), $innertext, $envs['aid'], $idlist, $channelid,
$ctag->GetAtt('limit'), $flag,$ctag->GetAtt('orderway'), $ctag->GetAtt('subday'), $ctag->GetAtt('noflag'),
$tagid,$pagesize,$isweight
);
}
/**
* arclist解析函数
*
* @access public
* @param object $refObj 引用对象
* @param object $ctag 标签
* @param int $typeid 栏目ID
* @param int $row 调用行数
* @param int $titlelen 字符串长度
* @param int $infolen 描述信息长度
* @param int $imgwidth 图片宽度
* @param int $imgheight 图片高度
* @param string $listtype 列表类型
* @param string $orderby 排列顺序
* @param string $keyword 关键词
* @param string $innertext 底层模板
* @param int $arcid 文档ID
* @param string $idlist ID列表
* @param int $channelid 频道ID
* @param string $limit 限制
* @param string $att 属性
* @param string $order 排序类型
* @param int $subday 天内
* @param string $noflag 属性标记
* @param string $tagid 标签id
* @param string $pagesize 显示条数
* @param string $isweight 是否需要对检索出来的内容按照weight排序
* @return string
*/
function lib_arclistDone(&$refObj, &$ctag, $typeid=0, $row=10, $col=1, $titlelen=30, $infolen=160,
$imgwidth=120, $imgheight=90, $listtype='all', $orderby='default', $keyword='',
$innertext='', $arcid=0, $idlist='', $channelid=0, $limit='', $att='', $order='desc', $subday=0, $noflag='',$tagid='', $pagesize=0, $isweight='N')
{
global $dsql,$PubFields,$cfg_keyword_like,$cfg_index_cache,$_arclistEnv,$envs,$cfg_cache_type,$cfg_digg_update;
$row = AttDef($row,10);
$titlelen = AttDef($titlelen,30);
$infolen = AttDef($infolen,160);
$imgwidth = AttDef($imgwidth,120);
$imgheight = AttDef($imgheight,120);
$listtype = AttDef($listtype,'all');
$arcid = AttDef($arcid,0);
$channelid = AttDef($channelid,0);
$orderby = AttDef($orderby,'default');
$orderWay = AttDef($order,'desc');
$subday = AttDef($subday,0);
$pagesize = AttDef($pagesize,0);
$line = $row;
$orderby = strtolower($orderby);
$keyword = trim($keyword);
$innertext = trim($innertext);
$tablewidth = $ctag->GetAtt('tablewidth');
$writer = $ctag->GetAtt('writer');
if($tablewidth == "") $tablewidth = 100;
if(empty($col)) $col = 1;
$colWidth = ceil(100/$col);
$tablewidth = $tablewidth."%";
$colWidth = $colWidth."%";
//记录属性,以便分页样式统一调用
$attarray = compact("row", "titlelen", 'infolen', 'imgwidth', 'imgheight', 'listtype',
'arcid', 'channelid', 'orderby', 'orderWay', 'subday','pagesize',
'orderby', 'keyword', 'tablewidth', 'col', 'colWidth');
if($innertext=='') $innertext = GetSysTemplets('part_arclist.htm');
if( @$ctag->GetAtt('getall') == 1 ) $getall = 1;
else $getall = 0;
if($att=='0') $att='';
if($att=='3') $att='f';
if($att=='1') $att='h';
$orwheres = array();
$maintable = 'dede_archives';
//按不同情况设定SQL条件 排序方式
if($idlist=='')
{
if($orderby=='near' && $cfg_keyword_like=='N') { $keyword=''; }
if($writer=='this') {
$wmid = isset($refObj->Fields['mid']) ? $refObj->Fields['mid'] : 0;
$orwheres[] = " arc.mid = '$wmid' ";
}
//时间限制(用于调用最近热门文章、热门评论之类),这里的时间只能计算到天,否则缓存功能将无效
if($subday > 0)
{
$ntime = gmmktime(0, 0, 0, gmdate('m'), gmdate('d'), gmdate('Y'));
$limitday = $ntime - ($subday * 24 * 3600);
$orwheres[] = " arc.senddate > $limitday ";
}
//关键字条件
if($keyword!='')
{
$keyword = str_replace(',', '|', $keyword);
$orwheres[] = " CONCAT(arc.title,arc.keywords) REGEXP '$keyword' ";
}
//文档属性
if(preg_match('/commend/i', $listtype)) $orwheres[] = " FIND_IN_SET('c', arc.flag)>0 ";
if(preg_match('/image/i', $listtype)) $orwheres[] = " FIND_IN_SET('p', arc.flag)>0 ";
if($att != '') {
$flags = explode(',', $att);
for($i=0; isset($flags[$i]); $i++) $orwheres[] = " FIND_IN_SET('{$flags[$i]}', arc.flag)>0 ";
}
if(!empty($typeid) && $typeid != 'top')
{
//指定了多个栏目时,不再获取子类的id
if( preg_match('#,#', $typeid) )
{
//指定了getall属性或主页模板例外
if($getall==1 || empty($refObj->Fields['typeid']))
{
$typeids = explode(',', $typeid);
foreach($typeids as $ttid) {
$typeidss[] = GetSonIds($ttid);
}
$typeidStr = join(',', $typeidss);
$typeidss = explode(',', $typeidStr);
$typeidssok = array_unique($typeidss);
$typeid = join(',', $typeidssok);
}
$orwheres[] = " arc.typeid IN ($typeid) ";
}
else
{
//处理交叉栏目
$CrossID = '';
if($ctag->GetAtt('cross')=='1')
{
$arr = $dsql->GetOne("SELECT `id`,`topid`,`cross`,`crossid`,`ispart`,`typename` FROM `dede_arctype` WHERE id='$typeid' ");
if( $arr['cross']==0 || ( $arr['cross']==2 && trim($arr['crossid']=='') ) )
{
$orwheres[] = ' arc.typeid IN ('.GetSonIds($typeid).')';
}
else
{
$selquery = '';
if($arr['cross']==1) {
$selquery = "SELECT id,topid FROM `dede_arctype` WHERE typename LIKE '{$arr['typename']}' AND id<>'{$typeid}' AND topid<>'{$typeid}' ";
}
else {
$arr['crossid'] = preg_replace('#[^0-9,]#', '', trim($arr['crossid']));
if($arr['crossid']!='') $selquery = "SELECT id,topid FROM `dede_arctype` WHERE id IN('{$arr['crossid']}') AND id<>'{$typeid}' AND topid<>'{$typeid}' ";
}
if($selquery!='')
{
$dsql->SetQuery($selquery);
$dsql->Execute();
while($arr = $dsql->GetArray())
{
$CrossID .= ($CrossID=='' ? $arr['id'] : ','.$arr['id']);
}
}
}
}
if($CrossID=='') $orwheres[] = ' arc.typeid IN ('.GetSonIds($typeid).')';
else $orwheres[] = ' arc.typeid IN ('.GetSonIds($typeid).','.$CrossID.')';
}
}
//频道ID
if(preg_match('#spec#i', $listtype)) $channelid==-1;
if(!empty($channelid)) $orwheres[] = " And arc.channel = '$channelid' ";
if(!empty($noflag))
{
if(!preg_match('#,#', $noflag))
{
$orwheres[] = " FIND_IN_SET('$noflag', arc.flag)<1 ";
}
else
{
$noflags = explode(',', $noflag);
foreach($noflags as $noflag) {
if(trim($noflag)=='') continue;
$orwheres[] = " FIND_IN_SET('$noflag', arc.flag)<1 ";
}
}
}
$orwheres[] = ' arc.arcrank > -1 ';
//由于这个条件会导致缓存功能失去意义,因此取消
//if($arcid!=0) $orwheres[] = " arc.id<>'$arcid' ";
}
//文档排序的方式
$ordersql = '';
if($orderby=='hot' || $orderby=='click') $ordersql = " ORDER BY arc.click $orderWay";
else if($orderby == 'sortrank' || $orderby=='pubdate') $ordersql = " ORDER BY arc.sortrank $orderWay";
else if($orderby == 'id') $ordersql = " ORDER BY arc.id $orderWay";
else if($orderby == 'near') $ordersql = " ORDER BY ABS(arc.id - ".$arcid.")";
else if($orderby == 'lastpost') $ordersql = " ORDER BY arc.lastpost $orderWay";
else if($orderby == 'scores') $ordersql = " ORDER BY arc.scores $orderWay";
//功能:增加按好评数和差评数调用
else if($orderby == 'goodpost') $ordersql = " order by arc.goodpost $orderWay";
else if($orderby == 'badpost') $ordersql = " order by arc.badpost $orderWay";
else if($orderby == 'rand') $ordersql = " ORDER BY rand()";
else $ordersql = " ORDER BY arc.sortrank $orderWay";
if($orderby == 'idlist' && $idlist!=''){
$ordersql = "ORDER BY FIELD(arc.id,$idlist) ";
}
//limit条件
$limit = trim(preg_replace('#limit#is', '', $limit));
if($limit!='')
{
$limitsql = " LIMIT $limit ";
$limitarr = explode(',', $limit);
$line = isset($limitarr[1])? $limitarr[1] : $line;
}
else $limitsql = " LIMIT 0,$line ";
$orwhere = '';
if(isset($orwheres[0])) {
$orwhere = join(' And ',$orwheres);
$orwhere = preg_replace("#^ And#is", '', $orwhere);
$orwhere = preg_replace("#And[ ]{1,}And#is", 'And ', $orwhere);
}
if($orwhere!='') $orwhere = " WHERE $orwhere ";
//获取附加表信息
$addfield = trim($ctag->GetAtt('addfields'));
$addfieldsSql = '';
$addfieldsSqlJoin = '';
if($addfield != '' && !empty($channelid))
{
$row = $dsql->GetOne("SELECT addtable FROM `dede_channeltype` WHERE id='$channelid' ");
if(isset($row['addtable']) && trim($row['addtable']) != '')
{
$addtable = trim($row['addtable']);
$addfields = explode(',', $addfield);
$row['addtable'] = trim($row['addtable']);
$addfieldsSql = ",addf.".join(',addf.', $addfields);
$addfieldsSqlJoin = " LEFT JOIN `$addtable` addf ON addf.aid = arc.id ";
}
}
$query = "SELECT arc.*,tp.typedir,tp.typename,tp.corank,tp.isdefault,tp.defaultname,tp.namerule,
tp.namerule2,tp.ispart,tp.moresite,tp.siteurl,tp.sitepath
$addfieldsSql
FROM `$maintable` arc LEFT JOIN `dede_arctype` tp on arc.typeid=tp.id
$addfieldsSqlJoin
$orwhere $ordersql $limitsql";
//统一hash
$taghash = md5(serialize($ctag).$typeid);
$needSaveCache = true;
//进行tagid的默认处理
if($pagesize > 0) $tagid = AttDef($tagid,'tag'.$taghash );
if($idlist!='' || $GLOBALS['_arclistEnv']=='index' || $cfg_index_cache==0)
{
$needSaveCache = false;
}
else
{
$idlist = GetArclistCache($taghash);
if($idlist != '') {
$needSaveCache = false;
}
//如果使用的是内容缓存,直接返回结果
if($cfg_cache_type=='content' && $idlist != '')
{
$idlist = ($idlist==0 ? '' : $idlist);
return $idlist;
}
}
//指定了id或使用缓存中的id
if($idlist != '')
{
$query = "SELECT arc.*,tp.typedir,tp.typename,tp.corank,tp.isdefault,tp.defaultname,tp.namerule,tp.namerule2,tp.ispart,
tp.moresite,tp.siteurl,tp.sitepath
$addfieldsSql
FROM `$maintable` arc left join `dede_arctype` tp on arc.typeid=tp.id
$addfieldsSqlJoin
WHERE arc.id in($idlist) $ordersql ";
}
// 好评差评缓存更新
if($cfg_digg_update > 0)
{
if($orderby == 'goodpost' || $orderby == 'badpost')
{
$t1 = ExecTime();
$postsql = "SELECT arc.id,arc.goodpost,arc.badpost,arc.scores
FROM `$maintable` arc
$orwhere $ordersql $limitsql";
if($idlist != '')
{
$postsql = "SELECT arc.id,arc.goodpost,arc.badpost,arc.scores
FROM `$maintable` arc
WHERE arc.id in($idlist) $ordersql ";
}
$dsql->SetQuery($query);
$dsql->Execute('lit');
while ($row = $dsql->GetArray('lit')) {
$prefix = 'diggCache';
$key = 'aid-'.$row['id'];
$cacherow = GetCache($prefix, $key);
$setsql = array();
if(!empty($cacherow['scores']) && $cacherow['scores'] != $row['scores'])
{
$setsql[] = "scores = {$cacherow['scores']}";
}
if(!empty($cacherow['goodpost']) && $cacherow['goodpost'] != $row['goodpost'])
{
$setsql[] = "goodpost = {$cacherow['goodpost']}";
}
if(!empty($cacherow['badpost']) && $cacherow['badpost'] != $row['badpost'])
{
$setsql[] = "badpost = {$cacherow['badpost']}";
}
$setsql = implode(',', $setsql);
$sql = "UPDATE `$maintable` SET {$setsql} WHERE id='{$row['id']}'";
if(!empty($setsql))
{
$dsql->ExecuteNoneQuery($sql);
}
}
//echo ExecTime()-$t1;
}
}
$dsql->SetQuery($query);
$dsql->Execute('al');
//$row = $dsql->GetArray("al");
$artlist = '';
if($pagesize > 0) $artlist .= " <div id='{$tagid}'>\r\n";
if($col > 1) $artlist = "<table width='$tablewidth' border='0' cellspacing='0' cellpadding='0'>\r\n";
$dtp2 = new DedeTagParse();
$dtp2->SetNameSpace('field', '[', ']');
$dtp2->LoadString($innertext);
$GLOBALS['autoindex'] = 0;
$ids = array();
$orderWeight = array();
for($i=0; $i<$line; $i++)
{
if($col>1) $artlist .= "<tr>\r\n";
for($j=0; $j<$col; $j++)
{
if($col>1) $artlist .= " <td width='$colWidth'>\r\n";
if($row = $dsql->GetArray("al"))
{
$ids[] = $row['id'];
//处理一些特殊字段
$row['info'] = $row['infos'] = cn_substr($row['description'],$infolen);
$row['id'] = $row['id'];
if($row['corank'] > 0 && $row['arcrank']==0)
{
$row['arcrank'] = $row['corank'];
}
$row['filename'] = $row['arcurl'] = GetFileUrl($row['id'],$row['typeid'],$row['senddate'],$row['title'],$row['ismake'],
$row['arcrank'],$row['namerule'],$row['typedir'],$row['money'],$row['filename'],$row['moresite'],$row['siteurl'],$row['sitepath']);
$row['typeurl'] = GetTypeUrl($row['typeid'],$row['typedir'],$row['isdefault'],$row['defaultname'],$row['ispart'],
$row['namerule2'],$row['moresite'],$row['siteurl'],$row['sitepath']);
if($row['litpic'] == '-' || $row['litpic'] == '')
{
$row['litpic'] = $GLOBALS['cfg_cmspath'].'/images/defaultpic.gif';
}
if(!preg_match("#^http:\/\/#i", $row['litpic']) && $GLOBALS['cfg_multi_site'] == 'Y')
{
$row['litpic'] = $GLOBALS['cfg_mainsite'].$row['litpic'];
}
$row['picname'] = $row['litpic'];
$row['stime'] = GetDateMK($row['pubdate']);
$row['typelink'] = "<a href='".$row['typeurl']."'>".$row['typename']."</a>";
$row['image'] = "<img src='".$row['picname']."' border='0' width='$imgwidth' height='$imgheight' alt='".preg_replace("#['><]#", "", $row['title'])."'>";
$row['imglink'] = "<a href='".$row['filename']."'>".$row['image']."</a>";
$row['fulltitle'] = $row['title'];
$row['title'] = cn_substr($row['title'], $titlelen);
if($row['color']!='') $row['title'] = "<font color='".$row['color']."'>".$row['title']."</font>";
if(preg_match('#b#', $row['flag'])) $row['title'] = "<strong>".$row['title']."</strong>";
//$row['title'] = "<b>".$row['title']."</b>";
$row['textlink'] = "<a href='".$row['filename']."'>".$row['title']."</a>";
$row['plusurl'] = $row['phpurl'] = $GLOBALS['cfg_phpurl'];
$row['memberurl'] = $GLOBALS['cfg_memberurl'];
$row['templeturl'] = $GLOBALS['cfg_templeturl'];
if(is_array($dtp2->CTags))
{
foreach($dtp2->CTags as $k=>$ctag)
{
if($ctag->GetName()=='array')
{
//传递整个数组,在runphp模式中有特殊作用
$dtp2->Assign($k, $row);
} else {
if(isset($row[$ctag->GetName()])) $dtp2->Assign($k,$row[$ctag->GetName()]);
else $dtp2->Assign($k, '');
}
}
$GLOBALS['autoindex']++;
}
if($pagesize > 0)
{
if($GLOBALS['autoindex'] <= $pagesize)
{
$liststr = $dtp2->GetResult();
$artlist .= $liststr."\r\n";
} else {
$artlist .= "";
$orderWeight[] = array(
'weight' => $row['weight'],
'arclist' => ''
);
}
} else {
$liststr = $dtp2->GetResult();
$artlist .= $liststr."\r\n";
}
$orderWeight[] = array(
'weight' => $row['weight'],
'arclist' => $liststr
);
}//if hasRow
else{
$artlist .= '';
}
// 进行判断,如果启用排序则内容输出为重新排序后的内容
// var_dump($isweight=='y' && count($orderWeight) == $line);
$isweight = strtolower($isweight);
if ( $isweight=='y' )
{
$artlist = '';
$orderWeight = list_sort_by($orderWeight, 'weight', 'asc');
foreach ($orderWeight as $vv) {
$artlist .= $vv['arclist'];
}
}
if($col>1) $artlist .= " </td>\r\n";
}//Loop Col
if($col>1) $i += $col - 1;
if($col>1) $artlist .= " </tr>\r\n";
}//loop line
if($col>1) $artlist .= " </table>\r\n";
$dsql->FreeResult("al");
$idsstr = join(',', $ids);
//分页特殊处理
if($pagesize > 0)
{
$artlist .= " </div>\r\n";
$row = $dsql->GetOne("SELECT tagid FROM dede_arcmulti WHERE tagid='$tagid'");
$uptime = time();
$attstr = addslashes(serialize($attarray));
$innertext = addslashes($innertext);
if(!is_array($row))
{
$query = "
INSERT INTO dede_arcmulti(tagid,uptime,innertext,pagesize,arcids,ordersql,addfieldsSql,addfieldsSqlJoin,attstr)
VALUES('$tagid','$uptime','$innertext','$pagesize','$idsstr','$ordersql','$addfieldsSql','$addfieldsSqlJoin','$attstr');
";
$dsql->ExecuteNoneQuery($query);
} else {
$query = "UPDATE `dede_arcmulti`
SET
uptime='$uptime',
innertext='$innertext',
pagesize='$pagesize',
arcids='$idsstr',
ordersql='$ordersql',
addfieldsSql='$addfieldsSql',
addfieldsSqlJoin='$addfieldsSqlJoin',
attstr='$attstr'
WHERE tagid='$tagid'
";
$dsql->ExecuteNoneQuery($query);
}
}
//保存ID缓存
if($needSaveCache)
{
if($idsstr=='') $idsstr = '0';
if($cfg_cache_type=='content' && $idsstr!='0') {
$idsstr = addslashes($artlist);
}
$inquery = "INSERT INTO `dede_arccache`(`md5hash`,`uptime`,`cachedata`) VALUES ('".$taghash."','".time()."', '$idsstr'); ";
$dsql->ExecuteNoneQuery("DELETE FROM `dede_arccache` WHERE md5hash='".$taghash."' ");
$dsql->ExecuteNoneQuery($inquery);
}
return $artlist;
}
/**
* 查询缓存
*
* @access public
* @param string $md5hash 唯一识别hash
* @return string
*/
function GetArclistCache($md5hash)
{
global $dsql,$envs,$cfg_makesign_cache,$cfg_index_cache,$cfg_cache_type;
if($cfg_index_cache <= 0) return '';
if(isset($envs['makesign']) && $cfg_makesign_cache=='N') return '';
$mintime = time() - $cfg_index_cache;
$arr = $dsql->GetOne("SELECT cachedata,uptime FROM `dede_arccache` WHERE md5hash = '$md5hash' ");
if(!is_array($arr)) {
return '';
}
else if($arr['uptime'] < $mintime) {
return '';
}
else {
return $arr['cachedata'];
}
}
/**
* 获取自动频道ID
*
* @access public
* @param string $sortid
* @param string $topid
* @return string
*/
function lib_GetAutoChannelID($sortid, $topid)
{
global $dsql;
if(empty($sortid)) $sortid = 1;
$getstart = $sortid - 1;
$row = $dsql->GetOne("SELECT id,typename FROM dede_arctype WHERE reid='{$topid}' And ispart<2 And ishidden<>'1' ORDER BY sortrank asc limit $getstart,1");
if(!is_array($row)) return 0;
else return $row['id'];
}
/**
* 对查询结果集进行排序
*
* @access public
* @param array $list 查询结果
* @param string $field 排序的字段名
* @param array $sortby 排序类型
* asc正向排序 desc逆向排序 nat自然排序
* @return array
*/
function list_sort_by($list, $field, $sortby='asc') {
if(is_array($list)){
$refer = $resultSet = array();
foreach ($list as $i => $data)
$refer[$i] = &$data[$field];
switch ($sortby) {
case 'asc': // 正向排序
asort($refer);
break;
case 'desc':// 逆向排序
arsort($refer);
break;
case 'nat': // 自然排序
natcasesort($refer);
break;
}
foreach ( $refer as $key=> $val)
$resultSet[] = &$list[$key];
return $resultSet;
}
return false;
}<?php if(!defined('DEDEINC')) exit('Request Error!');
/**
* 文章列表调用标记
*
* 9:19 2010年7月13日:修正对isweight属性的支持
*
* @version $Id: arclist.lib.php 3 9:19 2010年7月13日Z tianya $
* @package DedeCMS.Taglib
* @copyright Copyright (c) 2007 - 2010, DesDev, Inc.
* @license http://help.dedecms.com/usersguide/license.html
* @link http://www.dedecms.com
*/
/**
* arclist解析标签
*
* @access public
* @param object $ctag 解析标签
* @param object $refObj 引用对象
* @return string 成功后返回解析后的标签内容
*/
/*>>dede>>
<name>文档列表</name>
<type>全局标记</type>
<for>V55,V56,V57</for>
<description>获取指定文档列表</description>
<demo>
{dede:arclist flag='h' typeid='' row='' col='' titlelen='' infolen='' imgwidth='' imgheight='' listtype='' orderby='' keyword='' limit='0,1'}
<a href='[field:arcurl/]'>[field:title/]</a>
{/dede:arclist}
</demo>
<attributes>
<iterm>col:分多少列显示(默认为单列),5.3版中本属性可以通过多种方式进行多行显示</iterm>
<iterm>row:返回文档列表总数</iterm>
<iterm>typeid:栏目ID,在列表模板和档案模板中一般不需要指定,在首页模板中允许用","分开表示多个栏目</iterm>
<iterm>getall:在没有指定这属性的情况下,在栏目页、文章页模板,不会获取以","分开的多个栏目的下级子类</iterm>
<iterm>titlelen:标题长度 等同于titlelength</iterm>
<iterm>infolen:表示内容简介长度 等同于infolength</iterm>
<iterm>imgwidth:缩略图宽度</iterm>
<iterm>imgheight:缩略图高度</iterm>
<iterm>listtype: 栏目类型 image含有缩略图 commend推荐</iterm>
<iterm>orderby:文档排序方式</iterm>
<iterm>keyword:含有指定关键字的文档列表,多个关键字用","分</iterm>
<iterm>innertext:单条记录样式</iterm>
<iterm>aid:指定文档ID</iterm>
<iterm>idlist:提取特定文档(文档ID</iterm>
<iterm>channelid:频道ID</iterm>
<iterm>limit:(起始ID从0开始)表示限定的记录范围(如:limit='1,2' 表示从ID为1的记录开始,取2条记录</iterm>
<iterm>flag:自定义属性值:头条[h]推荐[c]图片[p]幻灯[f]滚动[s]跳转[j]图文[a]加粗[b]</iterm>
<iterm>noflag:同flag,但这里是表示不包含这些属性</iterm>
<iterm>orderway:值为 desc 或 asc ,指定排序方式是降序还是顺向排序,默认为降序</iterm>
<iterm>subday:表示在多少天以内的文档</iterm>
</attributes>
>>dede>>*/
function lib_arclist( &$ctag, &$refObj )
{
global $envs;
$autopartid = 0;
$tagid = '';
$tagname = $ctag->GetTagName();
$channelid = $ctag->GetAtt('channelid');
//增加对分页内容的处理
$pagesize = $ctag->GetAtt('pagesize');
if($pagesize == '')
{
$multi = 0;
} else {
$tagid = $ctag->GetAtt('tagid');
}
// arclist是否需要weight排序,默认为"N",如果需要排序则设置为"Y"
$isweight = $ctag->GetAtt('isweight');
if($tagname=='imglist' || $tagname=='imginfolist') {
$listtype = 'image';
}
else if($tagname=='specart') {
$channelid = -1;
$listtype='';
}
else if($tagname=='coolart') {
$listtype = 'commend';
}
else if($tagname=='autolist') {
$autopartid = $ctag->GetAtt('partsort');
}
else {
$listtype = $ctag->GetAtt('type');
}
//排序
if($ctag->GetAtt('sort')!='') $orderby = $ctag->GetAtt('sort');
else if($tagname=='hotart') $orderby = 'click';
else $orderby = $ctag->GetAtt('orderby');
//对相应的标记使用不同的默认innertext
if(trim($ctag->GetInnerText()) != '') $innertext = $ctag->GetInnerText();
else if($tagname=='imglist') $innertext = GetSysTemplets('part_imglist.htm');
else if($tagname=='imginfolist') $innertext = GetSysTemplets('part_imginfolist.htm');
else $innertext = GetSysTemplets("part_arclist.htm");
//兼容titlelength
if($ctag->GetAtt('titlelength')!='') $titlelen = $ctag->GetAtt('titlelength');
else $titlelen = $ctag->GetAtt('titlelen');
//兼容infolength
if($ctag->GetAtt('infolength')!='') $infolen = $ctag->GetAtt('infolength');
else $infolen = $ctag->GetAtt('infolen');
$typeid = trim($ctag->GetAtt('typeid'));
if(empty($typeid)) {
$typeid = ( isset($refObj->Fields['typeid']) ? $refObj->Fields['typeid'] : $envs['typeid'] );
}
$idlist = $ctag->GetAtt('idlist');
if(!empty($idlist)){
if($idlist == 'typesnews'){
$idlist = isset($refObj->Fields['typesnews']) ? $refObj->Fields['typesnews'] : '';
if(empty($idlist)){
$idlist = '0';
}
}
}
if($listtype=='autolist') {
$typeid = lib_GetAutoChannelID($ctag->GetAtt('partsort'),$typeid);
}
if($ctag->GetAtt('att')=='') {
$flag = $ctag->GetAtt('flag');
}
else {
$flag = $ctag->GetAtt('att');
}
return lib_arclistDone
(
$refObj, $ctag, $typeid, $ctag->GetAtt('row'), $ctag->GetAtt('col'), $titlelen, $infolen,
$ctag->GetAtt('imgwidth'), $ctag->GetAtt('imgheight'), $listtype, $orderby,
$ctag->GetAtt('keyword'), $innertext, $envs['aid'], $idlist, $channelid,
$ctag->GetAtt('limit'), $flag,$ctag->GetAtt('orderway'), $ctag->GetAtt('subday'), $ctag->GetAtt('noflag'),
$tagid,$pagesize,$isweight
);
}
/**
* arclist解析函数
*
* @access public
* @param object $refObj 引用对象
* @param object $ctag 标签
* @param int $typeid 栏目ID
* @param int $row 调用行数
* @param int $titlelen 字符串长度
* @param int $infolen 描述信息长度
* @param int $imgwidth 图片宽度
* @param int $imgheight 图片高度
* @param string $listtype 列表类型
* @param string $orderby 排列顺序
* @param string $keyword 关键词
* @param string $innertext 底层模板
* @param int $arcid 文档ID
* @param string $idlist ID列表
* @param int $channelid 频道ID
* @param string $limit 限制
* @param string $att 属性
* @param string $order 排序类型
* @param int $subday 天内
* @param string $noflag 属性标记
* @param string $tagid 标签id
* @param string $pagesize 显示条数
* @param string $isweight 是否需要对检索出来的内容按照weight排序
* @return string
*/
function lib_arclistDone(&$refObj, &$ctag, $typeid=0, $row=10, $col=1, $titlelen=30, $infolen=160,
$imgwidth=120, $imgheight=90, $listtype='all', $orderby='default', $keyword='',
$innertext='', $arcid=0, $idlist='', $channelid=0, $limit='', $att='', $order='desc', $subday=0, $noflag='',$tagid='', $pagesize=0, $isweight='N')
{
global $dsql,$PubFields,$cfg_keyword_like,$cfg_index_cache,$_arclistEnv,$envs,$cfg_cache_type,$cfg_digg_update;
$row = AttDef($row,10);
$titlelen = AttDef($titlelen,30);
$infolen = AttDef($infolen,160);
$imgwidth = AttDef($imgwidth,120);
$imgheight = AttDef($imgheight,120);
$listtype = AttDef($listtype,'all');
$arcid = AttDef($arcid,0);
$channelid = AttDef($channelid,0);
$orderby = AttDef($orderby,'default');
$orderWay = AttDef($order,'desc');
$subday = AttDef($subday,0);
$pagesize = AttDef($pagesize,0);
$line = $row;
$orderby = strtolower($orderby);
$keyword = trim($keyword);
$innertext = trim($innertext);
$tablewidth = $ctag->GetAtt('tablewidth');
$writer = $ctag->GetAtt('writer');
if($tablewidth == "") $tablewidth = 100;
if(empty($col)) $col = 1;
$colWidth = ceil(100/$col);
$tablewidth = $tablewidth."%";
$colWidth = $colWidth."%";
//记录属性,以便分页样式统一调用
$attarray = compact("row", "titlelen", 'infolen', 'imgwidth', 'imgheight', 'listtype',
'arcid', 'channelid', 'orderby', 'orderWay', 'subday','pagesize',
'orderby', 'keyword', 'tablewidth', 'col', 'colWidth');
if($innertext=='') $innertext = GetSysTemplets('part_arclist.htm');
if( @$ctag->GetAtt('getall') == 1 ) $getall = 1;
else $getall = 0;
if($att=='0') $att='';
if($att=='3') $att='f';
if($att=='1') $att='h';
$orwheres = array();
$maintable = 'dede_archives';
//按不同情况设定SQL条件 排序方式
if($idlist=='')
{
if($orderby=='near' && $cfg_keyword_like=='N') { $keyword=''; }
if($writer=='this') {
$wmid = isset($refObj->Fields['mid']) ? $refObj->Fields['mid'] : 0;
$orwheres[] = " arc.mid = '$wmid' ";
}
//时间限制(用于调用最近热门文章、热门评论之类),这里的时间只能计算到天,否则缓存功能将无效
if($subday > 0)
{
$ntime = gmmktime(0, 0, 0, gmdate('m'), gmdate('d'), gmdate('Y'));
$limitday = $ntime - ($subday * 24 * 3600);
$orwheres[] = " arc.senddate > $limitday ";
}
//关键字条件
if($keyword!='')
{
$keyword = str_replace(',', '|', $keyword);
$orwheres[] = " CONCAT(arc.title,arc.keywords) REGEXP '$keyword' ";
}
//文档属性
if(preg_match('/commend/i', $listtype)) $orwheres[] = " FIND_IN_SET('c', arc.flag)>0 ";
if(preg_match('/image/i', $listtype)) $orwheres[] = " FIND_IN_SET('p', arc.flag)>0 ";
if($att != '') {
$flags = explode(',', $att);
for($i=0; isset($flags[$i]); $i++) $orwheres[] = " FIND_IN_SET('{$flags[$i]}', arc.flag)>0 ";
}
if(!empty($typeid) && $typeid != 'top')
{
//指定了多个栏目时,不再获取子类的id
if( preg_match('#,#', $typeid) )
{
//指定了getall属性或主页模板例外
if($getall==1 || empty($refObj->Fields['typeid']))
{
$typeids = explode(',', $typeid);
foreach($typeids as $ttid) {
$typeidss[] = GetSonIds($ttid);
}
$typeidStr = join(',', $typeidss);
$typeidss = explode(',', $typeidStr);
$typeidssok = array_unique($typeidss);
$typeid = join(',', $typeidssok);
}
$orwheres[] = " arc.typeid IN ($typeid) ";
}
else
{
//处理交叉栏目
$CrossID = '';
if($ctag->GetAtt('cross')=='1')
{
$arr = $dsql->GetOne("SELECT `id`,`topid`,`cross`,`crossid`,`ispart`,`typename` FROM `dede_arctype` WHERE id='$typeid' ");
if( $arr['cross']==0 || ( $arr['cross']==2 && trim($arr['crossid']=='') ) )
{
$orwheres[] = ' arc.typeid IN ('.GetSonIds($typeid).')';
}
else
{
$selquery = '';
if($arr['cross']==1) {
$selquery = "SELECT id,topid FROM `dede_arctype` WHERE typename LIKE '{$arr['typename']}' AND id<>'{$typeid}' AND topid<>'{$typeid}' ";
}
else {
$arr['crossid'] = preg_replace('#[^0-9,]#', '', trim($arr['crossid']));
if($arr['crossid']!='') $selquery = "SELECT id,topid FROM `dede_arctype` WHERE id IN('{$arr['crossid']}') AND id<>'{$typeid}' AND topid<>'{$typeid}' ";
}
if($selquery!='')
{
$dsql->SetQuery($selquery);
$dsql->Execute();
while($arr = $dsql->GetArray())
{
$CrossID .= ($CrossID=='' ? $arr['id'] : ','.$arr['id']);
}
}
}
}
if($CrossID=='') $orwheres[] = ' arc.typeid IN ('.GetSonIds($typeid).')';
else $orwheres[] = ' arc.typeid IN ('.GetSonIds($typeid).','.$CrossID.')';
}
}
//频道ID
if(preg_match('#spec#i', $listtype)) $channelid==-1;
if(!empty($channelid)) $orwheres[] = " And arc.channel = '$channelid' ";
if(!empty($noflag))
{
if(!preg_match('#,#', $noflag))
{
$orwheres[] = " FIND_IN_SET('$noflag', arc.flag)<1 ";
}
else
{
$noflags = explode(',', $noflag);
foreach($noflags as $noflag) {
if(trim($noflag)=='') continue;
$orwheres[] = " FIND_IN_SET('$noflag', arc.flag)<1 ";
}
}
}
$orwheres[] = ' arc.arcrank > -1 ';
//由于这个条件会导致缓存功能失去意义,因此取消
//if($arcid!=0) $orwheres[] = " arc.id<>'$arcid' ";
}
//文档排序的方式
$ordersql = '';
if($orderby=='hot' || $orderby=='click') $ordersql = " ORDER BY arc.click $orderWay";
else if($orderby == 'sortrank' || $orderby=='pubdate') $ordersql = " ORDER BY arc.sortrank $orderWay";
else if($orderby == 'id') $ordersql = " ORDER BY arc.id $orderWay";
else if($orderby == 'near') $ordersql = " ORDER BY ABS(arc.id - ".$arcid.")";
else if($orderby == 'lastpost') $ordersql = " ORDER BY arc.lastpost $orderWay";
else if($orderby == 'scores') $ordersql = " ORDER BY arc.scores $orderWay";
//功能:增加按好评数和差评数调用
else if($orderby == 'goodpost') $ordersql = " order by arc.goodpost $orderWay";
else if($orderby == 'badpost') $ordersql = " order by arc.badpost $orderWay";
else if($orderby == 'rand') $ordersql = " ORDER BY rand()";
else $ordersql = " ORDER BY arc.sortrank $orderWay";
if($orderby == 'idlist' && $idlist!=''){
$ordersql = "ORDER BY FIELD(arc.id,$idlist) ";
}
//limit条件
$limit = trim(preg_replace('#limit#is', '', $limit));
if($limit!='')
{
$limitsql = " LIMIT $limit ";
$limitarr = explode(',', $limit);
$line = isset($limitarr[1])? $limitarr[1] : $line;
}
else $limitsql = " LIMIT 0,$line ";
$orwhere = '';
if(isset($orwheres[0])) {
$orwhere = join(' And ',$orwheres);
$orwhere = preg_replace("#^ And#is", '', $orwhere);
$orwhere = preg_replace("#And[ ]{1,}And#is", 'And ', $orwhere);
}
if($orwhere!='') $orwhere = " WHERE $orwhere ";
//获取附加表信息
$addfield = trim($ctag->GetAtt('addfields'));
$addfieldsSql = '';
$addfieldsSqlJoin = '';
if($addfield != '' && !empty($channelid))
{
$row = $dsql->GetOne("SELECT addtable FROM `dede_channeltype` WHERE id='$channelid' ");
if(isset($row['addtable']) && trim($row['addtable']) != '')
{
$addtable = trim($row['addtable']);
$addfields = explode(',', $addfield);
$row['addtable'] = trim($row['addtable']);
$addfieldsSql = ",addf.".join(',addf.', $addfields);
$addfieldsSqlJoin = " LEFT JOIN `$addtable` addf ON addf.aid = arc.id ";
}
}
$query = "SELECT arc.*,tp.typedir,tp.typename,tp.corank,tp.isdefault,tp.defaultname,tp.namerule,
tp.namerule2,tp.ispart,tp.moresite,tp.siteurl,tp.sitepath
$addfieldsSql
FROM `$maintable` arc LEFT JOIN `dede_arctype` tp on arc.typeid=tp.id
$addfieldsSqlJoin
$orwhere $ordersql $limitsql";
//统一hash
$taghash = md5(serialize($ctag).$typeid);
$needSaveCache = true;
//进行tagid的默认处理
if($pagesize > 0) $tagid = AttDef($tagid,'tag'.$taghash );
if($idlist!='' || $GLOBALS['_arclistEnv']=='index' || $cfg_index_cache==0)
{
$needSaveCache = false;
}
else
{
$idlist = GetArclistCache($taghash);
if($idlist != '') {
$needSaveCache = false;
}
//如果使用的是内容缓存,直接返回结果
if($cfg_cache_type=='content' && $idlist != '')
{
$idlist = ($idlist==0 ? '' : $idlist);
return $idlist;
}
}
//指定了id或使用缓存中的id
if($idlist != '')
{
$query = "SELECT arc.*,tp.typedir,tp.typename,tp.corank,tp.isdefault,tp.defaultname,tp.namerule,tp.namerule2,tp.ispart,
tp.moresite,tp.siteurl,tp.sitepath
$addfieldsSql
FROM `$maintable` arc left join `dede_arctype` tp on arc.typeid=tp.id
$addfieldsSqlJoin
WHERE arc.id in($idlist) $ordersql ";
}
// 好评差评缓存更新
if($cfg_digg_update > 0)
{
if($orderby == 'goodpost' || $orderby == 'badpost')
{
$t1 = ExecTime();
$postsql = "SELECT arc.id,arc.goodpost,arc.badpost,arc.scores
FROM `$maintable` arc
$orwhere $ordersql $limitsql";
if($idlist != '')
{
$postsql = "SELECT arc.id,arc.goodpost,arc.badpost,arc.scores
FROM `$maintable` arc
WHERE arc.id in($idlist) $ordersql ";
}
$dsql->SetQuery($query);
$dsql->Execute('lit');
while ($row = $dsql->GetArray('lit')) {
$prefix = 'diggCache';
$key = 'aid-'.$row['id'];
$cacherow = GetCache($prefix, $key);
$setsql = array();
if(!empty($cacherow['scores']) && $cacherow['scores'] != $row['scores'])
{
$setsql[] = "scores = {$cacherow['scores']}";
}
if(!empty($cacherow['goodpost']) && $cacherow['goodpost'] != $row['goodpost'])
{
$setsql[] = "goodpost = {$cacherow['goodpost']}";
}
if(!empty($cacherow['badpost']) && $cacherow['badpost'] != $row['badpost'])
{
$setsql[] = "badpost = {$cacherow['badpost']}";
}
$setsql = implode(',', $setsql);
$sql = "UPDATE `$maintable` SET {$setsql} WHERE id='{$row['id']}'";
if(!empty($setsql))
{
$dsql->ExecuteNoneQuery($sql);
}
}
//echo ExecTime()-$t1;
}
}
$dsql->SetQuery($query);
$dsql->Execute('al');
//$row = $dsql->GetArray("al");
$artlist = '';
if($pagesize > 0) $artlist .= " <div id='{$tagid}'>\r\n";
if($col > 1) $artlist = "<table width='$tablewidth' border='0' cellspacing='0' cellpadding='0'>\r\n";
$dtp2 = new DedeTagParse();
$dtp2->SetNameSpace('field', '[', ']');
$dtp2->LoadString($innertext);
$GLOBALS['autoindex'] = 0;
$ids = array();
$orderWeight = array();
for($i=0; $i<$line; $i++)
{
if($col>1) $artlist .= "<tr>\r\n";
for($j=0; $j<$col; $j++)
{
if($col>1) $artlist .= " <td width='$colWidth'>\r\n";
if($row = $dsql->GetArray("al"))
{
$ids[] = $row['id'];
//处理一些特殊字段
$row['info'] = $row['infos'] = cn_substr($row['description'],$infolen);
$row['id'] = $row['id'];
if($row['corank'] > 0 && $row['arcrank']==0)
{
$row['arcrank'] = $row['corank'];
}
$row['filename'] = $row['arcurl'] = GetFileUrl($row['id'],$row['typeid'],$row['senddate'],$row['title'],$row['ismake'],
$row['arcrank'],$row['namerule'],$row['typedir'],$row['money'],$row['filename'],$row['moresite'],$row['siteurl'],$row['sitepath']);
$row['typeurl'] = GetTypeUrl($row['typeid'],$row['typedir'],$row['isdefault'],$row['defaultname'],$row['ispart'],
$row['namerule2'],$row['moresite'],$row['siteurl'],$row['sitepath']);
if($row['litpic'] == '-' || $row['litpic'] == '')
{
$row['litpic'] = $GLOBALS['cfg_cmspath'].'/images/defaultpic.gif';
}
if(!preg_match("#^http:\/\/#i", $row['litpic']) && $GLOBALS['cfg_multi_site'] == 'Y')
{
$row['litpic'] = $GLOBALS['cfg_mainsite'].$row['litpic'];
}
$row['picname'] = $row['litpic'];
$row['stime'] = GetDateMK($row['pubdate']);
$row['typelink'] = "<a href='".$row['typeurl']."'>".$row['typename']."</a>";
$row['image'] = "<img src='".$row['picname']."' border='0' width='$imgwidth' height='$imgheight' alt='".preg_replace("#['><]#", "", $row['title'])."'>";
$row['imglink'] = "<a href='".$row['filename']."'>".$row['image']."</a>";
$row['fulltitle'] = $row['title'];
$row['title'] = cn_substr($row['title'], $titlelen);
if($row['color']!='') $row['title'] = "<font color='".$row['color']."'>".$row['title']."</font>";
if(preg_match('#b#', $row['flag'])) $row['title'] = "<strong>".$row['title']."</strong>";
//$row['title'] = "<b>".$row['title']."</b>";
$row['textlink'] = "<a href='".$row['filename']."'>".$row['title']."</a>";
$row['plusurl'] = $row['phpurl'] = $GLOBALS['cfg_phpurl'];
$row['memberurl'] = $GLOBALS['cfg_memberurl'];
$row['templeturl'] = $GLOBALS['cfg_templeturl'];
if(is_array($dtp2->CTags))
{
foreach($dtp2->CTags as $k=>$ctag)
{
if($ctag->GetName()=='array')
{
//传递整个数组,在runphp模式中有特殊作用
$dtp2->Assign($k, $row);
} else {
if(isset($row[$ctag->GetName()])) $dtp2->Assign($k,$row[$ctag->GetName()]);
else $dtp2->Assign($k, '');
}
}
$GLOBALS['autoindex']++;
}
if($pagesize > 0)
{
if($GLOBALS['autoindex'] <= $pagesize)
{
$liststr = $dtp2->GetResult();
$artlist .= $liststr."\r\n";
} else {
$artlist .= "";
$orderWeight[] = array(
'weight' => $row['weight'],
'arclist' => ''
);
}
} else {
$liststr = $dtp2->GetResult();
$artlist .= $liststr."\r\n";
}
$orderWeight[] = array(
'weight' => $row['weight'],
'arclist' => $liststr
);
}//if hasRow
else{
$artlist .= '';
}
// 进行判断,如果启用排序则内容输出为重新排序后的内容
// var_dump($isweight=='y' && count($orderWeight) == $line);
$isweight = strtolower($isweight);
if ( $isweight=='y' )
{
$artlist = '';
$orderWeight = list_sort_by($orderWeight, 'weight', 'asc');
foreach ($orderWeight as $vv) {
$artlist .= $vv['arclist'];
}
}
if($col>1) $artlist .= " </td>\r\n";
}//Loop Col
if($col>1) $i += $col - 1;
if($col>1) $artlist .= " </tr>\r\n";
}//loop line
if($col>1) $artlist .= " </table>\r\n";
$dsql->FreeResult("al");
$idsstr = join(',', $ids);
//分页特殊处理
if($pagesize > 0)
{
$artlist .= " </div>\r\n";
$row = $dsql->GetOne("SELECT tagid FROM dede_arcmulti WHERE tagid='$tagid'");
$uptime = time();
$attstr = addslashes(serialize($attarray));
$innertext = addslashes($innertext);
if(!is_array($row))
{
$query = "
INSERT INTO dede_arcmulti(tagid,uptime,innertext,pagesize,arcids,ordersql,addfieldsSql,addfieldsSqlJoin,attstr)
VALUES('$tagid','$uptime','$innertext','$pagesize','$idsstr','$ordersql','$addfieldsSql','$addfieldsSqlJoin','$attstr');
";
$dsql->ExecuteNoneQuery($query);
} else {
$query = "UPDATE `dede_arcmulti`
SET
uptime='$uptime',
innertext='$innertext',
pagesize='$pagesize',
arcids='$idsstr',
ordersql='$ordersql',
addfieldsSql='$addfieldsSql',
addfieldsSqlJoin='$addfieldsSqlJoin',
attstr='$attstr'
WHERE tagid='$tagid'
";
$dsql->ExecuteNoneQuery($query);
}
}
//保存ID缓存
if($needSaveCache)
{
if($idsstr=='') $idsstr = '0';
if($cfg_cache_type=='content' && $idsstr!='0') {
$idsstr = addslashes($artlist);
}
$inquery = "INSERT INTO `dede_arccache`(`md5hash`,`uptime`,`cachedata`) VALUES ('".$taghash."','".time()."', '$idsstr'); ";
$dsql->ExecuteNoneQuery("DELETE FROM `dede_arccache` WHERE md5hash='".$taghash."' ");
$dsql->ExecuteNoneQuery($inquery);
}
return $artlist;
}
/**
* 查询缓存
*
* @access public
* @param string $md5hash 唯一识别hash
* @return string
*/
function GetArclistCache($md5hash)
{
global $dsql,$envs,$cfg_makesign_cache,$cfg_index_cache,$cfg_cache_type;
if($cfg_index_cache <= 0) return '';
if(isset($envs['makesign']) && $cfg_makesign_cache=='N') return '';
$mintime = time() - $cfg_index_cache;
$arr = $dsql->GetOne("SELECT cachedata,uptime FROM `dede_arccache` WHERE md5hash = '$md5hash' ");
if(!is_array($arr)) {
return '';
}
else if($arr['uptime'] < $mintime) {
return '';
}
else {
return $arr['cachedata'];
}
}
/**
* 获取自动频道ID
*
* @access public
* @param string $sortid
* @param string $topid
* @return string
*/
function lib_GetAutoChannelID($sortid, $topid)
{
global $dsql;
if(empty($sortid)) $sortid = 1;
$getstart = $sortid - 1;
$row = $dsql->GetOne("SELECT id,typename FROM dede_arctype WHERE reid='{$topid}' And ispart<2 And ishidden<>'1' ORDER BY sortrank asc limit $getstart,1");
if(!is_array($row)) return 0;
else return $row['id'];
}
/**
* 对查询结果集进行排序
*
* @access public
* @param array $list 查询结果
* @param string $field 排序的字段名
* @param array $sortby 排序类型
* asc正向排序 desc逆向排序 nat自然排序
* @return array
*/
function list_sort_by($list, $field, $sortby='asc') {
if(is_array($list)){
$refer = $resultSet = array();
foreach ($list as $i => $data)
$refer[$i] = &$data[$field];
switch ($sortby) {
case 'asc': // 正向排序
asort($refer);
break;
case 'desc':// 逆向排序
arsort($refer);
break;
case 'nat': // 自然排序
natcasesort($refer);
break;
}
foreach ( $refer as $key=> $val)
$resultSet[] = &$list[$key];
return $resultSet;
}
return false;
}
修改完成后前台就可以使用
{dede:arclist idlist='typesnews' orderby='idlist' }进行调用
typesnews是你的自定义字段名
orderby='idlist' 是按照你填写的文章id顺序显示到前台,你可在后台自定义字段的地方填写1,3,2按填写顺序调用多个文章
厉害吧,如果觉得有用千万别忘了收藏。如有不明白处咨询QQ:286601999,免费为您解答。