Java 开源博客 Solo 2.9.4 发布,新皮肤加数据库重构

本贴最后更新于 2270 天前,其中的信息可能已经水流花落

Solo 是一款一个命令就能搭建好的 Java 开源博客系统,如果你想开个独立博客,请一定不要错过!

imagepng

2.9.4 版本加入了一款新皮肤 nijigen,二次元萌娘控们值得一试。另外,这个版本我们做了一次数据库重构,从 2.9.3 升级前务必备份数据库后再升级!

案例

功能

  • Markdown / Emoji
  • 聚合分类 / 标签
  • 自定义导航(页面、链接)
  • 草稿夹
  • 评论/回复邮件提醒
  • 随机文章 / 相关文章 / 置顶 / 更新提醒
  • 自定义文章永久链接
  • 自定义站点 SEO 参数
  • 自定义公告 / 页脚
  • 多个签名档
  • 代码高亮 / 数学公式 / 流程图
  • 多皮肤,多端适配 / 社区皮肤
  • 多语言 / 国际化
  • 上传本地 / 七牛云
  • 友情链接管理
  • 多用户写作,团队博客
  • Hexo/Jekyll 导入
  • SQL / JSON / Markdown 导出
  • 插件系统
  • Atom / RSS 订阅
  • Sitemap
  • MetaWeblog API
  • CDN 静态资源分离

安装

  • 下载安装包
  • 解压后执行 java -cp "WEB-INF/lib/*;WEB-INF/classes" org.b3log.solo.Starter

从 2.9.3 升级只需将已有的配置拷贝覆盖即可,启动后会自动升级。升级前请备份数据库,以免出现意外!

文档

项目

2.9.4 变更记录

  • 12494 新皮肤 nijigen skin
  • 12486 Next 皮肤调整 enhancement
  • 12489 加强文章标签格式校验 enhancement
  • 12492 验证码改进 enhancement
  • 12495 skins 作为 git 子模块引入 development
  • 12507 删除 JDBC 连接池配置项 development
  • 12509 重构数据库 development
  • 12510 支持 MySQL 8 development
  • 12500 友情链接管理问题 bug

历史版本变更请浏览这里

  • Solo

    Solo 是一款小而美的开源博客系统,专为程序员设计。Solo 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    1434 引用 • 10055 回帖 • 488 关注
  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3187 引用 • 8214 回帖
  • 开源

    Open Source, Open Mind, Open Sight, Open Future!

    408 引用 • 3576 回帖
  • 博客

    记录并分享人生的经历。

    273 引用 • 2388 回帖 • 1 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • 升级失败了。
    [INFO ]-[2018-09-16 15:36:21]-[org.b3log.solo.service.UpgradeService:191]: Upgrading from version [2.9.3] to version [2.9.4]....
    [ERROR]-[2018-09-16 15:36:21]-[org.b3log.solo.service.UpgradeService:210]: Upgrade failed!
    org.h2.jdbc.JdbcSQLException: Duplicate column name "ARTICLEAUTHORID"; SQL statement:
    ALTER TABLE b3_solo_article ADD articleAuthorId VARCHAR(19) DEFAULT '' NOT NULL [42121-190]
    at org.h2.message.DbException.getJdbcSQLException(DbException.java:345)
    at org.h2.message.DbException.get(DbException.java:179)
    at org.h2.message.DbException.get(DbException.java:155)
    at org.h2.table.Table.setColumns(Table.java:409)

    1 回复
  • 88250

    看来只能自己手动处理了,DDL 操作没有回滚。

    1 回复
  • H2 数据库咋整呢?

    1 回复
  • 88250

    用 H2 自带的那个 web 管理工具,看下表结构。

    1. article 表里面删了三列 articleCreateDatearticleUpdateDatearticleAuthorEmail,多加了三列 articleCreatedarticleUpdatedarticleAuthorId
    2. comment 表里面删了一列 commentDate,多加了一列 commentCreated
    3. 确认下以上多加的列是否有值

    如果以上 3 步确认没问题,然后看下 option 表的 version 行,值如果是 2.9.3 的话,手动更新成 2.9.4 然后重启。

    1 回复
  • 手动升级了数据库,确认字段该有的都有,不该有的都没有.
    但是还是遇到了一个问题, 似乎是 FreeMarker 报告的:
    [ERROR]-[2018-09-16 17:09:01]-[org.b3log.latke.servlet.renderer.freemarker.AbstractFreeMarkerRenderer:138]: FreeMarker renders error
    FreeMarker template error:
    An error has occurred when reading existing sub-variable "articleUpdateDate"; see cause exception! The type of the containing value was: extended_hash+string (org.json.JSONObject wrapped into f.e.b.StringModel)


    FTL stack trace ("~" means nesting-related):
    - Failed at: ${article.articleUpdateDate?string("y... [in template "article-list.ftl" at line 27, column 21]
    - Reached through: #include "article-list.ftl" [in template "index.ftl" at line 63, column 21]

    Java stack trace (for programmers):

    freemarker.core._TemplateModelException: [... Exception message was already printed; see it above ...]
    at freemarker.ext.beans.BeanModel.get(BeanModel.java:183)
    at freemarker.core.Dot._eval(Dot.java:43)
    at freemarker.core.Expression.eval(Expression.java:83)
    at freemarker.core.BuiltInsForMultipleTypes$stringBI._eval(BuiltInsForMultipleTypes.java:692)
    at freemarker.core.Expression.eval(Expression.java:83)

  • 我是直接从 github 拉去的最新的源码到一个新目录中.
    只修改了 latke 的配置文件中关于域名的部分.
    然后, mvn jetty:run
    运行的.

  • 补充错误信息:

        at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:635)
        at org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:555)
        at java.base/java.lang.Thread.run(Thread.java:844)
    

    Caused by: java.lang.reflect.InvocationTargetException
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.base/java.lang.reflect.Method.invoke(Method.java:564)
    at freemarker.ext.beans.BeansWrapper.invokeMethod(BeansWrapper.java:1505)
    at freemarker.ext.beans.BeanModel.invokeGenericGet(BeanModel.java:272)
    at freemarker.ext.beans.BeanModel.get(BeanModel.java:152)
    ... 57 more
    Caused by: org.json.JSONException: JSONObject["articleUpdateDate"] not found.
    at org.json.JSONObject.get(JSONObject.java:540)
    ... 64 more

    1 回复
  • 我 grep 了一下
    articleUpdateDate
    似乎还有不少 ftl 模版在用这个.
    p.p1 {margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px Monaco; color: #f3f3bd; background-color: #2a2a2a; background-color: rgba(42, 42, 42, 0.96)} p.p2 {margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px Monaco; color: #f3f3bd; background-color: #2a2a2a; background-color: rgba(42, 42, 42, 0.96); min-height: 16.0px} span.s1 {font-variant-ligatures: no-common-ligatures} span.Apple-tab-span {white-space:pre}

    grep -ir articleUpdateDate .

    Binary file ./.git/index matches

    ./.idea/dataSources/e220bb86-34ca-4298-ab6f-714ddc29d30c.xml:

    ./src/test/resources/skins/mobile/article.ftl: ${article.articleUpdateDate?string("yyyy-MM-dd HH:mm:ss")}

    ./src/test/resources/skins/mobile/article-list.ftl: <div class="cal-month month-{article.articleUpdateDate?string("MM")}">{article.articleUpdateDate?string("MM")}

    ./src/test/resources/skins/mobile/article-list.ftl:

    ${article.articleUpdateDate?string("dd")}

    ./src/main/webapp/skins/ease/article.ftl: ${article.articleUpdateDate?string("yy-MM-dd HH:mm")}

    ./src/main/webapp/skins/ease/article-list.ftl: ${article.articleUpdateDate?string("yy-MM-dd HH:mm")}

    ./src/main/webapp/skins/owmx-3.0/article.ftl: {updateDateLabel}:{article.articleUpdateDate?string("yyyy-MM-dd HH:mm:ss")}

    ./src/main/webapp/skins/owmx-3.0/article-list.ftl: ${article.articleUpdateDate?string("yyyy-MM-dd HH:mm")}

    ./src/main/webapp/skins/NeoEase/article.ftl: ${article.articleUpdateDate?string("yyyy-MM-dd HH:mm:ss")}

    ./src/main/webapp/skins/NeoEase/article-list.ftl: ${article.articleUpdateDate?string("yyyy-MM-dd HH:mm:ss")}

    ./src/main/webapp/skins/tree-house/article.ftl: ${article.articleUpdateDate?string("yyyy-MM-dd HH:mm:ss")}

  • 似乎是由于 skin 都没有升级导致的啊~~~

  • 问题已经定位,就是由于部分皮肤没有升级兼容新版本的 solo 导致的.
    改用 Medium 皮肤后问题解决.

  • 仍然有少量报错:
    [ERROR]-[2018-09-16 17:42:19]-[org.b3log.solo.service.ArticleQueryService:862]: Gets relevant articles failed
    java.lang.IllegalStateException: java.lang.ClassCastException: java.base/java.lang.Long cannot be cast to java.base/java.util.Date
    at org.b3log.solo.util.comparator.ArticleUpdateDateComparator.compare(ArticleUpdateDateComparator.java:48)
    at org.b3log.solo.util.comparator.ArticleUpdateDateComparator.compare(ArticleUpdateDateComparator.java:32)
    at java.base/java.util.TimSort.countRunAndMakeAscending(TimSort.java:355)
    at java.base/java.util.TimSort.sort(TimSort.java:220)

  • 88250

    @linker 以上升级问题均已修复,非常感谢帮忙 ❤️️

    1 回复
  • iTanken

    备份以前的数据,然后不升级,直接用新版本,再还原数据,是不是有些数据还原不了?

    1 回复
  • 88250

    “还原”是什么操作?

    1 回复
  • iTanken

    额,不好意思,搞错了

  • oagnahz

    升级成功报个到。

  • 非常快的响应速度啊,赞 ~

  • oagnahz

    点击 ‘动态‘ ,500

    1 回复
  • 88250

    哪个皮肤?

    1 回复
  • oagnahz 1

    就是导航上面的动态 https://88250.b3log.org/dynamic.html

    1 回复
  • PeterChu 1

    QQ20180917150521png
    hahahahahahahhahahahahah,好萌啊😂

  • 88250

    已经修复 😅

    1 回复
  • oagnahz

    ok,幸苦 d 大

  • wangzp
    该回帖仅作者和楼主可见
    1 回复
  • 88250

    F12 看下请求

    2 回复
  • 88250

    主要是为了让用户可以“无缝”登录。

  • vinasis

    支持👍

  • wangzp

    Snipaste_20180918_095139png
    emmm

    Snipaste_20180918_095302png

  • wangzp

    为嘛 jquery.min.js 文件的内容变成了和 index 一样的内容?
    imagepng
    直接 cat 服务器上的 jquery.min.js 文件内容和控制台看见不一样啊。
    是我的配置有问题吗?

  • 发现对 option 的 SQL 读特别频繁,是不是考虑缓存下?

    [INFO ]-[2018-09-19 02:00:31]-[org.b3log.latke.repository.jdbc.util.JdbcUtil:150]: Executing SQL [ select * from b3_solo_option whereoptionCategory=? limit 0,2147483647]

    1 回复
  • 88250

    请关注这个 issue

  • iTanken

    Sym:
    imagepng
    Solo:
    imagepng

    从 Solo 同步过来的文章,在社区匿名评论,同步到 Solo 的评论还是实名的...

    1 回复
  • 88250

    Solo 那边没有匿名机制嘛。

    1 回复
  • iTanken 1

    哦哦 😂 。

    imagepng
    另外发现一个皮肤问题,侧边栏目录出现滚动条时,底部统计数据会随滚动条滚动

    1 回复
  • 88250
  • laker

    相同的错误,请问怎么解决的?

    2 回复
  • 88250

    是最新代码么?哪个皮肤?

  • skins 仓库里面的部分皮肤,仍然在模版里用了些老的字段。

  • washmore

    D 大太给面子了呀...我这就去升级 2.9.4 咩哈哈哈哈 ,另外发现最近的文章无法同步到社区来了,这个我也去看一下咩原因

  • pencilso

    emmmm.... 新皮肤我很喜欢~~~~

  • pencilso

    另外 感谢 D 大把我的博客放到 solo 介绍里。。。。 增加了浏览量 = =

  • zjhch123

    我也想把我做的那个皮肤加入进来呀,应该如何操作呢…

    1 回复
  • iTanken 1

    又发现一个 Feed 的问题,内容包含 Emoji 表情时,访问 /tag-articles-feed.do?oId=****** 报错:

    [Fatal Error] :2:9: 字符引用 "&#
    [ERROR]-[2018-09-28 14:12:58]-[org.b3log.latke.util.XMLs:66]: format pretty XML failed
    org.xml.sax.SAXParseException; lineNumber: 2; columnNumber: 9; 瀛楃寮曠敤 "&#
            at com.sun.org.apache.xerces.internal.parsers.DOMParser.parse(Unknown Source)
            at com.sun.org.apache.xerces.internal.jaxp.DocumentBuilderImpl.parse(Unknown Source)
            at org.b3log.latke.util.XMLs.format(XMLs.java:56)
            at org.b3log.solo.model.feed.atom.Feed.toString(Feed.java:330)
            at org.b3log.solo.processor.FeedProcessor.tagArticlesAtom(FeedProcessor.java:293)
            at org.b3log.solo.processor.FeedProcessor_$$_jvst305_31._d9tagArticlesAtom(FeedProcessor_$$_jvst305_31.java)
    

    imagepng

    1 回复
  • 88250

    你压缩下原文 txt zip 一个给我,我这里用原始 emoji 字符没重现。

    1 回复
  • iTanken

    imagepng

    imagepng

    如果订阅输出模式是摘要的话,需要在文章管理的摘要里填入 Emoji 才有效果

    1 回复
  • 88250

    我这里好像没啥问题,你有空的话拉个 master 的代码试试?

    1 回复
  • iTanken

    😮 哦哦,好

请输入回帖内容 ...