RSSHelper正式开源

一.项目背景

没流量,然后还想看博客。所以想要纯文本的,方便阅读的,就想到了RSS

试过一些RSS订阅app,有些重要源无法解析,例如FEX周刊、奇舞周刊、国外站点等等。另外,对于没有提供RSS的网页,也没有办法订阅,所以决定自己搓一个

  • 抓取展示RSS最新10条(包括目录摘要和post内容)
  • 夜间模式(当时经常在晚上看)

当时会点安卓,偷懒采用安卓壳包着WebView容器的方式实现,看上了WebView在内容排版上的巨大优势

现在已经搬到了iOS,长这样子:

rsshelper_ios

二.安卓Hybrid App

把WebView作为容器,所有内容都是离线页面,没有服务,靠安卓跨域,没有持久存储(sqlite),甚至连基本的内存缓存都没有

遇到一些问题:

  • XML解析,用jsoup
  • 线程通信(抓取HTML和RSS并解析的过程在子线程)
  • 跨域,由安卓来请求,绕过去了
  • 安卓与JS双向通信(包括JS接口注入和WebView历史栈管理)

靠这样一个很弱的玩具找到了第一份实习工作,当时前端基础不好,除了个人网站首页(首页是自己做的,内容等都是wordpress)外,拿不出能看的项目,Java仅限于安卓玩具和SSH配出来的Hello World,这个小玩具可能是作为加分项了吧(猜测)

自己用了半年的样子,后来知道了有更合适的方式:ionic之类的依赖Cordova实现的跨平台方案

三.ionic应用

2个月的前期准备(跟着计划走,学了一点PHP,一些angular),花1周时间做好了:

  • PHP服务现场抓取RSS/HTML
  • 内存缓存 + 本地缓存,简单过期策略
  • 签名发布,正规安卓应用

遇到一些问题:

  • JSONP跨域,接angular
  • simplexml_load_file原生模块解析XML
  • splash闪屏、inappbrowser插件版本兼容性

相比纯手写的安卓应用,ionic开发遇到了更多问题,而且更难解决,很多奇怪的问题无法定位,只能google

四.PHP服务更新

simplexml_load_file原生模块很脆弱,遇到不合法的XML/HTML就报错,而且从XML角度解析RSS要手动兼容各种feed格式,例如RSS 2.0、Atom 1.0等等

RSS换过simplexml,也不支持某些不规范的feed格式,后来RSS换用原生XMLReader,HTML用DiDom,基本稳定

结构也做过拆分重构:

  • 引入Composer模块管理器
  • 把HTML解析规则配置化

但奇舞周刊,FEX周刊之类的feed无法解析,在PHP生态没有找到更好的RSS解析方案

五.服务迁移至node

原PHP服务器无法支持HTTPS(廉价虚拟主机限制),改用HTTPS顺便用node重写,发现了生态的巨大作用

  • RSS解析使用feedparser
  • HTML解析使用cheerio

feedparser能解析各种奇怪的不规范的XML(似乎有纠错容错处理),cheerio也没遇到奇怪的问题(BOM头导致乱码之类的),比之前PHP没有选择好太多了,繁荣的生态反过来推动语言的发展

添上了一些本该有的支持:

  • 定时抓取
  • 服务端内存缓存

服务功能还比较简单,但目前抓取部分算是稳定了

六.打包iOS真机安装

安卓打包发布在之前有说过:ionic开发跨平台App常见问题,环境要求比较麻烦

iOS打包需要OSX环境以及Xcode,目前真机调试已经不需要99刀认证的开发者账号,但上架App Store还是要交钱

0.环境

  • OSX@10.12.x: 支持构建ios10.x应用,低版本的只能构建ios9.x应用
  • Xcode@8.x: 支持构建ios10.x应用,Xcode 7.x只能构建ios9.x应用

注意:Xcode版本升级依赖OSX系统版本升级,OSX 10.9无法从App Store安装/更新Xcode 8

1.安卓iOS模拟器支持,并添加平台

npm install -g ios-sim
ionic platform add ios

2.构建

ionic build ios

3.模拟器运行

ionic emulate ios

4.真机安装

cd <path/to>/myapp/platforms/ios
# Open myapp.xcodeproj with Xcode
# USB connect the device
# Click Product>Destination>device name
# Click the triangle button(Build and run the current scheme)

注意:Xcode需要配置开发者账号,不用付费认证,只要是合法的apple id即可。启动应用会提示不受信任,需要去设置里信任开发者

七.项目地址

Github:https://github.com/ayqy/RSSHelper

事实上ionic的第一个版本就已经放上去了,但那时候还只是一个简单脆弱没有设计的应用,现在稍好一些,变得简单健壮了,下一步填充功能,支持自主订阅、用户管理之后,就是小型工具应用了

有一些后续的计划,总有一天会完成:

  • UE Optimizing
    • UI Style & Theme
    • Interaction
  • Function Enhancement
    • Login & User Management
    • Constom catelogy list
    • History & Favorite
    • Feedback

后话

除了WebView,另一个与笔者有不解之缘的关键字是贝塞尔曲线

永远做不完的文字识别项目中第一次听到贝塞尔曲线,Web Audio制作曲线频谱时找到了计算控制点的可靠方法,毕业的安卓涂鸦应用核心也是贝塞尔曲线

像一片羽毛落在水上泛开的涟漪,真正花了时间的东西,总会有奇怪的用处

原文发布于微信公众号 - ayqy(gh_690b43d4ba22)

原文发表时间:2017-05-13

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

扫码关注云+社区

领取腾讯云代金券