一、前言
一想都是满满的经历呀。如果不想看我废话,可以直接跳到后面。
1 关于编程
1.1 C、C++
作为一名软件工程生,编程是我以后自力更生的必备技能。奈何大一的我不懂得轻重,基本没有把精力放在编程上,以至于大一结束时只是似懂非懂地学了下C语言,对于作为C语言灵魂的指针那是一概不知。对于C语言的内存模型以及指针的理解还是在这学期加深的。学了C语言一定得学C++,它基于C,拓展C,对C语言的一些不足进行了优化,效率不输于C多少,更重要的是它采用了面向对象思想。
1.2 Python
大二我突然觉醒,意识到编程对我的重要性,但那时对编程的兴趣不算太大,于是找了相对简单的Python来学习,一学就上瘾。学Python基础用的是老师推荐的HeadFirst Python,简单易懂。跟着书我用flask框架设计出了我的第一个网页。
学完Python基础后,我去了解了一下更深的学习方向,有Web开发、爬虫、数据分析、人工智能等等。我选择了爬虫,于是买了本爬虫实战想要系统学习,正逢那会儿实验室招新,也许老师见我学习力十足,放我进去,于是我有了个可以专心搞技术的地方,有桌有电有网,何乐而不为?刚进去老师就让我跟着学长学姐一起做一个知识图谱的项目,需要某个网站的所有数据,而正好我又在学爬虫。于是,两个周内,我和搭档用各种爬虫(普通爬虫、多线程爬虫、scrapy框架、selenium爬虫)把那个网站所有的数据都整了下来,总共三百多兆。我现在都觉得我那两个周的学习不可思议,放在平时是不敢想象的。由于拿数据要分析网站,于是我对前端的理解(认知上)更深刻了。
在那之后,我产生一个想法,既然爬虫能够爬数据,那我是不是可以搞一个程序,把我想看的小说都给爬到本地来看呢。二话不说直接开整,一天不到我的初代小说爬虫就诞生了,不过是黑窗口,而且只能爬一本固定的小说。不过万事有个开头嘛,接下来不知道多少天,我对我的爬虫进行拓展,它慢慢开始成长。第一个我觉得比较重大的成长是它能够爬某个网站的指定小说了,不过依然是在黑窗口执行。
渐渐的,到了暑假实训的时候了,去了沈阳东软,报的Python方向。实训期间我那个爽呀,基础我都学完了,再听老师将就是巩固了,加深了我对Python的理解。学习之余,我又在摸索我的小说爬虫,想让它快快长大。实训接近尾声的时候,它成长到可以爬取若干本网站的指定小说了,而且我改用了多线程,解决了多线程爬取章节顺序的问题,大大加快了爬取速度。本次实训,老师讲了两个周的人工智能,不过说实话,我应该连门都没入。
假期剩下的这段时间,我一直在摸索人工智能,买了本深度学习入门,先学的神经网络,在转过去理解机器学习的一些算法。到假期结束,我已经会搭建卷积神经网络对图像进行识别,和对简单的英文问句进行分类,也理解了一些算法,比如朴素贝叶斯等等(现在都忘了)。
大三上的时候,我继续让我的爬虫成长,用了Python QT,把它设计成了一个桌面程序,总共可以爬取三十多个网站的任何小说(现在不知道还剩多少),而且可以搜索一些小说进行爬取,过滤了部分垃圾数据,并且增加了简单的阅读功能。
我会把软件放上,喜欢小说的小伙伴可以拿去试试,也可以给我评论哦!
小软件->小说爬虫
提取码:b1yw
1.3 Java
写完小说爬虫之后,我都在学习Java,也是从基础开始。在学习的过程中逐渐加深对面向对象的理解。学习时间比较漫长,直到寒假,才算是简单地过了一遍。紧接着就开始了JavaWeb的学习。从写html开始,学习简单的样式和js,学习servlet,以及理解网站开发的层次结构。用了半个寒假,我基本学完了传统的JavaWeb。正逢那会儿我在玩一个Steam上叫SpaceEngine的游戏,每次录制完视频之后都得放到格式工厂转码才能上传到某站。我就想:现在视频转换的软件那么多,我是不是可以搞个网页办的?正好刚学完Web基础,二话不说,直接开整。不做不知道,一做那个难呀。涉及到视频处理,那就得有上传、下载、预览的功能,注册和找回密码还得有邮件发送的功能,最重要的是视频处理,于是又去安装编译ffmpeg(超级坑)。网站做完了总得发布吧,不然别人怎么看,于是又去租用阿里云服务器,在上面搭建JavaWeb环境(也是超级坑)。我现在说的这么简短,开发期间那个难呀,不知道多少次整到我怀疑人生,网上的很多解决办法看似能解决问题,实则只能解决它们自己的问题,很多时候还得靠自己摸索。最终还是没有让自己失望,用传统的Web技术整出个简单的视频、音频上传、处理、下载的功能。
虽然功能不多,支持的音视频格式不多,但也算有个样子了。开发过程中涉及到的一些问题解决在我的另外一些博客里。网站也有一些问题没解决,比如断点续传,不过也能用。
接下来把网址放上,想体验的可以体验一下(服务器毕竟是学生机,下载速度堪忧)。
小网站->音视频简单处理
接下来当然是学习框架啦,想都不用想,从Spring开始,在这里,我第一次感受到了Java反射和注解的强大。Spring基础使用学完之后则学习持久化层框架Mybatis,我惊叹于把sql写到XML然后用反射创建对象是多么厉害的方式。接下来学习视图层SpringMVC,解决了之前做传统Web每个Servlet都要写一个类,并且在web.xml配置的繁琐操作。本学期的专业选修就是学习SSM,正好和我的学习进度对上。结课之后,我把Spring、SpringMVC还有Mybatis集成在一起(应该还可以更优化,不过能用),形成了SSM框架,并且做了个简单的好友录功能。
SSM集成(文笔不好勿怪)->SSM集成心得
提取码:cvgg
SSM运用->简单好友录
二、SpringBoot框架搭建和运用
接下来是正文。。。
1 SpringBoot框架搭建
1.1 Maven环境安装
Maven的安装和配置可以参照我的另一篇博客(注意加上阿里云镜像的配置,我那篇没有配置),只不过那篇是在Maven里面运用,而Springboot框架的搭建和使用在IDEA,只需要再在IDEA中配置一下maven就行。
1.2 用Maven创建Springboot项目
如图:
有些可能会遇到创建maven web项目之后没有生成webapp文件夹(很显然我遇到了)的情况(好像跟plugin有关),可以试试把下面的pom.xml配置好,然后maven会自动生成该目录。如果仍然没有,很可能是maven plugins不完整的原因,下面这一步给出了可能的解决方案。
1.3 pom.xml的配置
直接上代码,如果不要求特定版本的springboot,则可以直接复制,然后注意下有注释的地方:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.neusoft</groupId>
<artifactId>his3</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>war</packaging>
<name>his Maven Webapp</name>
<!-- FIXME change it to the project's website -->
<url>http://www.example.com</url>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
</properties>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.5.RELEASE</version>
<relativePath/>
</parent>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<!-- 如果打war包,在打包的时候把这块取消注释 -->
<!-- <exclusions>-->
<!-- <exclusion>-->
<!-- <groupId>org.springframework.boot</groupId>-->
<!--