• 文章介绍
  • 快速创建属于你自己的Discuz论坛小程序

    环境

    本环境是自己在公司的生产环境,不同的环境,可能需要部分修改,才能实现。

    1. PHP 5.2
    2. IIS 7
    3. Discuz X3.2
    4. Windows Server 2008

    安装方式

    1. 将本仓库下的 wmapi 放到 Discuz 论坛的根目录下 ,访问 https://你的网址/wmapi/wmapi_install.php
    2. 填写你的小程序 appid 以及 appsecret 进行安装(至此,论坛接口已安装完成)
    3. wmapp 即为小程序源码,微信提供的开发者工具打开
    4. 修改 app.js 下的 base_url 以及 svr_url 为你的网址

      base_url: ‘https://www.xxxx.com/’

      svr_url: ‘https://www.xxxx.com/wmapi/’

      最后的斜杠一定要加!

    (其他细节部分,例如小程序的申请,请自行谷歌、或者百度)

    这个小程序是公司针对一个自家产品的需求,而这个产品就是 Discuz (我知道没啥人用了,就不要吐槽了),版本是 X3.2 ,还是 GBK 编码!

    在公司给了需求,稍微学习了一下小程序,就直接开干了,网上找到一个基础版本(可耻的不全是自己写的),修复了一些 BUG,新增了一部分功能,也砍掉了一部分功能,兼容了 GBK 版本的 Discuz,简单设计了一下小程序的样式,产品也就基本成型了。

    之所以分享出来,是因为关于 Discuz 相关的文档、产品之类真的是太少了,想在一个平台上记录下来,如果碰见有缘人,没准能给他一些收获。 0.0\

    我的收获

    1. 关于 API 的开发有了一些理解(正好 Summer 大神出新书了,买了等更完再看)
    2. 微信公众号开发(原生 PHP 开发微信公众号,以及超神的 Easywechat)
      也成功让公司论坛关联了 公众号,实现在公众号上,领取论坛金钱红包。
    3. 微信小程序开发(官方文档,正在开发的小程序的源码,都给了我不少启发)
    4. HTTP 到 HTTPS
    5. 小程序上富文本的解析 (一个优秀的开源项目:wxParse-微信小程序富文本解析组件 )
      作用在于:解析你论坛上的帖子内容,你论坛上加粗的文字,加了颜色的文字,图片等等,都可以原原本本的展示在小程序中。
    6. Flex 布局
      这里分享阮老师的两篇文章 Flex 布局教程:语法篇Flex 布局教程:实例篇
    7. 两个 UI 组件 weuizanui
    8. …..

    部分细节

    主要有以下几点功能,需要记录

    第一节

    1. file_get_content() 函数,在论坛上有可能无法使用,已经在 inc.php 文件中实现相同功能的
    1. get_url_content() 函数。
    2. function get_url_content($url) {
    3. $ch = curl_init();
    4. curl_setopt($ch, CURLOPT_URL, $url);
    5. # curl_setopt($ch, CURLOPT_HEADER, 1);
    6. curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    7. curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
    8. curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
    9. if (!curl_exec($ch)) {
    10. error_log(curl_error($ch));
    11. $data = ”;
    12. } else {
    13. $data = curl_multi_getcontent($ch);
    14. }
    15. curl_close($ch);
    16. return $data;
    17. }
    1. 由于论坛整体格式为 GBK,而和微信服务端交互,必须为 UTF-8 编码,所以对接口编码进行了一部分的优化。

    输出的情况下,有 error.php 下的 array_iconv() 函数,来对输出数组进行编码的转换。

    1. static function array_iconv($str, $in_charset = “UTF-8”, $out_charset = CHARSET) {
    2. if (is_array($str)) {
    3. foreach ($str as $k => $v) {
    4. $str[$k] = WmApiError::array_iconv($v, $in_charset, $out_charset);
    5. }
    6. return $str;
    7. } else {
    8. if (is_string($str)) {
    9. // return iconv(‘UTF-8’, ‘GBK//IGNORE’, $str); return mb_convert_encoding($str, $out_charset, $in_charset);
    10. } else {
    11. return $str;
    12. }
    13. }

    接受的情况下, 有 inc.php 下的 getDataForCharset() 函数来整合接受编码。

    1. function getDataForCharset($data) {
    2. return (CHARSET != ‘UTF-8’) ? dhtmlspecialchars(WmApiError::array_iconv($data)) : dhtmlspecialchars($data);
    3. }
    1. 关闭了微信登陆的功能。
    2. 获取帖子时新增了帖子的具体内容,message。
    3. 优化了其他一些细节部分的内容。

    第二节

    wxParse 做的事情

    1. 输出帖子时,对 Discuz Code 进行解码,同时,获取图片附件,以及表情图片。
    2. 接受时,解析文本的加粗、高亮、斜体、字体等。让帖子呈原样输出。
    3. 以上功能,重点在 wmapi/get_post_detail.php 、 wmapi/get_self_post.php 两个脚本中重点突出。

    第三节

    1. 部分获取小程序的数据的方式为 get_url_content() 部分为 file_get_content() (生产环境可能由于设置问题,导致如此怪异,请结合自身服务器来看)
    2. 首页新增加载状态 (加载中… 没有更多… 暂无数据…)
    3. 群组帖子,无法显示群组的名称
    4. 在小程序向服务器传递中文字符串的时候,先 encodeURI() 再到论坛服务器上 urldecode() 最后进行 UTF8 -> GBK 的转码,当然,是有必要的情况下。

    基础展示

    开源Discuz小程序源码
    开源Discuz小程序源码
    【小程序源码网资源版权风险说明】:
    本站为避免不必要的纷争,分享的所有资源中一切可能有版权风险的资源将全部转载自第三方网站或平台,站长只为大家提供相关资源的介绍和跳转引导。 因可能有疏忽大意,所以如有遗漏资源侵犯了您的合法权利,请联系站长删除。
    【小程序源码网资源下载使用说明】:
    本站所分享的一切QQ小程序源码,thinkphp整站源码,微信小程序源码,图文教程等资源仅供用户学习参考使用,任何人不得作其他用途,违者自行承担所有责任。
    【小程序源码网毫无人看的介绍】:
    本站又称Z站,原名贼娘网,开站于2018年,换过三任站长,目前站长是第四任站长,本站是一个主要分享免费开源小程序源码/网站源码/免费素材/教程资源的网站,主要小程序资源有用于学习的小程序源码,也有正版原创可商用的小程序源码,是一个公益博客型网站。
    【小程序源码网原创源码版权申明】:
    未经小程序源码网许可,任何人不得擅自使用本站原创首发源码进行商业行为(除本站VIP用户在期限内,版权无使用限制),否则将依法承担相应赔偿责任。
    【小程序源码网转载文章版权申明】:
    本站所转载的QQ小程序或微信小程序源码与其他资源仅供学习,任何人不得作其他用途,违者自行承担所有责任。
    【小程序源码网站长最后的屁话】:
    如有您认为本站有任何侵犯您合法权益的文章,或者您有什么疑问需求,欢迎联系站长QQ,站长24小时在线,备注公司名称和源码版权问题或者需要小程序定制开发等站长业务类型可急速处理,如果您只是交流小程序的一些开发问题或源码问题可以加入QQ群讨论,就不用加站长啦,对于白嫖党,QQ群才是处理问题的天堂,当然站长也欢迎大家骚扰~
    小程序源码网 » 开源Discuz小程序源码

    发表评论

    嘿,投喂下嘛!