前端技术
HTML
CSS
Javascript
前端框架和UI库
VUE
ReactJS
AngularJS
JQuery
NodeJS
JSON
Element-UI
Bootstrap
Material UI
服务端和客户端
Java
Python
PHP
Golang
Scala
Kotlin
Groovy
Ruby
Lua
.net
c#
c++
后端WEB和工程框架
SpringBoot
SpringCloud
Struts2
MyBatis
Hibernate
Tornado
Beego
Go-Spring
Go Gin
Go Iris
Dubbo
HessianRPC
Maven
Gradle
数据库
MySQL
Oracle
Mongo
中间件与web容器
Redis
MemCache
Etcd
Cassandra
Kafka
RabbitMQ
RocketMQ
ActiveMQ
Nacos
Consul
Tomcat
Nginx
Netty
大数据技术
Hive
Impala
ClickHouse
DorisDB
Greenplum
PostgreSQL
HBase
Kylin
Hadoop
Apache Pig
ZooKeeper
SeaTunnel
Sqoop
Datax
Flink
Spark
Mahout
数据搜索与日志
ElasticSearch
Apache Lucene
Apache Solr
Kibana
Logstash
数据可视化与OLAP
Apache Atlas
Superset
Saiku
Tesseract
系统与容器
Linux
Shell
Docker
Kubernetes
[从启动失败到Tomcat配置文件恢复 ]的搜索结果
这里是文章列表。热门标签的颜色随机变换,标签颜色没有特殊含义。
点击某个标签可搜索标签相关的文章。
点击某个标签可搜索标签相关的文章。
转载文章
...partFile进行文件上传。 转换流程:BufferedImage → InputStream → MultipartFile //得到BufferedImage对象BufferedImage bufferedImage = JoinTwoImage.testEncode(200, 200, url);//创建一个ByteArrayOutputStreamByteArrayOutputStream os = new ByteArrayOutputStream();//把BufferedImage写入ByteArrayOutputStreamImageIO.write(bufferedImage, "jpg", os);//ByteArrayOutputStream转成InputStreamInputStream input = new ByteArrayInputStream(os.toByteArray());//InputStream转成MultipartFileMultipartFile multipartFile =new MockMultipartFile("file", "file.jpg", "text/plain", input); 本篇文章为转载内容。原文链接:https://blog.csdn.net/qq_39648029/article/details/111543794。 该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。
2023-11-25 22:36:21
321
转载
HTML
...假如您更喜欢在CSS文件中设定页面背景色彩,您也可以这样做: body { background-color: green; } 采用这种方式,您可以将HTML页面中的背景色彩集中到单个CSS文件中,使代码更整洁。 最后,无论您选择哪种方式,都要记得选择适合您网站主题的颜色,以获得最佳的视觉效果。
2023-05-13 16:29:20
497
数据库专家
VUE
...PEG或PNG以减小文件体积,或者利用CDN加速图片加载。另外,针对移动设备特性,可参考苹果推出的“适配视网膜显示屏”的最佳实践,采用2x甚至3x的图片源,确保在高DPI屏幕上也能清晰展示。 总之,无论是从技术实现还是用户体验角度,实现全屏图片展示的同时避免压缩变形都是现代Web开发的重要考量之一,而Vue.js及其生态提供了丰富的解决方案和最佳实践供开发者借鉴和学习。
2023-04-27 22:56:48
119
码农
Python
...hon中,组件是一种文件,包括了Python代码和其他资源。组件通常以.py为后缀,可以包括类、函数、属性等。Python组件放置目录是指这些组件放置的位置。 Python组件放置目录可以划分为全局组件放置目录和局部组件放置目录。 全局组件放置目录是指Python系统安装后自带的组件的放置位置。这些组件通常存储在Python解释器的site-packages目录下。在Windows系统中,这个目录位于Python的安装目录下的Lib\site-packages文件夹里。在Linux系统中,这个目录位于Python的安装目录下的/usr/local/lib/pythonX.X/site-packages文件夹里。其中,X.X表示Python的版本号。 局部组件放置目录是指我们自己创建的Python组件的放置位置。我们通常会根据需要创建一些Python组件来满足特定的需求。这些组件可以存储在任何我们希望的位置,只要确保Python程序能够找到它们即可。我们可以将这些组件放置在某个目录下,然后在Python程序中调用sys.path.append()方法将这个目录添加到Python路径中就可以了。 import sys sys.path.append('/path/to/module_directory') 在这个例子中,我们向Python路径中添加了一个名为module_directory的目录。这个目录可以放置我们创建的Python组件。 总之,Python组件放置目录是Python程序员必须了解的一些知识。准确地放置和组织Python组件可以帮助我们更好地管理Python程序,提高代码重用率,降低程序开发和维护成本。
2023-01-16 18:22:18
159
键盘勇士
VUE
...个部件库兼容录制媒体文件的多种功能,如影片、音频、GIF 动画。在该部件库中,我们只需要声明一个名为videoBlob的变量来保存影片并将其传输到服务器端。代码如下: import MediaRecorder from 'vue-media-recorder'; export default { components: { MediaRecorder }, data() { return { videoBlob: null }; }, methods: { startRecording() { this.$refs.mediaRecorder.startRecording(); setTimeout(() =>{ this.stopRecording(); }, 5000); }, stopRecording() { this.$refs.mediaRecorder.stopRecording(); }, saveRecording() { const formData = new FormData(); formData.append('time', new Date()); formData.append('video', this.videoBlob); // API call to send data to backend } }, watch: { videoBlob(val) { if (val) { this.saveRecording(); } } } } 在startRecording()函数中,我们使用setTimeout()函数来延后终止录制,这样我们就可以拍摄指定时间的延后影片。然后,在stopRecording()函数中,我们终止录制并将影片保存在videoBlob变量中。最后,在saveRecording()函数中,我们将影片资料和时间戳等信息一起传输到服务器端加工。 在 Vue 中使用延时拍摄功能非常简易,我们只需要添加一些代码和使用相应的部件库即可。以上代码仅供参考。在实际开发中,我们需要对其进行适度的调整。希望这篇文章能够帮助你更好地理解 Vue 中的延时拍摄功能。
2023-07-16 10:09:08
88
程序媛
HTML
...在省区选择框中,我们配置了 onChange 特性,并规定了一个名为 changeProvince 的方法,这个方法用于调整市区和区域选择框的项目。 function changeProvince() { var province = document.getElementById("province").value; var city = document.getElementById("city"); city.options.length = 0; if (province == "") { var area = document.getElementById("area"); area.options.length = 0; area.options.add(new Option("--请选择区域--","")); city.options.add(new Option("--请选择市区--","")); } else if (province == "1") { city.options.add(new Option("沈阳市","101")); city.options.add(new Option("大连市","102")); city.options.add(new Option("鞍山市","103")); } else if (province == "2") { city.options.add(new Option("长春市","201")); city.options.add(new Option("吉林市","202")); city.options.add(new Option("四平市","203")); } else if (province == "3") { city.options.add(new Option("哈尔滨市","301")); city.options.add(new Option("齐齐哈尔市","302")); city.options.add(new Option("牡丹江市","303")); } } 在上述程序中,我们解释了一个名为 changeProvince 的方法,它会取得选定省区的 value 数值,并对市区和区域选择框进行更改。通过更改 options 的长度,我们可以移除原有项目并增加新增项目。在增加新项目时,我们使用 add 方法来增加新增 Option 实体,其中第一个参数为项目的文本,第二个参数为项目的 value 数值。 其余的市区和区域的项目更改方法,以及 CSS CSS样式程序等,请自行处理。
2023-11-21 16:03:03
523
软件工程师
VUE
...将代码备份到一个临时文件中。当代码编辑完成后,Vue叉吗会比较编辑前后的代码,然后自动解决版本不一致。 当我们使用Vue叉吗处理冲突时,需要注意以下几点: 尽量减少对同一组件的并行修改。 编辑前要及时更新代码,确保本地代码与仓库代码保持一致。 在解决冲突时,要仔细阅读提示信息,并根据提示进行选择。 总之,Vue叉吗是一个非常实用的工具,它可以帮助我们有效地解决版本不一致的问题。当我们在使用Vue.js研制大型项目时,一定要注意避免出现版本不一致问题,以保障代码质量和研制效率。
2023-08-19 09:28:38
65
键盘勇士
MySQL
VUE
...作,并且提供了丰富的配置选项以满足复杂场景需求。同时,结合Vue的Async Components和Suspense特性,能够有效提升大型单页应用的数据加载体验和整体性能。 另外,针对数据密集型应用,Vue生态也提倡使用Vuex进行状态管理,通过集中式存储管理和响应式机制,确保组件间数据同步的高效与准确。配合Vue的异步数据获取方法,如async/await语法糖,可以在保证代码可读性的同时,显著改善应用程序的数据加载逻辑。 此外,前端性能优化领域,除了关注数据请求方式外,还包括缓存策略、服务端渲染(SSR)、静态生成(SSG)等技术手段。例如,Nuxt.js作为基于Vue的通用应用框架,为开发者提供了一站式的解决方案,包括但不限于服务端渲染、预取数据等功能,从而提升了Vue应用在SEO友好性和首屏加载速度方面的表现。 总之,在Vue应用程序开发过程中,合理选择数据请求方式并结合最新技术和最佳实践,对于构建高性能、用户体验优秀的Web应用至关重要。
2023-02-20 14:35:44
101
编程狂人
CSS
...上所示,我们可以通过配置宽高相等的尺寸来建立一个四方形。为了在该四方形中插入数字,我们必须将其内部的元素中心对齐。我们使用了CSS的flexbox排版,通过配置display: flex、justify-content: center、align-items: center,使内部元素横向和垂直中心对齐。 接下来,我们所需要做的就是在四方形中插入数字。为了使数字更加突出,我们配置了它的字体加粗,并配置了较大的字号。如果你需要调整数字的大小,只需修改font-size的值即可。 <div class="square">1</div> 最后,在HTML中加入刚刚建立的.square类,我们就可以愉快地插入数字了。这是一种简单有效的方式来使数字在网页中更加突出、易于辨识。
2023-06-14 12:07:04
426
软件工程师
Element-UI
...过Props进行功能配置,实现诸如禁用日期、自定义格式化、添加事件监听等功能,从而更好地满足用户在实际使用场景中的各种需求。不仅如此,Element Plus还深度整合了Vue 3的Composition API,使得在处理复杂的表单逻辑和状态管理时更为得心应手。 此外,针对无障碍设计和用户体验优化的趋势,Element Plus团队也在持续迭代更新,力求为开发者提供更完善的UI组件及配套的最佳实践指导,以适应不断变化的前端开发环境。因此,对于正在寻求提升日期选择器组件用户体验的开发者来说,了解和学习Element Plus的相关特性将是一个极具时效性和针对性的选择。
2023-07-02 11:30:26
497
秋水共长天一色_
VUE
...的单元测试工具,通过配置npm脚本来运行测试,并使用其提供的API来创建和执行针对Vue组件的测试用例。 shallowMount , shallowMount是Vue Test Utils库中提供的一个方法,专门用于在单元测试中浅层挂载(渲染)Vue组件。相较于完整挂载(render),浅层挂载只渲染当前组件本身,而不递归渲染其子组件,这样可以更快捷地聚焦于当前组件的行为测试,减少不必要的复杂性和开销。在文章中的例子中,shallowMount(Hello, propsData: name )用于创建一个包裹着Hello组件且传递了name属性的测试环境,以便进一步进行组件逻辑的验证。
2023-04-13 20:21:26
58
算法侠
转载文章
...于一个DLL或EXE文件,它决定了类和成员的内部可见性规则,比如C中的internal访问级别就限定了成员只在同一程序集内可见。 InternalsVisibleToAttribute , 这是一个特性(attribute)类,在C中以属性的形式应用于程序集级别,允许将标记为internal的类型和成员暴露给指定的友元程序集。通过在AssemblyInfo.cs文件中添加 assembly: InternalsVisibleTo(\ 指定的程序集名称\ ) ,可以突破常规的internal访问限制,使得特定程序集能够访问当前程序集中原本仅限于本程序集内部使用的类型和成员,从而增强了不同项目或组件间的协作能力,同时保持了一定程度的封装性。
2023-02-02 17:54:25
331
转载
Java
...尤其适用于网络通信、文件系统交互等高吞吐量场景。 此外,随着函数式编程范式的流行,Java 8及后续版本推出的Stream API提供了流畅且易于并行化的数据处理能力,极大提升了集合类数据的输入输出效率,特别是在数据过滤、转换、聚合等操作上,体现了现代化编程语言对输入输出处理的更高层次抽象。 综上所述,Java输入输出功能已从基础的控制台输入输出发展到支持高级数据流处理、高性能并发I/O以及更友好的字符串表示形式,未来将随着技术趋势持续演进,以满足日益复杂的软件工程应用场景需求。开发者应当关注这些最新进展,以便在实际项目中充分利用Java提供的强大工具和框架,提升程序效能和用户体验。
2023-12-24 11:21:23
398
数据库专家
CSS
...ndent 属性用来配置文本块的首个行文本首个行缩进。其取值可以是一个固定长度(如 px、em 等),也可以是一个百分比。当取值为负值时,文本将会被左移。 下面是一个基本示例,达成一个首个行首个行缩进 2em 的段落: p { text-indent: 2em; } 可以看到,我们使用了 p 标签来定义段落格式,使用 text-indent 属性配置首个行首个行缩进。 需要注意的是,text-indent 只对块元素有效,对于内联元素是无效的。如果想要内联元素的文本也首个行缩进,需要将其配置为块元素。 还有一种比较特殊情形,就是针对符号或数字列的样式。我们可以使用 list-style 属性来配置符号或数字列的样式,其中包含了一个 list-style-position 属性。这个属性可以用来配置符号或数字列的位置,包含 内部、外部 和 继承 三个取值。其中,我们可以使用 内部 取值来实现首个行缩进符号或数字列的效果。 下面是一个示例编程,达成一个首个行缩进标记列的效果: ul { list-style: none; margin: 0; padding: 0; } li:before { content: "•"; display: inline-block; width: 1em; text-align: center; margin-left: -1em; } li { text-indent: -2em; padding-left: 2em; } 可以看到,我们首先用 list-style: none 去除标记列的样式,然后通过 li:before 定义了一个符号元素(这里使用了实心圆点作为符号),并使用 text-indent 属性和 padding-left 属性来实现首个行缩进的效果。 总结一下,在 CSS 中,我们可以使用 text-indent 属性来实现段落首个行首个行缩进的效果,也可以使用 list-style-position 属性来实现符号或数字列的首个行缩进效果。这些简单的样式技巧能够让我们轻松地实现更加美观、易读的排版效果。
2023-02-27 22:17:26
525
逻辑鬼才
CSS
...文档中导入插件CSS文件地址。例如,比如我们要运用的插件为“plugin.css”,那么我们可以在head标签中插入以下代码: <link rel="stylesheet" type="text/css" href="plugin.css"> 接下来,我们要开始为插件的元素制定个性化样式规则。首先,我们需要识别插件组件标识符。一般可以通过审查元素的方式来查阅插件元素的属性。 例如,如果我们要调整插件元素的字号和颜色,可以运用以下代码: <style> .plugin-element { font-size: 14px; color: 333; } </style> 以上代码中,“.plugin-element”为插件元素的类名,“font-size”用于设置字号,“color”用于设置字体颜色。 如果想要替代插件元素的默认样式表,我们需要将自定义的样式表放在默认样式表之后,这样我们的样式表才会替代默认样式表。可以运用以下代码来实现: <link rel="stylesheet" type="text/css" href="plugin.css"> <style> .plugin-element { font-size: 14px; color: 333; } </style> 最后,我们还可以运用!important关键字来强制替代其他样式表。例如: .plugin-element { font-size: 14px!important; color: 333!important; } 需要注意的是,运用!important关键字可能会影响到其他样式表的表现,因此应该尽量避免运用。 综上所述,运用CSS样式表替代插件可以让我们更自如地定制网站元素的外观。同时,我们需要注意插件组件标识符,以及运用!important关键字的影响。
2023-05-26 10:19:55
459
编程狂人
Java
...理代码,如关闭打开的文件流、数据库连接等资源,以确保资源能够得到及时释放,避免内存泄漏等问题的发生。 异常类型匹配规则 , 在Java编程中,catch块需要指定具体的异常类型以便准确捕获对应的异常。这意味着只有当try块中抛出的异常与catch块后声明的具体异常类型相匹配(或者是其子类)时,该catch块才会被执行。例如,若try块内可能出现NullPointerException,那么需要有一个catch(NullPointerException e)块来捕获和处理这种类型的异常。 throw关键字 , throw是Java中用于手动抛出异常的关键字。程序员可以在代码中使用throw显式地抛出一个异常对象,这通常发生在检测到某种不可接受的状态或条件时,比如参数无效、资源未找到等情况。通过抛出异常,可以强制程序中断当前执行流程,并将控制权转移给能处理此异常的上层代码逻辑。 try-with-resources语句 , Java 7引入的一种简化资源管理的语法结构,允许在try语句后面直接定义和初始化资源,这些资源会在try代码块结束时自动关闭,无需在finally块中手动处理。这样不仅提高了代码的简洁性,还降低了因忘记关闭资源而导致的潜在风险。例如,在读写文件操作中,我们可以直接在try关键字后的括号内声明FileInputStream对象,编译器会确保在try块结束后正确关闭这个输入流。
2024-01-13 22:39:29
336
键盘勇士
Java
...以及更严格的默认安全配置。同时,为了帮助开发者更好地理解和应用这些安全措施,Oracle官方文档及社区博客定期发布关于如何在Java应用程序中正确实现和配置SSL/TLS连接的最佳实践和指南。 此外,开源社区也在积极推动相关工具和技术的发展,例如Apache HttpClient库已完全兼容TLS 1.3,使得Java开发者能够更加便捷地构建安全的HTTP客户端。另外,学术界和业界专家也不断进行研究和讨论,就如何在未来版本中进一步增强TLS协议的安全性提出新的观点和建议,为Java和其他编程语言在网络通信安全方面奠定了坚实的基础。 因此,对于Java开发者而言,关注TLS协议的最新发展动态、掌握Java中SSL/TLS的高级应用技巧,以及深入了解各种安全漏洞及其解决方案,是构建和维护高安全性网络应用程序的关键所在。
2023-05-26 16:19:14
314
算法侠
Kylin
...来说,当你打算把一个文件从一处搬到另一处,但这两个地方不在同一个磁盘分区上时,你的电脑操作系统就会犯迷糊,认不出磁盘分区,然后给你来个错误提示。这是因为不同的磁盘分区有不同的文件系统,如果你试图将文件从一种文件系统移动到另一种文件系统,操作系统就无法识别这个操作。 三、原因分析 那么,为什么我们在安装Kylin系统时会出现这种问题呢?这可能是由于以下几种原因: 1. 系统资源不足 如果你的计算机硬盘空间不足,系统可能无法正确地进行分区。 2. 文件系统不匹配 如果你试图将文件从一种文件系统移动到另一种文件系统,而这两个文件系统的版本不同,系统就可能出现识别错误。 3. 磁盘损坏 如果你的磁盘出现物理损坏,系统就可能无法正确地读取和写入数据。 四、解决方案 知道了问题的原因,我们就可以开始寻找解决问题的方法了。以下是一些常见的解决办法: 1. 扩展硬盘空间 如果你的硬盘空间不足,你可以尝试扩大硬盘的空间。这可以通过购买一个新的硬盘或者升级现有的硬盘来实现。 2. 更改文件系统 如果你试图将文件从一种文件系统移动到另一种文件系统,你可以尝试更改其中一个文件系统的版本。比如说,你要是想把文件从FAT32格式的盘挪到NTFS格式的盘,完全可以先把这个盘转换成NTFS格式,然后再进行文件搬家的操作。 3. 检查磁盘 如果你的磁盘出现物理损坏,你需要检查磁盘并修复或替换它。 五、实例演示 让我们来看一个具体的例子。假设你在安装Kylin系统时出现了磁盘分区识别错误。你可以按照以下步骤来解决问题: 1. 首先,检查你的硬盘空间。如果你的硬盘空间不足,你需要扩展硬盘空间。你可以通过购买一个新的硬盘或者升级现有的硬盘来实现。 2. 其次,检查你的文件系统。如果你想把文件从一个文件系统搬到另一个文件系统,那就得先瞧准了,这两个系统的版本得对得上号才行。你可以使用命令行工具来查看和更改文件系统的版本。例如,在Windows系统中,你可以使用fsutil fsinfo diskvolume信息来查看和更改文件系统的版本。 3. 最后,如果你的磁盘出现物理损坏,你需要检查磁盘并修复或替换它。你可以使用各种磁盘检测和修复工具来帮助你完成这个任务。 六、总结 总的来说,磁盘分区识别错误是一个比较常见的问题,但是只要你知道了它的原因,并且采取了正确的解决办法,你就能够成功地解决这个问题。记住了啊,不论你碰到啥困难、挑战,都要稳住心态,乐观面对,坚信自己肯定有办法把问题给解决了。别忘了,你可是个解决问题的小能手呢!
2023-04-06 20:16:18
186
雪域高原-t
VUE
...看、注释和保存PDF文件,大大提升了在线文档处理的用户体验。 同时,众多企业和开发者也在积极构建基于Web的开源解决方案,如PDF.js、pdfmake等项目,使得开发在线PDF编辑器和生成器变得更加简易高效。这些服务不仅支持从文本内容快速创建PDF,还能够处理表格、图像、列表等复杂结构,并确保跨平台兼容性良好。 此外,针对数据安全性和隐私保护问题,一些在线PDF工具也推出了加密生成、权限设置等功能,以满足企业和个人用户对于敏感信息处理的安全需求。因此,了解并合理利用这些在线PDF工具和技术,不仅可以提升工作效率,也是紧跟数字化时代发展步伐的重要表现。通过深入研究和实践,我们可预见在未来,更多创新的在线文档处理方案将不断涌现,持续推动无界办公和远程协作的新常态。
2023-11-07 11:10:47
80
程序媛
JQuery
...载了Jquery的库文件。然后,在页面中设定了一个div组件包含一个按钮和一张图片。 按钮具有一个id为“toggleButton”,而图片具有一个id为“catImage”,并且在最开始的时候其格式设置为“display:none”以隐蔽此图片。 在Jquery的脚本中,我们使用了“document.ready”函数,它会在页面加载时被自动地实行,并实行函数内部的代码。 我们使用了“click”函数来为按钮添加到点击动作,当用户点击按钮时,就会转换图片的可见性。如果图片是隐蔽的,那么它就会变为可见的,否则将隐蔽它。 通过这个简单的例子,我们可以看出Jquery是一个非常方便、实用的工具,并且通过使用Jquery,我们可以快速地呈现可交互、美观的网页效果。
2023-11-16 15:49:26
344
算法侠
Docker
...,在这个工具中,网络配置是至关重要的一部分,因为一个有效的容器网络能够为我们提供高效的服务保障。在这篇文章中,我们来讨论如何在Docker中创建一个网络。 $ docker network create --subnet 172.28.0.0/16 mynetwork 上面的命令将会在Docker中创建一个名为mynetwork的网络,同时设定了一个子网络的IP地址。这个IP地址是一个私有IP地址,用于Docker容器之间的通信。 $ docker run -itd --name container1 --net mynetwork --ip 172.28.1.100 ubuntu 上面的命令将会在mynetwork中创建一个名为container1的容器,并且将其IPIP地址设置为172.28.1.100。这个命令可以在每个容器中运行。 $ docker run -itd --name container2 --net mynetwork --ip 172.28.1.101 ubuntu 若需在mynetwork中新建另一个容器,则可以使用上面的命令来新建一个名为container2的容器,其IPIP地址为172.28.1.101。 $ docker network connect mynetwork container2 如果已然有一个容器并且想让它接入mynetwork中,则可以使用上面的命令将容器与网络链接。 $ docker network ls 此命令将展示当前Docker中的所有网络。 总之,创建一个Docker网络非常简单,并且Docker提供了强大的网络工具,使得我们可以轻松地创建并管理容器的网络。阅读本文后,您应该已然掌握了Docker网络的基本知识,现在您可以开始使用Docker来构建您的应用程序网络。
2023-11-16 16:39:36
494
算法侠
站内搜索
用于搜索本网站内部文章,支持栏目切换。
知识学习
实践的时候请根据实际情况谨慎操作。
随机学习一条linux命令:
netstat -tulpn
- 查看网络连接状态、监听端口等信息。
推荐内容
推荐本栏目内的其它文章,看看还有哪些文章让你感兴趣。
2023-04-28
2023-08-09
2023-06-18
2023-04-14
2023-02-18
2023-04-17
2024-01-11
2023-10-03
2023-09-09
2023-06-13
2023-08-07
2023-03-11
历史内容
快速导航到对应月份的历史文章列表。
随便看看
拉到页底了吧,随便看看还有哪些文章你可能感兴趣。
时光飞逝
"流光容易把人抛,红了樱桃,绿了芭蕉。"