一键自动化博客发布工具,用过的人都说好(oschina篇)

使用一键自动化博客发布工具blog-auto-publishing-tools把博客发布到oschina上。

oschina和segmentfault一样,界面非常的清爽。

界面上除了必须的标题,内容之外,还有文章专辑和推广专区这几个选项。

一起来看看在blog-auto-publishing-tools中,是如何实现自动发布到oschina的吧。

前提条件

前提条件当然是先下载 blog-auto-publishing-tools这个博客自动发布工具,地址如下:https://github.com/ddean2009/blog-auto-publishing-tools

oschina的实现

接下来我们手把手看看具体在oschina的自动化是如何实现的。

oschina的配置文件

除了title和content之外,oschina还需要一个文章专辑和推广专区:

image-20240506225816971

所以我们的配置文件大概是这样的:

其中collection是你自己创建的文章集合。

topic是oschina中自带的topic,你只需要从中间选择一个即可。

oschina的实现代码

所有的发布器都在publisher目录下,在下面你可以找到oschina_publisher这个专门给oschina的发布器。

首先我们需要打开新的tab,然后切换到oschina的博客发布页面:

填充文章内容

先看下页面上文章内容的信息:

image-20240506230435279

可以看到oschina使用的也是CodeMirror这个开源的代码编辑工具。

这个工具不同于传统的text或者textArea,他里面的元素是随着你的输入动态变化的,所以这里很难像传统的页面一样直接使用send_keys来填充内容。

那么我们怎么向CodeMirror输入内容呢?

既然send_keys不行,我们可以换一个思路,比如借助系统自带的复制和粘贴功能。

首先定位到内容的输入位置,然后把要输入的内容粘贴进去即可。

定位元素,我们是找到CodeMirror-code class下面的role=presentation的span即可。

这里,我们使用的是xpath定位。

然后使用ActionChains来模拟系统的粘贴操作。

填充文章的标题

标题部分比较简单,他有一个name字段:

image-20240506232051687

所以我们可以这样来使用:

文章专辑

接下来,我们点击发布文章按钮之后,就会显示一个弹出框。

这里我们需要填入文章专辑。

image-20240506225816971

文章专辑需要分两步走。

第一步是点击下拉框:

这里通过xpath来定位下拉框。

第二步是从下拉框选择对应的文章专辑:

同样的,我们使用xpath的contains来获取到text中包含有要选择专辑名字的列表。

推广专区

推广专区和文章专辑很类似,都是一个下拉框。

同样的,我们先点击下拉框:

然后选择对应的推广专区:

发布按钮

最后一步,就可以点击发布按钮发布了:

总结

这样我们对于oschina的自动发布就完成了。oschina相对而言比较简单,甚至没有封面上传:-)

最后更新于

这有帮助吗?